/* ═══════════════════════════════════════════════════════════════
   KOJAK · REP SYSTEM
   ───────────────────────────────────────────────────────────────
   البنية الموحّدة لكل صفحات المندوب (Mobile + Laptop)

   هذا الملف يحتوي:
   • Layout Shell (الهيكل العام)
   • Sidebar (للابتوب) + Drawer (للجوال)
   • Bottom Nav (للجوال) + Top Bar (للابتوب)
   • App Bar (للصفحات الفرعية)
   • Forms, States, Modals مشتركة

   فلسفة التكيّف:
   • Mobile-first (الافتراضي)
   • Tablet/Laptop يضيف فقط (لا يستبدل)
   • نفس الـ DOM، CSS فقط يتكيّف

   لتغيير شيء في كل صفحات المندوب:
   • هنا (rep-system.css) للبنية
   • design-system.css للألوان والخطوط
   ═══════════════════════════════════════════════════════════════ */


/* ═══ 1. متغيرات Layout خاصة بالمندوب ═══════════════════════ */
:root {
    --rep-sidebar-w: 240px;
    --rep-content-max: 1200px;
    --rep-bottom-nav-h: 76px;
    --rep-appbar-h: 60px;
    --rep-page-px-mobile: 16px;
    --rep-page-px-desktop: 24px;
}


/* ═══ 2. Body Reset (خاص بصفحات rep) ════════════════════════ */
body.rep-body {
    background: var(--kj-bg);
    min-height: 100vh;
    margin: 0;
}


/* ═══ 3. Layout Shell (الهيكل الرئيسي) ══════════════════════ */
.rep-shell {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* المحتوى الرئيسي - حاوية */
.rep-content {
    flex: 1;
    width: 100%;
    max-width: var(--rep-content-max);
    margin: 0 auto;
    padding: 18px var(--rep-page-px-mobile);
    padding-bottom: calc(var(--rep-bottom-nav-h) + 24px);
}

/* للصفحات الفرعية بدون bottom nav */
.rep-content--no-nav {
    padding-bottom: 24px;
}

/* للصفحات التي بـ App Bar - الـ App Bar داخل المحتوى الآن */
.rep-content--with-appbar {
    padding-top: 18px;
}


/* ═══ 4. Top Bar (موحّد للجوال واللابتوب) ══════════════════════════ */
.rep-topbar {
    display: flex;
    position: sticky;
    top: 0;
    z-index: var(--kj-z-sticky);
    background: var(--kj-white);
    border-bottom: 1px solid var(--kj-gray-200);
    padding: 10px 16px;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    box-shadow: 0 1px 3px rgba(48, 57, 73, 0.04);
    /* في RTL: العنصر الأول في الـ DOM يظهر يميناً.
       نريد الشعار يساراً، لذا نضع الشعار آخراً في الـ DOM. */
}

.rep-topbar__brand {
    display: flex;
    align-items: center;
    text-decoration: none;
    color: inherit;
    flex-shrink: 0;
    margin-right: auto;
    transition: opacity var(--kj-transition-fast);
}

.rep-topbar__brand:hover {
    opacity: 0.85;
}

.rep-topbar__logo {
    height: 32px;
    width: auto;
    display: block;
    fill: var(--kj-dark);
}

.rep-topbar__right {
    display: flex;
    align-items: center;
    gap: 8px;
}

.rep-lang-switcher {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    padding: 3px;
    background: var(--kj-gray-100);
    border: 1px solid var(--kj-gray-200);
    border-radius: 12px;
    flex-shrink: 0;
}

.rep-lang-switcher__icon {
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
}

.rep-lang-option {
    min-width: 32px;
    height: 28px;
    padding: 0 7px;
    border: 0;
    border-radius: 9px;
    background: transparent;
    color: var(--kj-gray-500);
    font-family: inherit;
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
    transition: all var(--kj-transition-fast);
}

.rep-lang-option:hover {
    color: var(--kj-gold-deep);
}

.rep-lang-option.is-active {
    background: var(--kj-white);
    color: var(--kj-gold-deep);
    box-shadow: 0 2px 7px rgba(48, 57, 73, 0.1);
}

.rep-lang-option.is-loading {
    opacity: 0.5;
    pointer-events: none;
}

@media (max-width: 480px) {
    .rep-lang-switcher__icon,
    .rep-topbar__user-info {
        display: none;
    }

    .rep-lang-option {
        min-width: 29px;
        padding: 0 5px;
    }
}

.rep-topbar__user {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 10px 6px 6px;
    background: transparent;
    border: 0;
    border-radius: 30px;
    cursor: pointer;
    transition: background var(--kj-transition-fast);
    font-family: inherit;
    /* الترتيب: الاسم يمين ← Avatar يسار */
    flex-direction: row;
}

.rep-topbar__user:hover {
    background: var(--kj-cream-bg);
}

.rep-topbar__user:active {
    transform: scale(0.97);
}

.rep-topbar__user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--kj-cream-bg);
    border: 1px solid var(--kj-gold);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
    color: var(--kj-gold-deep);
    flex-shrink: 0;
}

.rep-topbar__user-avatar svg {
    display: block;
    width: 18px;
    height: 18px;
    color: var(--kj-gold-deep);
}

.rep-topbar__user-info {
    display: flex; /* ظاهر على الجوال واللابتوب */
    flex-direction: column;
    align-items: flex-start;
    line-height: 1.2;
    text-align: right;
}

.rep-topbar__user-name {
    font-size: 12px;
    font-weight: 600;
    color: var(--kj-dark);
    white-space: nowrap;
}

.rep-topbar__user-role {
    font-size: 10px;
    font-weight: 500;
    color: var(--kj-gray-500);
    white-space: nowrap;
}


/* ═══ 5. Sidebar (للابتوب فقط) ══════════════════════════════ */
.rep-sidebar {
    display: none;
}


/* ═══ 6. Bottom Navigation (الجوال) ═════════════════════════ */
.rep-bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--kj-white);
    border-top: 0.5px solid var(--kj-gray-200);
    padding: 10px 0 14px;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: end;
    z-index: var(--kj-z-sticky);
    box-shadow: 0 -2px 12px rgba(48, 57, 73, 0.04);
}

.rep-bottom-nav__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 6px 0;
    cursor: pointer;
    text-decoration: none;
    background: transparent;
    border: 0;
    font-family: inherit;
    color: var(--kj-gray-500);
    transition: all var(--kj-transition-fast);
}

.rep-bottom-nav__item:hover {
    color: var(--kj-gold-deep);
    transform: translateY(-2px);
}

.rep-bottom-nav__item:active {
    transform: scale(0.95);
}

.rep-bottom-nav__item.is-active {
    color: var(--kj-gold-deep);
}

.rep-bottom-nav__icon {
    font-size: 22px;
    line-height: 1;
}

.rep-bottom-nav__label {
    font-size: 12px;
    font-weight: 500;
}

/* الزر الأوسط الكبير (FAB) */
.rep-bottom-nav__fab-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 0 16px;
}

.rep-bottom-nav__fab {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--kj-gold);
    color: var(--kj-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 16px rgba(224, 199, 159, 0.4);
    margin-top: -32px;
    border: 4px solid var(--kj-white);
    cursor: pointer;
    text-decoration: none;
    transition: transform var(--kj-transition-fast),
                box-shadow var(--kj-transition-fast);
}

.rep-bottom-nav__fab:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(224, 199, 159, 0.5);
}

.rep-bottom-nav__fab:active {
    transform: scale(0.96);
}

.rep-bottom-nav__fab-icon {
    font-size: 28px;
    font-weight: 500;
    line-height: 1;
}

.rep-bottom-nav__fab-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--kj-dark);
    margin-top: -2px;
}


/* ═══ 7. Drawer (الجوال - يفتح من اليمين) ═══════════════════ */
.rep-drawer {
    position: fixed;
    inset: 0;
    z-index: var(--kj-z-drawer);
    visibility: hidden;
    opacity: 0;
    transition: opacity var(--kj-transition-normal),
                visibility var(--kj-transition-normal);
}

.rep-drawer.is-open {
    visibility: visible;
    opacity: 1;
}

.rep-drawer__overlay {
    position: absolute;
    inset: 0;
    background: rgba(48, 57, 73, 0.4);
}

.rep-drawer__content {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 280px;
    max-width: 85vw;
    background: var(--kj-white);
    transform: translateX(100%);
    transition: transform var(--kj-transition-normal);
    display: flex;
    flex-direction: column;
}

.rep-drawer.is-open .rep-drawer__content {
    transform: translateX(0);
}

/* صف الترويسة: حساب المستخدم (يمين) + الشعار (يسار) */
.rep-drawer__header {
    padding: 18px 20px;
    border-bottom: var(--kj-border-thin);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

/* جانب الحساب (يبقى على اليمين البصري - أول عنصر في DOM في RTL) */
.rep-drawer__user-side {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 1;
    min-width: 0;
}

/* الـ avatar */
.rep-drawer__user-side .kj-avatar {
    width: 36px !important;
    height: 36px !important;
    font-size: 14px !important;
    flex-shrink: 0;
}

/* معلومات المستخدم (الاسم + الفئة) */
.rep-drawer__user-info {
    min-width: 0;
}

/* اسم المستخدم */
.rep-drawer__user-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--kj-dark);
    margin: 0;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* فئة المستخدم (مندوب مبيعات) */
.rep-drawer__user-role {
    font-size: 11px;
    color: var(--kj-gray-500);
    margin: 2px 0 0;
    line-height: 1.2;
    white-space: nowrap;
}

/* الشعار (يبقى على اليسار البصري) */
.rep-drawer__brand {
    flex-shrink: 0;
}

.rep-drawer__brand-logo {
    height: 28px;
    width: auto;
    display: block;
    fill: var(--kj-dark);
}

.rep-drawer__nav {
    flex: 1;
    padding: 12px;
    overflow-y: auto;
}

.rep-nav-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px;
    border-radius: var(--kj-radius-lg);
    font-size: 15px;
    color: var(--kj-dark);
    cursor: pointer;
    text-decoration: none;
    transition: all var(--kj-transition-fast);
    border: 0;
    background: transparent;
    font-family: inherit;
    width: 100%;
    text-align: right;
}

.rep-nav-item:hover {
    background: var(--kj-cream-bg);
    transform: translateX(-4px);
}

.rep-nav-item.is-active {
    background: var(--kj-cream-bg);
    font-weight: 500;
    color: var(--kj-gold-deep);
}

.rep-nav-icon {
    font-size: 18px;
    width: 24px;
    text-align: center;
}

.rep-nav-divider {
    height: 0.5px;
    background: var(--kj-gray-200);
    margin: 12px;
    border: 0;
}

.rep-nav-item--logout {
    color: var(--kj-danger);
}

.rep-nav-item--logout:hover {
    background: var(--kj-danger-soft);
}


/* ═══ 8. App Bar (للصفحات الفرعية: login, new-order, ...) ═══ */
.rep-appbar {
    background: var(--kj-white);
    border-bottom: var(--kj-border-thin);
    padding: 12px var(--rep-page-px-mobile);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    min-height: var(--rep-appbar-h);
    /* غير sticky لأن Top Bar فوقه هو الـ sticky */
    margin: -18px calc(var(--rep-page-px-mobile) * -1) 16px;
}

.rep-appbar__left {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
    min-width: 0;
}

.rep-appbar__back {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--kj-gray-50);
    color: var(--kj-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 20px;
    font-weight: 500;
    line-height: 1;
    border: 0;
    cursor: pointer;
    flex-shrink: 0;
    transition: all var(--kj-transition-fast);
}

.rep-appbar__back:hover {
    background: var(--kj-cream-bg);
    color: var(--kj-gold-deep);
}

.rep-appbar__titles {
    flex: 1;
    min-width: 0;
}

.rep-appbar__title {
    font-size: 16px;
    font-weight: 500;
    color: var(--kj-dark);
    margin: 0;
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.rep-appbar__subtitle {
    font-size: 12px;
    color: var(--kj-gray-500);
    margin: 2px 0 0;
}

.rep-appbar__action {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--kj-gray-50);
    color: var(--kj-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    cursor: pointer;
    font-size: 16px;
    flex-shrink: 0;
    padding: 0;
    line-height: 0;
}

.rep-appbar__action svg {
    display: block;
    width: 14px;
    height: 14px;
}
    transition: all var(--kj-transition-fast);
}

.rep-appbar__action:hover {
    background: var(--kj-cream-bg);
    color: var(--kj-gold-deep);
}


/* ═══ 9. Cards & Surfaces ════════════════════════════════════ */
.rep-card {
    background: #FFFFFF;
    border: 1px solid #E5E7EB;
    border-radius: var(--kj-radius-xl);
    padding: 18px;
    margin-bottom: 14px;
    box-shadow: 0 1px 3px rgba(48, 57, 73, 0.08), 0 4px 12px rgba(48, 57, 73, 0.04);
    transition: all var(--kj-transition-fast);
}

.rep-card:hover {
    border-color: #D1D5DB;
    box-shadow: 0 2px 6px rgba(48, 57, 73, 0.10), 0 8px 16px rgba(48, 57, 73, 0.06);
}

.rep-card--cream {
    background: var(--kj-cream-bg);
    border-color: var(--kj-gold);
}

.rep-card--cream:hover {
    border-color: var(--kj-gold-deep);
    box-shadow: var(--kj-shadow-gold);
}

.rep-card__header {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 16px;
    padding-bottom: 14px;
    border-bottom: 0.5px solid var(--kj-gray-100);
}

.rep-card__icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: var(--kj-cream-bg);
    color: var(--kj-gold-deep);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    flex-shrink: 0;
}

.rep-card__title-wrap {
    flex: 1;
    min-width: 0;
}

.rep-card__title {
    font-size: 16px;
    font-weight: 500;
    color: var(--kj-dark);
    margin: 0;
}

.rep-card__subtitle {
    font-size: 13px;
    color: var(--kj-gray-500);
    margin: 4px 0 0;
}


/* ═══ 10. Forms ══════════════════════════════════════════════ */
.rep-form-group {
    margin-bottom: 16px;
}

.rep-form-label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--kj-dark);
    margin-bottom: 8px;
}

.rep-form-label__required {
    color: var(--kj-danger);
    margin-right: 2px;
}

.rep-input,
.rep-textarea,
.rep-select {
    width: 100%;
    padding: 12px 14px;
    font-size: 15px;
    font-family: inherit;
    color: var(--kj-dark);
    background: #F9F9F7;
    border: 1.5px solid #D1D5DB;
    border-radius: var(--kj-radius-lg);
    transition: var(--kj-transition-fast);
    -webkit-appearance: none;
    appearance: none;
}

.rep-input:focus,
.rep-textarea:focus,
.rep-select:focus {
    outline: none;
    background: #FFFFFF;
    border-color: var(--kj-gold);
    box-shadow: 0 0 0 3px rgba(224, 199, 159, 0.15);
}

.rep-input::placeholder,
.rep-textarea::placeholder {
    color: var(--kj-gray-400);
}

.rep-input.is-error,
.rep-textarea.is-error {
    border-color: var(--kj-danger);
}

.rep-input.is-error:focus,
.rep-textarea.is-error:focus {
    box-shadow: 0 0 0 3px var(--kj-danger-soft);
}

.rep-textarea {
    resize: vertical;
    min-height: 80px;
}

.rep-form-hint {
    font-size: 12px;
    color: var(--kj-gray-500);
    margin: 6px 0 0;
}

.rep-form-error {
    font-size: 12px;
    color: var(--kj-danger);
    margin: 6px 0 0;
}

.rep-form-divider {
    text-align: center;
    margin: 18px 0;
    font-size: 12px;
    color: var(--kj-gray-400);
    position: relative;
}

.rep-form-divider::before,
.rep-form-divider::after {
    content: '';
    position: absolute;
    top: 50%;
    width: calc(50% - 60px);
    height: 0.5px;
    background: var(--kj-gray-200);
}

.rep-form-divider::before { right: 0; }
.rep-form-divider::after { left: 0; }


/* ═══ 11. Buttons (إضافة لما في design-system) ══════════════ */
.rep-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 18px;
    border-radius: var(--kj-radius-lg);
    font-size: 15px;
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    transition: all var(--kj-transition-fast);
    user-select: none;
    -webkit-tap-highlight-color: transparent;
    border: 0;
    line-height: 1.4;
    text-decoration: none;
}

.rep-btn:active {
    transform: scale(0.98);
}

.rep-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.rep-btn--primary {
    background: #95B3C7;
    color: #FFFFFF;
}

.rep-btn--primary:hover:not(:disabled) {
    background: #7B9DB3;
    box-shadow: 0 4px 16px rgba(149, 179, 199, 0.4);
}

.rep-btn--secondary {
    background: var(--kj-white);
    color: var(--kj-dark);
    border: 1px solid var(--kj-gray-200);
}

.rep-btn--secondary:hover:not(:disabled) {
    border-color: var(--kj-gold);
    background: var(--kj-cream-bg);
}

.rep-btn--ghost {
    background: transparent;
    color: var(--kj-dark);
}

.rep-btn--ghost:hover:not(:disabled) {
    background: var(--kj-gray-50);
}

.rep-btn--danger {
    background: var(--kj-danger);
    color: var(--kj-white);
}

.rep-btn--danger:hover:not(:disabled) {
    background: var(--kj-danger-deep);
}

.rep-btn--block {
    width: 100%;
}

.rep-btn--lg {
    padding: 16px 22px;
    font-size: 16px;
}


/* ═══ 12. States (loading, empty, error) ═════════════════════ */
.rep-state {
    text-align: center;
    padding: 48px 20px;
}

.rep-state__icon {
    font-size: 48px;
    margin-bottom: 14px;
    opacity: 0.6;
}

.rep-state__title {
    font-size: 17px;
    font-weight: 500;
    color: var(--kj-dark);
    margin: 0 0 8px;
}

.rep-state__text {
    font-size: 14px;
    color: var(--kj-gray-500);
    margin: 0 0 16px;
}


/* ═══ 13. Modals ═════════════════════════════════════════════ */
.rep-modal {
    position: fixed;
    inset: 0;
    z-index: var(--kj-z-modal);
    visibility: hidden;
    opacity: 0;
    transition: opacity var(--kj-transition-normal),
                visibility var(--kj-transition-normal);
}

.rep-modal.is-open {
    visibility: visible;
    opacity: 1;
}

.rep-modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(48, 57, 73, 0.5);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 20px;
}

.rep-modal__content {
    background: var(--kj-white);
    border-radius: 20px 20px 0 0;
    width: 100%;
    max-width: 480px;
    max-height: 90vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transform: translateY(100%);
    transition: transform var(--kj-transition-normal);
}

.rep-modal.is-open .rep-modal__content {
    transform: translateY(0);
}

.rep-modal__header {
    padding: 18px 20px;
    border-bottom: var(--kj-border-thin);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}

.rep-modal__title {
    font-size: 17px;
    font-weight: 500;
    color: var(--kj-dark);
    margin: 0;
}

.rep-modal__close {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--kj-gray-50);
    color: var(--kj-dark);
    border: 0;
    cursor: pointer;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: var(--kj-transition-fast);
}

.rep-modal__close:hover {
    background: var(--kj-danger-soft);
    color: var(--kj-danger);
}

.rep-modal__body {
    flex: 1;
    overflow-y: auto;
    padding: 18px 20px;
}

.rep-modal__footer {
    padding: 14px 20px;
    border-top: var(--kj-border-thin);
    display: flex;
    gap: 10px;
}


/* ═══ 14. Alerts (موحّدة) ════════════════════════════════════ */
.rep-alerts {
    margin-bottom: 14px;
}

.rep-alert {
    padding: 12px 16px;
    border-radius: var(--kj-radius-lg);
    margin-bottom: 10px;
    font-size: 14px;
    line-height: 1.5;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.rep-alert__icon {
    font-size: 16px;
    flex-shrink: 0;
}

.rep-alert--success {
    background: var(--kj-success-soft);
    color: var(--kj-success-deep);
}

.rep-alert--danger {
    background: var(--kj-danger-soft);
    color: var(--kj-danger-deep);
}

.rep-alert--warning {
    background: var(--kj-warning-soft);
    color: var(--kj-warning-deep);
}

.rep-alert--info {
    background: var(--kj-info-soft);
    color: var(--kj-info-deep);
}


/* ═══ 15. Spinner ════════════════════════════════════════════ */
.rep-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(48, 57, 73, 0.15);
    border-top-color: var(--kj-gold-deep);
    border-radius: 50%;
    animation: rep-spin 700ms linear infinite;
    vertical-align: middle;
}

.rep-spinner--lg {
    width: 32px;
    height: 32px;
    border-width: 3px;
}

.rep-spinner--white {
    border-color: rgba(255, 255, 255, 0.3);
    border-top-color: var(--kj-white);
}

@keyframes rep-spin {
    to { transform: rotate(360deg); }
}


/* ═══ 16. Utilities (مختصرات) ════════════════════════════════ */
.rep-text-gold { color: var(--kj-gold-deep); }
.rep-text-muted { color: var(--kj-gray-500); }
.rep-text-danger { color: var(--kj-danger); }
.rep-text-success { color: var(--kj-success-deep); }


/* ═══════════════════════════════════════════════════════════════
   ▼▼▼ TABLET / LAPTOP RESPONSIVE ▼▼▼
   كل ما تحت هذا الخط يطبّق على شاشات ≥ 768px
   ═══════════════════════════════════════════════════════════════ */


/* ═══ 17. Tablet (≥768px) ════════════════════════════════════ */
@media (min-width: 768px) {
    .rep-content {
        padding: 24px var(--rep-page-px-desktop);
    }

    .rep-appbar {
        padding: 14px var(--rep-page-px-desktop);
    }
}


/* ═══ 18. Laptop (≥1024px) - تحويل كامل للتخطيط ══════════════ */
@media (min-width: 1024px) {

    /* Top Bar - تحسينات للابتوب فقط */
    .rep-topbar {
        padding: 12px 24px;
        gap: 16px;
    }

    .rep-topbar__logo {
        height: 36px;
    }

    /* تكبير الخط على اللابتوب */
    .rep-topbar__user-name {
        font-size: 13px;
    }

    .rep-topbar__user-role {
        font-size: 11px;
    }

    /* تفعيل Sidebar */
    .rep-shell {
        display: grid;
        grid-template-columns: var(--rep-sidebar-w) 1fr;
        grid-template-rows: auto 1fr;
        grid-template-areas:
            "topbar topbar"
            "sidebar main";
    }

    .rep-topbar { grid-area: topbar; }

    .rep-sidebar {
        display: flex;
        grid-area: sidebar;
        flex-direction: column;
        background: var(--kj-white);
        border-left: var(--kj-border-thin);
        padding: 18px 14px;
        gap: 6px;
        position: sticky;
        top: 60px;
        height: calc(100vh - 60px);
        overflow-y: auto;
    }

    .rep-sidebar__nav {
        display: flex;
        flex-direction: column;
        gap: 4px;
    }

    .rep-sidebar__footer {
        margin-top: auto;
        padding-top: 14px;
        border-top: var(--kj-border-thin);
    }

    /* المحتوى الرئيسي */
    main.rep-content,
    .rep-content {
        grid-area: main;
        padding: 24px 32px;
        padding-bottom: 32px;
        max-width: var(--rep-content-max);
    }

    /* إخفاء عناصر الجوال على اللابتوب */
    .rep-bottom-nav,
    .rep-drawer,
    .rep-mobile-only {
        display: none !important;
    }

    /* إخفاء App Bar على اللابتوب (الـ Top Bar يأخذ مكانه) */
    .rep-appbar {
        display: none;
    }

    /* لكن: في صفحات بدون Sidebar (مثل login)،
       نُظهر app bar وليس top bar */
    .rep-shell--auth {
        display: flex !important;
        grid-template-columns: none !important;
        grid-template-rows: none !important;
        grid-template-areas: none !important;
        flex-direction: column;
    }

    .rep-shell--auth .rep-topbar {
        display: none;
    }

    .rep-shell--auth .rep-content {
        max-width: 480px;
        padding: 32px 24px;
    }

    /* عناصر تظهر فقط على اللابتوب */
    .rep-desktop-only {
        display: block;
    }
}

/* الجوال: إخفاء العناصر المخصصة للابتوب */
@media (max-width: 1023px) {
    .rep-desktop-only {
        display: none !important;
    }
}


/* ═══ 19. Wide Desktop (≥1280px) - تحسينات إضافية ═══════════ */
@media (min-width: 1280px) {
    main.rep-content,
    .rep-content {
        padding: 32px 40px;
    }
}


/* ═══════════════════════════════════════════════════════════════
   نهاية REP SYSTEM
   ═══════════════════════════════════════════════════════════════ */


/* ═══════════════════════════════════════════════════════════════
   ▼▼▼ SUB-PAGE LAYOUT (للصفحات الفرعية مثل new-order) ▼▼▼
   صفحات تحتوي App Bar (موبايل) أو Page Header (لابتوب)
   ═══════════════════════════════════════════════════════════════ */

/* Page Header (يظهر على اللابتوب فقط - بدل App Bar) */
.rep-page-header {
    display: none;  /* مخفي افتراضياً (الموبايل) */
}

@media (min-width: 1024px) {
    .rep-page-header {
        display: flex;
        align-items: center;
        gap: 16px;
        padding: 8px 0 20px;
        margin-bottom: 8px;
        border-bottom: 0.5px solid var(--kj-gray-100);
    }

    .rep-page-header__back {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 8px 14px;
        font-size: 13px;
        font-weight: 500;
        color: var(--kj-gray-600);
        background: var(--kj-gray-50);
        border-radius: var(--kj-radius-lg);
        text-decoration: none;
        transition: all var(--kj-transition-fast);
        flex-shrink: 0;
    }

    .rep-page-header__back:hover {
        background: var(--kj-cream-bg);
        color: var(--kj-gold-deep);
        transform: translateX(4px);
    }

    .rep-page-header__titles {
        flex: 1;
        min-width: 0;
    }

    .rep-page-header__title {
        font-size: 22px;
        font-weight: 600;
        color: var(--kj-dark);
        margin: 0;
        line-height: 1.2;
    }

    .rep-page-header__subtitle {
        font-size: 13px;
        color: var(--kj-gray-500);
        margin: 4px 0 0;
    }

    /* صفحات الـ subpage: لا تحتوي على Bottom Nav padding */
    .rep-shell--subpage .rep-content {
        padding-bottom: 32px;
    }
}


/* ═══════════════════════════════════════════════════════════════════
   GLOBAL ALIGNMENT FIXES — إصلاحات شاملة للمحاذاة
   ─────────────────────────────────────────────────────────────────
   يُطبَّق على كل صفحات المندوب لمعالجة مشكلة baseline misalignment
   التي تحدث مع رموز Unicode (✕، ←، →، ▼، ➕، إلخ) داخل الأزرار
   الدائرية والمربعة.

   السبب الجذري: خطوط النظام العربية (Tajawal, IBM Plex Sans Arabic،
   إلخ) لها descender غير متماثل، فلا تتمركز الرموز بدقة ضمن صندوق
   الخط (font-box) حتى مع flex centering.
   ═══════════════════════════════════════════════════════════════════ */

/* ─── 1. أزرار التحكم العامة للـ topbar/appbar ─── */
.rep-topbar__user,
.rep-topbar__user-avatar,
.rep-appbar__back,
.rep-appbar__action,
.rep-page-header__back,
.rep-bottom-nav__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* ─── 2. الـ Avatar في Drawer (الـ Side Menu) ─── */
.kj-avatar,
.rep-drawer__user-side .kj-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* ─── 3. أزرار Sidebar/Drawer العامة ─── */
.rep-sidebar__btn,
.rep-drawer__btn,
.rep-drawer__close,
.rep-drawer__menu-btn {
    display: inline-flex;
    align-items: center;
    line-height: 1;
}

/* ─── 4. زر الرجوع في AppBar (السهم ←) ─── */
.rep-appbar__back,
.rep-page-header__back {
    /* السهم ← في الخطوط العربية له offset رأسي طفيف */
    line-height: 1;
}

/* ─── 5. الأيقونات داخل الأزرار النصية ─── */
.btn-primary-full > span,
.btn-secondary-full > span,
.btn-primary-half > span,
.btn-secondary-half > span,
.btn-success-full > span {
    display: inline-flex;
    align-items: center;
    line-height: 1;
}

/* ─── 6. ضبط الأيقونات النصية الكبيرة (مثل arrows) ─── */
.btn-primary-full .arrow,
.btn-secondary-full .arrow,
.btn-primary-half .arrow,
.btn-secondary-half .arrow {
    display: inline-block;
    line-height: 1;
    vertical-align: middle;
}

/* ─── 7. SVG Icons - يجب أن تكون block وليست inline ─── */
button > svg,
a > svg,
.icon-btn > svg {
    display: block;
    flex-shrink: 0;
}

/* ─── 8. أيقونات Step Headers (الإيموجي 👤، 📷، إلخ) ─── */
.step-icon,
.kj-modal__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* ─── 9. شارات (badges) - مثل عيار 21 ─── */
.scanned-row__karat,
.scanner-card__name small,
.product-item__karat,
.kj-badge {
    display: inline-flex;
    align-items: center;
    line-height: 1;
}

/* ─── 10. عداد الإحصائيات في الماسح ─── */
.scanner-cards__counter,
.scanner-cards__stats,
.scanner-cards__stat,
.scanner-cards__stat-value,
.scanner-cards__stat-label,
.scanner-cards__stat-divider {
    line-height: 1;
}

.scanner-cards__stats {
    display: inline-flex;
    align-items: center;
}

.scanner-cards__stat {
    display: inline-flex;
    align-items: baseline;
}

/* ─── 11. حقول الإدخال - باركود scanner ─── */
.scanner-fullscreen__status,
.scanner-feedback__title,
.scanner-feedback__subtitle {
    line-height: 1.3;
}

/* ─── 12. أزرار الـ scanner controls (دائرية) ─── */
.scanner-fullscreen__controls .scanner-btn-icon,
.scanner-fullscreen__controls .scanner-btn-zoom,
.scanner-fullscreen__controls .scanner-zoom-value {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* ─── 13. زر "تم" في الماسح ─── */
.scanner-btn-done-full {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* ─── 14. الـ Form labels والـ hints ─── */
.form-group label,
.form-hint {
    line-height: 1.4;
}

/* ─── 15. Top Bar user info (الاسم + الدور) ─── */
.rep-topbar__user-info {
    line-height: 1.2;
}

.rep-topbar__user-name,
.rep-topbar__user-role {
    line-height: 1.3;
}

/* ─── 16. Drawer user info ─── */
.rep-drawer__user-info {
    line-height: 1.2;
}

.rep-drawer__user-name,
.rep-drawer__user-role {
    line-height: 1.3;
}

/* ─── 17. Toast الحذف ─── */
.kj-delete-toast__icon,
.kj-delete-toast__title,
.kj-delete-toast__details {
    line-height: 1.3;
}

.kj-delete-toast__icon {
    line-height: 1;
}

/* ─── 18. الإيموجي العربية (مثل ▼ في step-header__arrow) ─── */
.step-header__arrow,
.toggle-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
