/* ============================================================
   AyubiSoft — سیستم مدیریت انبار و فروش
   Mobile First · RTL · Vazirmatn
   ============================================================ */

:root {
    --color-primary:    #0B6E4F;
    --color-primary-dk: #08503A;
    --color-primary-lt: #E6F4EE;
    --color-accent:     #E8A33D;
    --color-accent-dk:  #C97F1F;
    --color-danger:     #C1432F;
    --color-danger-lt:  #FBEAE6;
    --color-ink:        #1A2421;
    --color-muted:      #637370;
    --color-bg:         #F3F5F3;
    --color-surface:    #FFFFFF;
    --color-border:     #E2E6E1;

    --radius-sm:   10px;
    --radius-md:   16px;
    --radius-lg:   22px;
    --radius-xl:   28px;
    --radius-pill: 999px;

    --shadow-sm:   0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.05);
    --shadow-md:   0 4px 12px rgba(0,0,0,.08), 0 1px 3px rgba(0,0,0,.05);
    --shadow-lg:   0 10px 24px rgba(0,0,0,.10), 0 2px 6px rgba(0,0,0,.05);

    --ease: cubic-bezier(.4, 0, .2, 1);
    --dur:  160ms;

    --topbar-h:    62px;
    --bottomnav-h: 70px;
}

/* ── Reset & Base ─────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html {
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

html, body {
    font-family: 'Vazirmatn', Tahoma, Arial, sans-serif;
    background: var(--color-bg);
    color: var(--color-ink);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body.app-body {
    min-height: 100vh;
    padding-top: var(--topbar-h);
    padding-bottom: calc(var(--bottomnav-h) + env(safe-area-inset-bottom));
    overscroll-behavior-y: none;
}
/* Remove bottom-nav padding reservation on desktop where it's hidden */
@media (min-width: 768px) {
    body.app-body { padding-bottom: 32px; }
}

h1,h2,h3,h4,h5,h6 { font-weight: 700; }
a { text-decoration: none; }

/* ── Touch Optimisation ───────────────────────────────── */
/* Eliminates 300 ms click delay on mobile browsers */
a, button, [role="button"],
.btn, .icon-btn, .side-link,
.bottom-nav-item, .bottom-nav-fab,
.qa-btn, .list-group-item-action, label {
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

/* ── Topbar ──────────────────────────────────────────── */
.app-topbar {
    position: fixed;
    top: 0; right: 0; left: 0;
    height: var(--topbar-h);
    background: linear-gradient(135deg, var(--color-primary-dk) 0%, var(--color-primary) 100%);
    color: #fff;
    display: flex;
    align-items: center;
    padding: 0 6px;
    z-index: 1030;
    box-shadow: 0 2px 12px rgba(8,80,58,.28);
}
.app-topbar-title {
    flex: 1;
    text-align: center;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    line-height: 1.2;
    overflow: hidden;
    gap: 1px;
}
.app-topbar-brand {
    font-size: .65rem; font-weight: 900;
    letter-spacing: .14em; text-transform: uppercase;
    color: rgba(255,255,255,.6);
}
.app-topbar-page {
    font-weight: 700; font-size: 1rem;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    max-width: 100%;
}
.icon-btn {
    color: #fff; background: transparent; border: none;
    width: 44px; height: 44px;
    display: flex; align-items: center; justify-content: center;
    border-radius: var(--radius-pill);
    font-size: 1.25rem;
    transition: background var(--dur) var(--ease);
    flex-shrink: 0;
}
.icon-btn:hover, .icon-btn:active { background: rgba(255,255,255,.15); color: #fff; }

/* ── AyubiSoft Brand ─────────────────────────────────── */
.ayubisoft-brand {
    font-size: .82rem; font-weight: 900;
    letter-spacing: .1em; text-transform: uppercase;
    color: var(--color-primary);
    line-height: 1; margin-bottom: 3px; text-align: center;
}
.login-ayubisoft {
    font-size: .88rem; font-weight: 900;
    letter-spacing: .14em; text-transform: uppercase;
    color: var(--color-primary);
    display: block; width: 100%; text-align: center;
    margin: 0 auto 6px;
}

/* ── Sidebar ─────────────────────────────────────────── */
.offcanvas-header { padding: 18px 18px 14px; }
.offcanvas-title  { font-size: .98rem; }

.side-link {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 14px;
    margin: 2px 8px;
    border-radius: var(--radius-md);
    color: var(--color-ink);
    font-weight: 500; font-size: .9rem;
    min-height: 46px;
    transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.side-link i {
    font-size: 1.1rem; color: var(--color-muted);
    width: 22px; text-align: center;
    transition: color var(--dur) var(--ease);
}
.side-link:hover { background: var(--color-primary-lt); color: var(--color-primary-dk); }
.side-link:hover i { color: var(--color-primary); }
.side-link.active {
    background: var(--color-primary); color: #fff;
    font-weight: 600;
    box-shadow: 0 3px 10px rgba(11,110,79,.3);
}
.side-link.active i { color: #fff; }

/* ── Main Content ─────────────────────────────────────── */
.app-main {
    padding: 16px;
    max-width: 1100px;
    margin: 0 auto;
}

/* ── Bottom Nav ─────────────────────────────────────── */
.bottom-nav {
    position: fixed;
    bottom: 0; right: 0; left: 0;
    height: var(--bottomnav-h);
    background: rgba(255,255,255,.97);
    border-top: 1px solid rgba(0,0,0,.07);
    display: flex; align-items: center; justify-content: space-around;
    z-index: 1030;
    padding-bottom: env(safe-area-inset-bottom);
    box-shadow: 0 -2px 16px rgba(0,0,0,.07);
}
.bottom-nav-item {
    display: flex; flex-direction: column; align-items: center; gap: 3px;
    color: var(--color-muted);
    font-size: .65rem; font-weight: 500;
    flex: 1; min-height: 50px;
    padding: 6px 4px;
    border-radius: var(--radius-md);
    transition: color var(--dur) var(--ease);
    position: relative;
}
.bottom-nav-item i { font-size: 1.3rem; transition: transform var(--dur) var(--ease); }
.bottom-nav-item.active { color: var(--color-primary-dk); font-weight: 700; }
.bottom-nav-item.active i { transform: scale(1.1); }
.bottom-nav-item.active::before {
    content: '';
    position: absolute; top: 4px;
    left: 50%; transform: translateX(-50%);
    width: 36px; height: 36px;
    background: var(--color-primary-lt);
    border-radius: var(--radius-md);
    z-index: -1;
}
.bottom-nav-fab {
    width: 54px; height: 54px;
    border-radius: var(--radius-pill);
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dk) 100%);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.55rem;
    margin-top: -24px;
    box-shadow: 0 6px 20px rgba(11,110,79,.45);
    border: 3px solid var(--color-bg);
    transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.bottom-nav-fab:hover  { transform: scale(1.06); box-shadow: 0 8px 24px rgba(11,110,79,.5); }
.bottom-nav-fab.active { background: linear-gradient(135deg, var(--color-primary-dk) 0%, #054330 100%); }

/* ── Cards ──────────────────────────────────────────── */
.card {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}
.kpi-card {
    background: var(--color-surface);
    border-radius: var(--radius-md);
    padding: 18px 16px;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.kpi-card:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }
.kpi-card .kpi-label { color: var(--color-muted); font-size: .78rem; font-weight: 600; letter-spacing: .02em; }
.kpi-card .kpi-value { font-size: 1.55rem; font-weight: 800; margin-top: 5px; }
.kpi-card .kpi-icon {
    width: 44px; height: 44px; border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem;
    background: var(--color-primary-lt); color: var(--color-primary-dk);
}

/* ── Buttons ─────────────────────────────────────────── */
.btn {
    border-radius: var(--radius-md);
    font-weight: 600;
    min-height: 40px;
    transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease),
                background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.btn:active { transform: scale(.97); }
.btn-sm { min-height: 34px; }
.btn-lg { border-radius: var(--radius-lg); padding: .75rem 1.5rem; font-size: 1rem; min-height: 48px; }

.btn-primary {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dk) 100%);
    border-color: var(--color-primary-dk);
    box-shadow: 0 2px 8px rgba(11,110,79,.28);
}
.btn-primary:hover, .btn-primary:active {
    background: linear-gradient(135deg, var(--color-primary-dk) 0%, #054330 100%);
    border-color: var(--color-primary-dk);
    box-shadow: 0 4px 14px rgba(11,110,79,.38);
}
.btn-outline-primary {
    color: var(--color-primary); border-color: var(--color-primary); border-width: 1.5px;
}
.btn-outline-primary:hover {
    background: var(--color-primary); border-color: var(--color-primary);
    box-shadow: 0 2px 8px rgba(11,110,79,.25);
}
.btn-outline-danger    { border-width: 1.5px; }
.btn-outline-secondary { border-width: 1.5px; }

/* ── Form inputs ─────────────────────────────────────── */
.form-control, .form-select {
    border-radius: var(--radius-md);
    border-color: var(--color-border);
    font-size: 1rem; /* 16 px — prevents iOS auto-zoom on focus */
    transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.form-control:focus, .form-select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(11,110,79,.14);
}
/* On mobile keep sm controls at 16 px to prevent iOS zoom */
.form-control-sm, .form-select-sm { font-size: 1rem; }
@media (min-width: 768px) {
    .form-control-sm, .form-select-sm { font-size: .875rem; }
}
.form-control-lg { border-radius: var(--radius-lg); }

/* ── Login Page ──────────────────────────────────────── */
.login-screen {
    min-height: 100vh;
    min-height: 100dvh; /* respect mobile browser chrome */
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(155deg, #054330 0%, var(--color-primary-dk) 40%, var(--color-primary) 75%, #12A06E 100%);
    padding: 20px;
}
.login-card {
    background: var(--color-surface);
    border-radius: var(--radius-xl);
    padding: 36px 28px;
    width: 100%; max-width: 390px;
    box-shadow: 0 24px 60px rgba(0,0,0,.3), 0 8px 24px rgba(0,0,0,.15);
}
.login-logo {
    width: 62px; height: 62px; border-radius: 18px;
    background: linear-gradient(135deg, var(--color-primary-lt) 0%, #d4eee4 100%);
    color: var(--color-primary-dk);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.9rem;
    margin: 0 auto 16px;
    box-shadow: 0 4px 14px rgba(11,110,79,.2);
}

/* ── POS Two-Column Layout ───────────────────────────── */
/*
   Mobile  : single column — controls stack above cart
   ≥768 px : flex row — RTL positions controls on RIGHT, cart on LEFT
*/
.pos-layout { display: flex; flex-direction: column; gap: 0; }

@media (min-width: 768px) {
    .pos-layout {
        flex-direction: row;   /* RTL: first child = right, second = left */
        align-items: flex-start;
        gap: 20px;
    }
    .pos-controls {
        flex: 1; min-width: 0;
        position: sticky;
        top: calc(var(--topbar-h) + 16px);
    }
    .pos-cart {
        width: 360px; flex-shrink: 0;
        display: flex; flex-direction: column; gap: 12px;
        position: sticky;
        top: calc(var(--topbar-h) + 16px);
        max-height: calc(100vh - var(--topbar-h) - 48px);
    }
    /* Cart card scrolls internally when many items */
    .pos-cart .card {
        flex: 1; min-height: 100px;
        overflow-y: auto;
        overscroll-behavior: contain;
    }
    /* Total bar is pinned inside the sticky cart column */
    .cart-total-bar {
        position: static !important;
        bottom: auto !important;
        flex-shrink: 0;
    }
}

/* ── Scanner / POS ──────────────────────────────────── */
.scan-input-wrap { position: relative; }
.scan-input {
    font-size: 1.15rem;
    padding: 14px 50px 14px 16px;
    border-radius: var(--radius-lg);
    border: 2px solid var(--color-primary);
    text-align: center;
    font-weight: 600; letter-spacing: .5px;
    transition: box-shadow var(--dur) var(--ease);
}
.scan-input:focus {
    box-shadow: 0 0 0 4px rgba(11,110,79,.15);
    border-color: var(--color-primary);
    outline: none;
}
.scan-icon-badge {
    position: absolute; right: 14px; top: 50%; transform: translateY(-50%);
    color: var(--color-primary); font-size: 1.3rem;
    pointer-events: none;
}
.input-group .scan-input {
    padding-right: 16px;
    border-radius: var(--radius-lg) 0 0 var(--radius-lg) !important;
}

/* Cart rows */
.cart-row {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 8px;
    border-bottom: 1px solid var(--color-border);
    transition: background var(--dur) var(--ease);
}
.cart-row:last-child { border-bottom: none; }
.cart-row:active     { background: var(--color-bg); }
.cart-name  { font-weight: 600; flex: 1; min-width: 0; }
.cart-meta  { font-size: .78rem; color: var(--color-muted); margin-top: 2px; }

/* Quantity control — 40 px on touch, 36 px on desktop */
.qty-control { display: flex; align-items: center; gap: 4px; }
.qty-control button {
    width: 36px; height: 36px;
    border-radius: var(--radius-pill);
    border: 1.5px solid var(--color-border);
    background: var(--color-surface);
    line-height: 1; font-size: .95rem;
    display: flex; align-items: center; justify-content: center;
    transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
    cursor: pointer; flex-shrink: 0;
}
@media (pointer: coarse) {
    /* Finger-sized touch targets on phones/tablets */
    .qty-control button { width: 40px; height: 40px; }
}
.qty-control button:hover  { background: var(--color-primary-lt); border-color: var(--color-primary); }
.qty-control button:active { transform: scale(.90); }

.cart-total-bar {
    position: sticky;
    bottom: calc(var(--bottomnav-h) + 8px);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 16px;
    box-shadow: var(--shadow-lg);
    margin-bottom: 12px;
}

/* ── Tables ──────────────────────────────────────────── */
.table-responsive-card table { margin-bottom: 0; }
.table > :not(caption) > * > * { padding: .7rem .65rem; }
.table thead th {
    font-size: .8rem; font-weight: 700;
    color: var(--color-muted);
    text-transform: uppercase; letter-spacing: .04em;
}

/* ── Badges ──────────────────────────────────────────── */
.badge-stock-low { background: var(--color-danger-lt); color: var(--color-danger); border-radius: var(--radius-pill); }
.badge-stock-ok  { background: var(--color-primary-lt); color: var(--color-primary-dk); border-radius: var(--radius-pill); }
.badge { border-radius: var(--radius-pill); font-weight: 600; }

/* ── Skeleton ────────────────────────────────────────── */
.skeleton {
    background: linear-gradient(90deg, #e8ece8 25%, #f2f5f2 50%, #e8ece8 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.3s ease-in-out infinite;
    border-radius: var(--radius-md);
}
@keyframes skeleton-loading {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ── Empty State ─────────────────────────────────────── */
.empty-state {
    text-align: center;
    padding: 48px 16px;
    color: var(--color-muted);
}
.empty-state i {
    font-size: 2.8rem; color: var(--color-border);
    display: block; margin-bottom: 12px;
}

/* ── Focus Accessibility ─────────────────────────────── */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible {
    outline: 3px solid var(--color-accent);
    outline-offset: 2px;
}
/* Hide focus ring for pointer/touch users; show only for keyboard navigation */
:focus:not(:focus-visible) { outline: none; }

/* ── Dashboard Layout ────────────────────────────────── */
.dash-layout { display: flex; flex-direction: column; gap: 16px; }
@media (min-width: 992px) {
    .dash-layout {
        display: grid;
        grid-template-columns: 1fr 180px;
        gap: 20px; align-items: start;
    }
    .dash-quick-nav { grid-column: 2; grid-row: 1; position: sticky; top: calc(var(--topbar-h) + 16px); }
    .dash-main      { grid-column: 1; grid-row: 1; }
}

/* Quick-nav */
.dash-quick-nav > .card { border-top: 3px solid var(--color-primary); padding: 0; }
.qa-nav-title {
    display: flex; align-items: center; gap: 6px;
    padding: 10px 12px 8px;
    font-size: .74rem; font-weight: 700;
    color: var(--color-muted); letter-spacing: .05em;
    border-bottom: 1px solid var(--color-border);
}
.qa-nav-title i { font-size: .9rem; color: var(--color-primary); }

.qa-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(74px, 1fr));
    gap: 8px; padding: 10px;
}
@media (min-width: 992px) {
    .qa-grid { display: flex; flex-direction: column; gap: 2px; padding: 8px; }
}

.qa-btn {
    display: flex; flex-direction: column; align-items: center;
    gap: 6px; padding: 10px 6px;
    border-radius: var(--radius-md);
    color: var(--color-ink);
    font-size: .7rem; font-weight: 600;
    text-align: center;
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    line-height: 1.3; min-height: 80px;
    transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease),
                border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.qa-btn:hover  { transform: translateY(-2px); box-shadow: var(--shadow-md); color: var(--color-ink); }
.qa-btn:active { transform: scale(.96); box-shadow: none; }
.qa-icon {
    width: 40px; height: 40px; border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; flex-shrink: 0;
    transition: transform var(--dur) var(--ease);
}
.qa-btn:hover .qa-icon { transform: scale(1.1); }

@media (min-width: 992px) {
    .qa-btn {
        flex-direction: row; text-align: right;
        padding: 8px 10px; gap: 10px;
        font-size: .83rem; min-height: unset;
        border-color: transparent; background: transparent;
        justify-content: flex-start;
    }
    .qa-btn:hover { transform: none; box-shadow: none; }
    .qa-btn:hover .qa-icon { transform: none; }
    .qa-icon { width: 32px; height: 32px; font-size: .9rem; border-radius: 9px; }
}

/* Icon colours */
.qa-c-green  .qa-icon { background: #e6f4ee; color: #0B6E4F; }
.qa-c-blue   .qa-icon { background: #eff6ff; color: #2563eb; }
.qa-c-teal   .qa-icon { background: #ecfeff; color: #0891b2; }
.qa-c-purple .qa-icon { background: #f5f3ff; color: #7c3aed; }
.qa-c-amber  .qa-icon { background: #fffbeb; color: #d97706; }
.qa-c-slate  .qa-icon { background: #f1f5f9; color: #475569; }
.qa-c-emrld  .qa-icon { background: #ecfdf5; color: #059669; }
.qa-c-gray   .qa-icon { background: #f4f4f5; color: #71717a; }

.qa-c-green:hover  { border-color: rgba(11,110,79,.25);   background: #f4fbf7; }
.qa-c-blue:hover   { border-color: rgba(37,99,235,.25);   background: #f5f8ff; }
.qa-c-teal:hover   { border-color: rgba(8,145,178,.25);   background: #f0fafe; }
.qa-c-purple:hover { border-color: rgba(124,58,237,.25);  background: #faf5ff; }
.qa-c-amber:hover  { border-color: rgba(217,119,6,.25);   background: #fffdf2; }
.qa-c-slate:hover  { border-color: rgba(71,85,105,.25);   background: #f6f8fa; }
.qa-c-emrld:hover  { border-color: rgba(5,150,105,.25);   background: #f2fdf8; }
.qa-c-gray:hover   { border-color: rgba(113,113,122,.25); background: #fafafa; }

@media (min-width: 992px) {
    .qa-c-green:hover  { background: #e6f4ee; border-color: transparent; }
    .qa-c-blue:hover   { background: #eff6ff; border-color: transparent; }
    .qa-c-teal:hover   { background: #ecfeff; border-color: transparent; }
    .qa-c-purple:hover { background: #f5f3ff; border-color: transparent; }
    .qa-c-amber:hover  { background: #fffbeb; border-color: transparent; }
    .qa-c-slate:hover  { background: #f1f5f9; border-color: transparent; }
    .qa-c-emrld:hover  { background: #ecfdf5; border-color: transparent; }
    .qa-c-gray:hover   { background: #f4f4f5; border-color: transparent; }
}

/* ── Report Tabs ─────────────────────────────────────── */
.rpt-tabs-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.rpt-tabs { display: flex; gap: 6px; padding-bottom: 4px; min-width: max-content; }
.rtab {
    display: flex; flex-direction: column; align-items: center; gap: 3px;
    padding: 8px 18px; min-height: 56px;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    color: var(--color-muted);
    font-size: .78rem; font-weight: 600;
    cursor: pointer; white-space: nowrap;
    transition: background var(--dur) var(--ease), color var(--dur) var(--ease),
                border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease),
                transform var(--dur) var(--ease);
}
.rtab i { font-size: 1.05rem; }
.rtab:hover { background: var(--color-primary-lt); color: var(--color-primary); border-color: var(--color-primary-lt); transform: translateY(-1px); }
.rtab.active {
    background: var(--color-primary); color: #fff;
    border-color: var(--color-primary);
    box-shadow: 0 3px 10px rgba(11,110,79,.28);
    transform: translateY(-1px);
}

/* Report KPI */
.rpt-kpi {
    background: var(--color-surface);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    padding: 12px 14px;
}
.rpt-kpi .kpi-label { font-size: .72rem; color: var(--color-muted); margin-bottom: 3px; font-weight: 600; }
.rpt-kpi .kpi-value { font-size: 1.05rem; font-weight: 700; }

/* ── Dashboard KPI cards ─────────────────────────────── */
.kpi-card { border-top: 3px solid transparent; }
.kpi-c-green  { border-top-color: #0B6E4F; }
.kpi-c-teal   { border-top-color: #0891b2; }
.kpi-c-purple { border-top-color: #7c3aed; }
.kpi-c-red    { border-top-color: #C1432F; }
.kpi-sub   { font-size: .72rem; color: var(--color-muted); margin-top: 3px; }
.kpi-value { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.dash-greeting { border-right: 4px solid var(--color-primary); background: var(--color-surface); }

.dash-list-header {
    display: flex; align-items: center; gap: 6px;
    padding: 10px 14px;
    font-size: .82rem; font-weight: 700;
    border-bottom: 1px solid var(--color-border);
}
.dash-list-body { padding: 0 0 4px; }
.dash-list-row {
    display: flex; align-items: center; gap: 8px;
    padding: 9px 14px; font-size: .82rem;
    border-bottom: 1px solid var(--color-border);
    transition: background var(--dur) var(--ease);
}
.dash-list-row:last-child { border-bottom: none; }
.dash-list-row:hover { background: var(--color-bg); }
.dash-rank {
    display: flex; align-items: center; justify-content: center;
    width: 22px; height: 22px; flex-shrink: 0;
    border-radius: var(--radius-pill);
    background: var(--color-primary-lt); color: var(--color-primary-dk);
    font-size: .7rem; font-weight: 700;
}

/* ── Net Profit Card ─────────────────────────────────── */
.net-profit-card { border-top: 3px solid var(--color-primary); }
.np-header { display: flex; align-items: center; gap: 8px; font-size: .9rem; margin-bottom: 10px; }
.np-icon {
    width: 34px; height: 34px; border-radius: 9px;
    background: var(--color-primary-lt); color: var(--color-primary-dk);
    display: flex; align-items: center; justify-content: center;
    font-size: .9rem; flex-shrink: 0;
}
.np-cell { background: var(--color-bg); border-radius: var(--radius-sm); padding: 10px 12px; height: 100%; }
.np-cell-title { font-size: .7rem; font-weight: 700; color: var(--color-muted); margin-bottom: 8px; letter-spacing: .04em; }
.np-line {
    display: flex; justify-content: space-between; align-items: baseline;
    gap: 4px; font-size: .74rem; margin-bottom: 5px;
}
.np-line .np-val { font-weight: 600; font-size: .76rem; text-align: left; flex-shrink: 0; }
.np-sep   { border-top: 1px dashed var(--color-border); margin: 7px 0; }
.np-total .np-key { font-weight: 700; font-size: .8rem; }
.np-total .np-val { font-weight: 800; font-size: .82rem; color: var(--color-primary-dk); }

/* ── Camera Scanner Modal ────────────────────────────── */
.cam-modal-dialog { max-width: 460px; }
.cam-modal-content {
    background: #111 !important; color: #fff;
    border: none !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden; display: flex; flex-direction: column;
}
@media (max-width: 575.98px) { .cam-modal-content { border-radius: 0 !important; } }

.cam-modal-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 14px; background: #1c1c1c;
    font-size: .88rem; font-weight: 600;
    flex-shrink: 0; gap: 10px;
}
.cam-toggle-label {
    display: flex; align-items: center; gap: 6px;
    font-size: .78rem; font-weight: 400;
    color: rgba(255,255,255,.7);
    cursor: pointer; user-select: none;
}
.cam-close-btn {
    background: rgba(255,255,255,.1); border: none; color: #fff;
    width: 36px; height: 36px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; flex-shrink: 0; line-height: 1;
    transition: background var(--dur) var(--ease);
}
.cam-close-btn:hover { background: rgba(255,255,255,.22); }

.cam-viewport {
    position: relative; background: #000; overflow: hidden;
    flex: 1; min-height: 260px;
    display: flex; align-items: center; justify-content: center;
}
#camVideo, #stockCamVideo {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover; display: block;
}
.cam-overlay {
    position: absolute; inset: 0;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 12px; pointer-events: none; z-index: 2;
}
.cam-finder { position: relative; width: 260px; height: 150px; }

/* GPU-accelerated scan line — transform instead of top avoids layout reflow */
.cam-scan-line {
    position: absolute;
    top: 4px; left: 4px; right: 4px;
    height: 2px;
    background: linear-gradient(90deg, transparent 0%, #00ff88 40%, #00ff88 60%, transparent 100%);
    box-shadow: 0 0 8px 1px rgba(0,255,136,.55);
    border-radius: 2px;
    will-change: transform;
    animation: cam-sweep 2s linear infinite;
}
@keyframes cam-sweep {
    /* translateY instead of top: no layout, runs on GPU compositor */
    0%   { transform: translateY(0); }
    100% { transform: translateY(140px); } /* finder 150px − 4px top − 6px gap */
}

.cam-corner { position: absolute; width: 22px; height: 22px; border-color: #00ff88; border-style: solid; border-width: 0; }
.cam-corner.tl { top:0;    left:0;  border-top-width:3px;    border-left-width:3px;  border-radius:4px 0 0 0; }
.cam-corner.tr { top:0;    right:0; border-top-width:3px;    border-right-width:3px; border-radius:0 4px 0 0; }
.cam-corner.bl { bottom:0; left:0;  border-bottom-width:3px; border-left-width:3px;  border-radius:0 0 0 4px; }
.cam-corner.br { bottom:0; right:0; border-bottom-width:3px; border-right-width:3px; border-radius:0 0 4px 0; }

.cam-hint {
    color: rgba(255,255,255,.72); font-size: .76rem; margin: 0;
    text-align: center; text-shadow: 0 1px 4px rgba(0,0,0,.9);
}
.cam-error-overlay {
    position: absolute; inset: 0; background: rgba(0,0,0,.88);
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 10px; color: #fff; font-size: .88rem;
    z-index: 5; padding: 16px; text-align: center;
}
.cam-status {
    display: flex; align-items: center; gap: 8px;
    padding: 9px 14px; background: #1c1c1c;
    font-size: .78rem; color: rgba(255,255,255,.65);
    flex-shrink: 0; min-height: 38px;
}
.cam-status-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: #555; flex-shrink: 0; transition: background .25s;
}
.cam-status-dot.scanning { background: #00ff88; animation: dot-pulse 1.1s ease-in-out infinite; }
.cam-status-dot.success  { background: #00ff88; }
.cam-status-dot.error    { background: var(--color-danger); }
@keyframes dot-pulse {
    0%, 100% { opacity: 1; }
    50%       { opacity: .35; }
}

/* ── Multi-select ────────────────────────────────────── */
.prod-selected {
    border-color: var(--color-primary) !important;
    border-width: 2px !important;
    background: var(--color-primary-lt);
}
.selection-bar {
    position: fixed; bottom: 0; left: 0; right: 0;
    background: var(--color-primary-dk); color: #fff;
    padding: 10px 16px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 10px; z-index: 1025;
    box-shadow: 0 -4px 20px rgba(0,0,0,.25);
    animation: slideUp .18s var(--ease);
}
@keyframes slideUp {
    from { transform: translateY(100%); }
    to   { transform: translateY(0); }
}
@media (max-width: 767.98px) { .selection-bar { bottom: var(--bottomnav-h); } }

/* ── Toast notifications ─────────────────────────────── */
.toast-container { z-index: 1090; }
.toast {
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-lg) !important;
    border: none !important;
    font-size: .88rem; font-weight: 500;
}

/* ── Responsive tweaks ───────────────────────────────── */
@media (max-width: 575.98px) {
    .app-main  { padding: 12px 10px; }
    .kpi-value { font-size: 1.3rem !important; }
    /* Modals: slide up from bottom on phone */
    .modal.fade .modal-dialog { transition: transform .25s var(--ease); }
}

/* ── Reduced motion ──────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation: none !important; transition: none !important; }
}
