@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
    --primary: #2547B1;
    --primary-dark: #1e3a8a;
    --primary-light: #3b59d8;
    --green: #16a34a;
    --green-bg: #dcfce7;
    --red: #dc2626;
    --red-bg: #fee2e2;
    --yellow: #d97706;
    --yellow-bg: #fef3c7;
    --blue: #2563eb;
    --blue-bg: #dbeafe;
    --bg: #f8fafc;
    --surface: #ffffff;
    --surface-2: #f1f5f9;
    --text: #0f172a;
    --text-muted: #64748b;
    --border: #e2e8f0;
    --header: #2547B1;
    --header-tab: rgba(255,255,255,0.12);
    --shadow: 0 1px 3px rgba(15,23,42,0.08), 0 8px 24px rgba(15,23,42,0.06);
    --radius: 12px;
    --radius-lg: 16px;
    --font: 'Inter', system-ui, sans-serif;
    --sidebar-width: 204px;
    --sidebar-collapsed-width: 72px;
    --topbar-height: 72px;
}

[data-theme="dark"] {
    --bg: #0b0f17;
    --surface: #111827;
    --surface-2: #1f2937;
    --text: #f8fafc;
    --text-muted: #94a3b8;
    --border: #334155;
    --header: #0f172a;
    --header-tab: rgba(255,255,255,0.06);
    --shadow: 0 8px 30px rgba(0,0,0,0.35);
    color-scheme: dark;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;overflow-x:clip}
button,input,select{font-family:inherit}
a{text-decoration:none;color:inherit}
.hidden{display:none!important}
.text-green{color:var(--green)!important}
.text-danger{color:var(--red)!important}
.text-primary{color:var(--primary)!important}
.text-right{text-align:right}
.flex-1{flex:1}

/* App shell & sidebar */
.app-shell{
    min-height:100vh;
    display:flex;
    background:var(--bg);
}
.app-sidebar{
    position:fixed;
    top:0;
    left:0;
    bottom:0;
    width:var(--sidebar-collapsed-width);
    background:linear-gradient(180deg,#1e3a8a 0%,#2547B1 55%,#1e40af 100%);
    color:#fff;
    display:flex;
    flex-direction:column;
    z-index:120;
    box-shadow:4px 0 30px rgba(15,23,42,.18);
    transition:width .28s cubic-bezier(.4,0,.2,1),box-shadow .28s cubic-bezier(.4,0,.2,1);
    overflow:hidden;
}
.app-shell.sidebar-expanded .app-sidebar{
    width:var(--sidebar-width);
    box-shadow:8px 0 40px rgba(15,23,42,.22);
}
[data-theme="dark"] .app-sidebar{
    background:linear-gradient(180deg,#0f172a 0%,#111827 55%,#0b1220 100%);
    box-shadow:4px 0 30px rgba(0,0,0,.45);
}
[data-theme="dark"] .app-shell.sidebar-expanded .app-sidebar{
    box-shadow:8px 0 40px rgba(0,0,0,.55);
}
.sidebar-head{
    display:flex;
    align-items:center;
    justify-content:center;
    padding:14px 10px;
    border-bottom:1px solid rgba(255,255,255,.1);
    min-height:68px;
    flex-shrink:0;
}
.app-shell.sidebar-expanded .sidebar-head{
    padding:14px 12px;
    justify-content:flex-start;
}
.sidebar-brand{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:0;
    min-width:0;
    flex:1;
    overflow:hidden;
    transition:gap .28s ease;
}
.app-shell.sidebar-expanded .sidebar-brand{
    justify-content:flex-start;
    gap:10px;
}
.sidebar-brand-icon{
    width:36px;height:36px;border-radius:11px;
    background:rgba(255,255,255,.14);
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.15);
}
.sidebar-brand-text{
    opacity:0;
    flex:0 0 0;
    width:0;
    max-width:0;
    overflow:hidden;
    white-space:nowrap;
    transition:opacity .22s ease .04s,max-width .28s cubic-bezier(.4,0,.2,1);
}
.sidebar-brand-text small{display:block;font-size:.62rem;opacity:.78;letter-spacing:.03em}
.sidebar-brand-text strong{display:block;font-size:.88rem;font-weight:800;letter-spacing:.01em;line-height:1.2}
.app-shell.sidebar-expanded .sidebar-brand-text{
    opacity:1;
    flex:1 1 auto;
    width:auto;
    max-width:calc(var(--sidebar-width) - 52px);
}
.sidebar-nav{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:6px;
    padding:12px 8px;
    flex:1;
    min-height:0;
    overflow-y:auto;
    overflow-x:hidden;
}
.app-shell.sidebar-expanded .sidebar-nav{
    align-items:stretch;
    padding:12px 10px;
}
.sidebar-link{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:0;
    width:100%;
    padding:9px 8px;
    border-radius:12px;
    color:rgba(255,255,255,.82);
    font-size:.875rem;
    font-weight:600;
    transition:background .2s ease,color .2s ease,box-shadow .2s ease,padding .28s ease,justify-content .28s ease,gap .28s ease;
    white-space:nowrap;
}
.app-shell.sidebar-expanded .sidebar-link{
    justify-content:flex-start;
    gap:10px;
    padding:10px 10px;
}
.sidebar-link-icon{
    width:36px;height:36px;border-radius:11px;
    background:rgba(255,255,255,.08);
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
    transition:background .2s ease;
}
.sidebar-link-label{
    opacity:0;
    width:0;
    overflow:hidden;
    transition:opacity .22s ease .04s,width .28s cubic-bezier(.4,0,.2,1);
}
.app-shell.sidebar-expanded .sidebar-link-label{
    opacity:1;
    width:auto;
}
.sidebar-link:hover{
    background:rgba(255,255,255,.1);
    color:#fff;
}
.sidebar-link:hover .sidebar-link-icon{background:rgba(255,255,255,.16)}
.sidebar-link.active{
    background:rgba(255,255,255,.16);
    color:#fff;
    box-shadow:0 8px 24px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.12);
}
.sidebar-link.active .sidebar-link-icon{background:#fff;color:var(--primary)}
.sidebar-foot{
    padding:10px 8px 14px;
    border-top:1px solid rgba(255,255,255,.1);
    flex-shrink:0;
}
.app-shell.sidebar-expanded .sidebar-foot{padding:10px 10px 14px}
.sidebar-toggle{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:0;
    padding:10px 8px;
    border:none;
    border-radius:12px;
    background:rgba(255,255,255,.1);
    color:#fff;
    cursor:pointer;
    font-size:.8rem;
    font-weight:600;
    transition:background .2s ease,gap .28s ease,padding .28s ease;
}
.sidebar-toggle:hover{background:rgba(255,255,255,.18)}
.sidebar-toggle-icon{
    width:36px;height:36px;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
    transition:transform .28s cubic-bezier(.4,0,.2,1);
}
.app-shell.sidebar-expanded .sidebar-toggle-icon{transform:rotate(180deg)}
.sidebar-toggle-label{
    opacity:0;
    width:0;
    overflow:hidden;
    white-space:nowrap;
    transition:opacity .22s ease .04s,width .28s ease;
}
.app-shell.sidebar-expanded .sidebar-toggle{
    justify-content:flex-start;
    gap:8px;
    padding:10px 10px;
}
.app-shell.sidebar-expanded .sidebar-toggle-label{
    opacity:1;
    width:auto;
}
.app-content{
    flex:1;
    min-width:0;
    margin-left:var(--sidebar-collapsed-width);
    display:flex;
    flex-direction:column;
    min-height:100vh;
    transition:margin-left .28s cubic-bezier(.4,0,.2,1);
    overflow-x:clip;
}
.app-shell.sidebar-expanded .app-content{
    margin-left:var(--sidebar-width);
}
.app-main{
    flex:1;
    width:100%;
    max-width:none;
    padding:24px clamp(16px,2.5vw,32px);
    min-width:0;
}
.header-top{
    padding:14px clamp(16px,2.5vw,32px);
}

/* Header */
.app-header{
    background:var(--surface);
    color:var(--text);
    position:sticky;top:0;z-index:100;
    box-shadow:0 1px 0 var(--border),0 8px 24px rgba(15,23,42,.04);
    border-bottom:1px solid var(--border);
}
[data-theme="dark"] .app-header{box-shadow:0 1px 0 var(--border),0 8px 24px rgba(0,0,0,.25)}
.header-top{display:flex;align-items:center;justify-content:flex-end;gap:16px;min-height:var(--topbar-height)}
.header-actions-only{margin-left:auto;width:100%;justify-content:flex-end}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand-icon,.brand-icon.lg{
    width:42px;height:42px;border-radius:12px;
    background:linear-gradient(135deg,rgba(37,71,177,.12),rgba(59,89,216,.18));
    color:var(--primary);
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.brand small{display:block;font-size:.7rem;color:var(--text-muted)}
.brand strong{font-size:1.05rem;font-weight:800;color:var(--text)}
.header-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.header-btn,.kebab-btn{width:40px;height:40px;border:none;border-radius:12px;background:var(--surface-2);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center}
.profile-menu{position:relative}
.profile-trigger{
    display:flex;align-items:center;gap:10px;
    padding:6px 12px 6px 6px;border:1px solid var(--border);border-radius:999px;
    background:var(--surface);color:var(--text);cursor:pointer;
    transition:box-shadow .2s ease,border-color .2s ease;
}
.profile-trigger:hover{border-color:rgba(37,71,177,.25);box-shadow:0 8px 20px rgba(37,71,177,.1)}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem}
.avatar.lg{width:48px;height:48px;font-size:1.1rem}
.profile-text{text-align:left}
.profile-text strong{display:block;font-size:.85rem;color:var(--text)}
.profile-text small{font-size:.7rem;color:var(--text-muted)}
.profile-dropdown{position:absolute;right:0;top:calc(100% + 8px);width:280px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:8px;z-index:200}
.dropdown-user{display:flex;gap:12px;padding:12px;border-bottom:1px solid var(--border);margin-bottom:4px}
.dropdown-user strong{display:block;font-size:.9rem;color:var(--text)}
.dropdown-user small{display:block;color:var(--text-muted);font-size:.75rem;word-break:break-all}
.role-badge{display:inline-block;margin-top:6px;padding:3px 8px;border-radius:999px;background:var(--green-bg);color:var(--green);font-size:.7rem;font-weight:700}
.dropdown-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;background:none;color:var(--text);border-radius:10px;cursor:pointer;font-size:.875rem;text-align:left}
.dropdown-item [data-theme-icon]{display:inline-flex;width:16px;height:16px}
.dropdown-item [data-theme-icon] svg{width:16px;height:16px}
.dropdown-item.danger{color:var(--red)}

/* Page */
.page-head{margin-bottom:24px}
.page-head h1{font-size:1.75rem;font-weight:800;letter-spacing:-.02em}
.page-head p{color:var(--text-muted);margin-top:4px}
.page-head.row-between{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}

/* Stats — mobile-first responsive grids */
.stat-grid{
    display:grid;
    gap:clamp(10px,2vw,16px);
    margin-bottom:clamp(16px,3vw,24px);
    width:100%;
    grid-template-columns:minmax(0,1fr);
}
.stat-grid > .stat-card{min-width:0}
.stat-grid.cols-2,
.stat-grid.cols-3,
.stat-grid.cols-4,
.stat-grid.cols-5,
.stat-grid.upload-stats{
    grid-template-columns:minmax(0,1fr);
}
.stat-grid.narrow{
    width:100%;
}
.stat-grid.upload-stats{max-width:none}
.stat-card{
    position:relative;
    overflow:hidden;
    background:linear-gradient(155deg,var(--surface) 0%,var(--surface-2) 100%);
    border:1px solid rgba(226,232,240,.9);
    border-radius:18px;
    padding:clamp(14px,3vw,20px);
    box-shadow:0 2px 4px rgba(15,23,42,.04),0 10px 28px rgba(15,23,42,.08);
    width:100%;
    min-width:0;
    max-width:100%;
    transform:none;
    transform-style:flat;
    transition:box-shadow .35s ease,border-color .35s ease;
    will-change:auto;
    cursor:default;
}
[data-theme="dark"] .stat-card{
    border-color:rgba(51,65,85,.95);
    background:linear-gradient(155deg,var(--surface) 0%,rgba(31,41,55,.85) 100%);
}
.stat-card::before{
    display:none;
}
.stat-card::after{
    content:'';
    position:absolute;
    top:0;
    left:0;
    right:0;
    height:4px;
    background:linear-gradient(90deg,var(--primary),var(--primary-light));
    opacity:.85;
}
.stat-card:has(.stat-icon.info)::after{background:linear-gradient(90deg,var(--blue),#60a5fa)}
.stat-card:has(.stat-icon.success)::after{background:linear-gradient(90deg,var(--green),#4ade80)}
.stat-card:has(.stat-icon.warning)::after{background:linear-gradient(90deg,var(--yellow),#fbbf24)}
.stat-card:has(.stat-icon.danger)::after{background:linear-gradient(90deg,var(--red),#f87171)}
.stat-card:has(.stat-icon.primary)::after{background:linear-gradient(90deg,var(--primary),var(--primary-light))}
.stat-card:hover,
.stat-card.is-tilting{
    transform:none;
    border-color:rgba(37,71,177,.22);
    box-shadow:0 18px 36px rgba(15,23,42,.12),0 28px 60px rgba(37,71,177,.14);
}
[data-theme="dark"] .stat-card:hover,
[data-theme="dark"] .stat-card.is-tilting{
    border-color:rgba(51,65,85,.95);
    box-shadow:var(--shadow);
}
.stat-card:has(.stat-icon.info):hover{box-shadow:0 18px 36px rgba(15,23,42,.12),0 28px 60px rgba(37,99,235,.18)}
.stat-card:has(.stat-icon.success):hover{box-shadow:0 18px 36px rgba(15,23,42,.12),0 28px 60px rgba(22,163,74,.18)}
.stat-card:has(.stat-icon.warning):hover{box-shadow:0 18px 36px rgba(15,23,42,.12),0 28px 60px rgba(217,119,6,.18)}
.stat-card:has(.stat-icon.danger):hover{box-shadow:0 18px 36px rgba(15,23,42,.12),0 28px 60px rgba(220,38,38,.18)}
.stat-card:hover::before{opacity:0}
.stat-card.is-tilting::before{opacity:0}
.stat-card.compact{padding:clamp(12px,2.5vw,18px)}
.stat-card-top{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:8px;
    margin-bottom:12px;
    flex-wrap:wrap;
}
.stat-card small{
    display:block;
    color:var(--text-muted);
    font-size:clamp(.62rem,1.8vw,.68rem);
    font-weight:700;
    letter-spacing:.06em;
    margin-bottom:6px;
    line-height:1.3;
    word-break:break-word;
}
.stat-card strong{
    display:block;
    font-size:clamp(1.25rem,4.5vw,1.75rem);
    font-weight:800;
    line-height:1.1;
    letter-spacing:-.03em;
    background:linear-gradient(135deg,var(--text) 0%,var(--text-muted) 140%);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent;
    word-break:break-word;
}
.stat-sub{
    display:block;
    color:var(--text-muted);
    font-size:clamp(.68rem,2vw,.72rem);
    margin-top:8px;
    line-height:1.35;
    word-break:break-word;
}
.stat-icon{
    width:clamp(36px,10vw,42px);
    height:clamp(36px,10vw,42px);
    border-radius:12px;
    display:flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    transition:transform .35s ease,box-shadow .35s ease;
    box-shadow:0 6px 16px rgba(15,23,42,.08);
}
.stat-card .pill{
    flex-shrink:1;
    min-width:0;
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    transition:transform .35s ease;
}
.stat-card:hover .stat-icon,.stat-card.is-tilting .stat-icon{transform:none}
.stat-icon.info{background:linear-gradient(135deg,var(--blue-bg),#bfdbfe);color:var(--blue)}
.stat-icon.success{background:linear-gradient(135deg,var(--green-bg),#bbf7d0);color:var(--green)}
.stat-icon.warning{background:linear-gradient(135deg,var(--yellow-bg),#fde68a);color:var(--yellow)}
.stat-icon.danger{background:linear-gradient(135deg,var(--red-bg),#fecaca);color:var(--red)}
.stat-icon.primary{background:linear-gradient(135deg,rgba(37,71,177,.14),rgba(59,89,216,.22));color:var(--primary)}
.stat-card:hover .pill,.stat-card.is-tilting .pill{transform:none}

.pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:700}
.pill.sm{font-size:.62rem;padding:3px 8px}
.pill.primary{background:rgba(37,71,177,.12);color:var(--primary)}
.pill.success,.pill.approved{background:var(--green-bg);color:var(--green)}
.pill.warning,.pill.pending{background:var(--yellow-bg);color:var(--yellow)}
.pill.danger,.pill.rejected{background:var(--red-bg);color:var(--red)}
.pill.info{background:var(--blue-bg);color:var(--blue)}

/* Panels */
.panel-grid{
    display:grid;
    gap:20px;
    width:100%;
    grid-template-columns:repeat(2,minmax(0,1fr));
}
@media (max-width:900px){
    .panel-grid{grid-template-columns:minmax(0,1fr)}
}
.panel{
    position:relative;
    overflow:hidden;
    background:linear-gradient(155deg,var(--surface) 0%,var(--surface-2) 100%);
    border:1px solid rgba(226,232,240,.95);
    border-radius:20px;
    box-shadow:0 2px 4px rgba(15,23,42,.04),0 12px 32px rgba(15,23,42,.08);
    width:100%;
    min-width:0;
    transform-style:preserve-3d;
    transition:transform .12s ease-out,box-shadow .35s ease,border-color .35s ease;
}
[data-theme="dark"] .panel{border-color:rgba(51,65,85,.95)}
.panel::before{
    content:'';
    position:absolute;
    inset:0;
    background:radial-gradient(circle at var(--mouse-x,50%) var(--mouse-y,0%),rgba(255,255,255,.22),transparent 55%);
    opacity:0;
    transition:opacity .35s ease;
    pointer-events:none;
}
.panel:hover::before,.panel.is-tilting::before{opacity:1}
.panel-accent::after{
    content:'';
    position:absolute;
    top:0;left:0;right:0;height:4px;
    background:linear-gradient(90deg,var(--primary),var(--primary-light));
}
.panel-actions::after{background:linear-gradient(90deg,#7c3aed,#a78bfa)}
.panel:hover,.panel.is-tilting{
    border-color:rgba(37,71,177,.2);
    box-shadow:0 18px 36px rgba(15,23,42,.1),0 28px 60px rgba(37,71,177,.12);
}
.panel-head{
    display:flex;justify-content:space-between;align-items:center;
    padding:18px 20px;border-bottom:1px solid var(--border);
    background:rgba(255,255,255,.35);
}
[data-theme="dark"] .panel-head{background:rgba(255,255,255,.02)}
.panel-title{display:flex;align-items:center;gap:10px}
.panel-title h2{font-size:1rem;font-weight:800;letter-spacing:-.01em}
.panel-body{padding:16px 20px 20px}
.link-btn{
    color:var(--primary);font-size:.85rem;font-weight:700;
    padding:8px 12px;border-radius:10px;background:rgba(37,71,177,.08);
    transition:background .2s ease,transform .2s ease;
}
.link-btn:hover{background:rgba(37,71,177,.14);transform:translateX(2px)}
.list-stack{display:grid;gap:12px}
.dashboard-sales-scroll{
    max-height:min(320px,42vh);
    overflow-y:auto;
    overflow-x:hidden;
    padding-right:4px;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
}
.dashboard-sales-scroll::-webkit-scrollbar{width:6px}
.dashboard-sales-scroll::-webkit-scrollbar-thumb{
    background:rgba(100,116,139,.35);
    border-radius:999px;
}
.list-row{
    display:flex;justify-content:space-between;gap:16px;
    padding:14px 16px;border:1px solid var(--border);border-radius:14px;
    background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);
    width:100%;min-width:0;flex-wrap:wrap;
    transform-style:preserve-3d;
    transition:transform .12s ease-out,box-shadow .3s ease,border-color .3s ease;
    cursor:default;
}
.list-row::before{
    content:'';
    position:absolute;
    inset:0;
    border-radius:inherit;
    background:radial-gradient(circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(255,255,255,.25),transparent 60%);
    opacity:0;
    pointer-events:none;
}
.list-row{position:relative;overflow:hidden}
.list-row:hover,.list-row.is-tilting{
    border-color:rgba(37,71,177,.18);
    box-shadow:0 12px 28px rgba(37,71,177,.1);
}
.list-row:hover::before,.list-row.is-tilting::before{opacity:1}
.list-row strong{display:block;font-size:.92rem;word-break:break-word;transform:translateZ(12px)}
.list-row small{display:block;color:var(--text-muted);font-size:.78rem;margin-top:2px;word-break:break-word;transform:translateZ(8px)}
.action-grid{display:grid;gap:12px;width:100%;grid-template-columns:repeat(auto-fit,minmax(min(100%,180px),1fr))}
.action-card{
    display:flex;flex-direction:column;gap:10px;
    padding:16px;border:1px solid var(--border);border-radius:16px;
    background:linear-gradient(145deg,var(--surface) 0%,var(--surface-2) 100%);
    cursor:pointer;text-align:left;width:100%;min-width:0;
    transform-style:preserve-3d;
    transition:transform .12s ease-out,box-shadow .35s ease,border-color .35s ease;
    position:relative;overflow:hidden;
}
.action-card::before{
    content:'';
    position:absolute;inset:0;
    background:radial-gradient(circle at var(--mouse-x,50%) var(--mouse-y,0%),rgba(255,255,255,.28),transparent 55%);
    opacity:0;transition:opacity .35s ease;pointer-events:none;
}
.action-card:hover,.action-card.is-tilting{
    border-color:rgba(37,71,177,.2);
    box-shadow:0 16px 32px rgba(37,71,177,.12);
}
.action-card:hover::before,.action-card.is-tilting::before{opacity:1}
.action-card strong{font-size:.92rem;font-weight:700;transform:translateZ(14px)}
.action-card small{color:var(--text-muted);font-size:.78rem;transform:translateZ(10px)}
.action-card .stat-icon{transform:translateZ(18px)}
.action-card:hover .stat-icon,.action-card.is-tilting .stat-icon{transform:translateZ(24px) scale(1.06)}
.tilt-card{will-change:transform}

/* Upload page */
.upload-page-grid{
    display:grid;
    gap:20px;
    width:100%;
    grid-template-columns:minmax(min(100%,320px),360px) minmax(0,1fr);
    align-items:start;
}
.upload-form-panel .panel-body{display:grid;gap:16px}
.upload-form-actions{margin-top:4px}
.btn-block{width:100%;justify-content:center}
.stat-grid.upload-stats{
    max-width:none;
    width:100%;
}
.panel-flat{
    transform:none!important;
    transform-style:flat;
}
.panel-flat:hover,
.panel-flat.is-tilting{
    transform:none!important;
    box-shadow:0 2px 4px rgba(15,23,42,.04),0 12px 32px rgba(15,23,42,.08);
    border-color:rgba(226,232,240,.95);
}
[data-theme="dark"] .panel-flat:hover,
[data-theme="dark"] .panel-flat.is-tilting{border-color:rgba(51,65,85,.95)}
.panel-flat:hover::before,
.panel-flat.is-tilting::before{opacity:0!important}
.card-flat,
.stat-card.card-flat,
.sale-card.card-flat,
.txn-card.card-flat{
    transform:none!important;
    transform-style:flat;
    will-change:auto;
}
.card-flat:hover,
.card-flat.is-tilting,
.stat-card.card-flat:hover,
.stat-card.card-flat.is-tilting,
.sale-card.card-flat:hover,
.txn-card.card-flat:hover{
    transform:none!important;
    box-shadow:0 2px 4px rgba(15,23,42,.04),0 10px 28px rgba(15,23,42,.08);
    border-color:rgba(226,232,240,.9);
}
[data-theme="dark"] .card-flat:hover,
[data-theme="dark"] .card-flat.is-tilting,
[data-theme="dark"] .stat-card.card-flat:hover,
[data-theme="dark"] .sale-card.card-flat:hover{
    border-color:rgba(51,65,85,.95);
    box-shadow:var(--shadow);
}
.card-flat:hover::before,
.card-flat.is-tilting::before,
.stat-card.card-flat:hover::before,
.stat-card.card-flat.is-tilting::before{
    opacity:0!important;
}
.stat-card.card-flat:hover .stat-icon,
.stat-card.card-flat.is-tilting .stat-icon{
    transform:none;
}
.sales-toolbar{align-items:flex-end;gap:16px}
.sales-toolbar .search-box{min-width:min(100%,260px)}
.sales-date-filter{
    display:flex;
    align-items:flex-start;
    gap:10px;
    flex-shrink:0;
    min-width:min(100%,320px);
}
.sales-date-filter label{display:block;font-size:.72rem;color:var(--text-muted);margin-bottom:4px}
.sales-date-filter .date-range{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.sales-date-filter .date-range input{
    min-width:132px;
    padding:9px 10px;
    border:1px solid var(--border);
    border-radius:10px;
    background:var(--surface);
    color:var(--text);
    font-size:.82rem;
}
.sales-date-filter .date-sep{color:var(--text-muted);font-size:.85rem}
.tag.date-tag{
    padding:6px 10px;
    border:1px solid var(--border);
    border-radius:10px;
    background:var(--surface-2);
    font-size:.74rem;
    color:var(--text-muted);
    white-space:nowrap;
    flex-shrink:0;
}
.sale-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.sale-meta-grid .sale-amount{grid-column:1/-1;justify-self:end;text-align:right}
.upload-type-tabs .segment-tab{text-decoration:none;color:inherit}

/* Upload type modal */
.modal-upload-type{max-width:540px}
.modal-upload-type .modal-head{
    align-items:flex-start;
    padding:28px 28px 0;
    gap:16px;
}
.modal-upload-type .modal-head h3{
    font-size:1.2rem;
    letter-spacing:-.02em;
    margin:0;
}
.modal-head-sub{
    margin:6px 0 0;
    font-size:.875rem;
    color:var(--text-muted);
    font-weight:500;
    line-height:1.45;
}
.modal-upload-type .modal-body{padding:24px 28px 8px}
.modal-upload-type .modal-foot{
    padding:20px 28px 28px;
    gap:12px;
    border-top:1px solid var(--border);
    margin-top:8px;
    background:var(--surface-2);
    border-radius:0 0 20px 20px;
}
[data-theme="dark"] .modal-upload-type .modal-foot{background:rgba(255,255,255,.03)}
.upload-type-choices{
    display:flex;
    flex-direction:column;
    gap:14px;
}
.upload-type-choice{
    display:flex;
    flex-direction:row;
    align-items:center;
    gap:18px;
    width:100%;
    padding:20px 22px;
    border:2px solid var(--border);
    border-radius:16px;
    background:var(--surface);
    cursor:pointer;
    text-align:left;
    transition:border-color .2s ease,background .2s ease,box-shadow .2s ease,transform .15s ease;
}
.upload-type-choice:hover{
    border-color:rgba(37,71,177,.3);
    background:var(--surface-2);
    transform:translateY(-1px);
}
.upload-type-choice.active{
    border-color:var(--primary);
    background:rgba(37,71,177,.05);
    box-shadow:0 0 0 4px rgba(37,71,177,.1);
}
.upload-type-choice .stat-icon{
    width:52px;
    height:52px;
    border-radius:14px;
    flex-shrink:0;
}
.upload-type-label{
    display:flex;
    flex-direction:column;
    gap:6px;
    min-width:0;
}
.upload-type-choice strong{
    font-size:1.02rem;
    font-weight:700;
    color:var(--text);
    line-height:1.25;
}
.upload-type-choice small{
    font-size:.8rem;
    color:var(--text-muted);
    line-height:1.5;
}
.modal-upload-type .modal-foot .btn{
    min-width:120px;
    padding:12px 22px;
}
@media (max-width:480px){
    .modal-upload-type .modal-head,
    .modal-upload-type .modal-body,
    .modal-upload-type .modal-foot{padding-left:20px;padding-right:20px}
    .upload-type-choice{padding:18px 16px;gap:14px}
    .upload-type-choice .stat-icon{width:46px;height:46px}
}
.compact-toolbar{
    display:flex;align-items:center;gap:12px;flex-wrap:wrap;
    margin:0 20px 12px;padding:0;border:none;background:transparent;box-shadow:none;
}
.compact-toolbar .search-box.compact{margin:0}
.voucher-row small{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:6px}
.upload-pagination{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    padding:12px 20px 18px;border-top:1px solid var(--border);font-size:.84rem;color:var(--text-muted);
}
.filter-menu .filter-option{
    display:block;width:100%;padding:10px 12px;border:none;background:none;
    text-align:left;border-radius:8px;cursor:pointer;font-size:.84rem;color:var(--text);text-decoration:none;
}
.filter-menu .filter-option.active,.filter-menu .filter-option:hover{background:rgba(37,71,177,.08);color:var(--primary)}
.panel-scroll{display:flex;flex-direction:column;min-height:420px;max-height:min(78vh,820px)}
.panel-scroll .search-box.compact{
    margin:0 20px 12px;
    flex-shrink:0;
}
.panel-scroll-body{
    flex:1;
    min-height:0;
    overflow-y:auto;
    overscroll-behavior:contain;
    padding-top:0;
    display:grid;
    gap:10px;
    align-content:start;
    scrollbar-width:thin;
    scrollbar-color:rgba(37,71,177,.35) transparent;
}
.panel-scroll-body::-webkit-scrollbar{width:8px}
.panel-scroll-body::-webkit-scrollbar-thumb{
    background:rgba(37,71,177,.28);
    border-radius:999px;
}
.serial-row{
    display:flex;
    justify-content:space-between;
    gap:16px;
    padding:14px 16px;
    border:1px solid var(--border);
    border-radius:14px;
    background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);
    width:100%;
    min-width:0;
    flex-wrap:wrap;
}
.serial-row strong{display:block;font-size:.92rem;word-break:break-word}
.serial-row small{display:block;color:var(--text-muted);font-size:.78rem;margin-top:2px;word-break:break-word}
.serial-row .text-right{text-align:right}

/* Tabs / toolbar */
.segment-tabs{
    display:flex;
    gap:4px;
    padding:4px;
    background:var(--surface-2);
    border:1px solid var(--border);
    border-radius:14px;
    margin-bottom:16px;
    width:100%;
    max-width:100%;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
}
.segment-tab{
    flex:1;
    min-width:0;
    padding:10px;
    border:none;
    border-radius:10px;
    background:transparent;
    color:var(--text-muted);
    font-weight:600;
    font-size:.85rem;
    cursor:pointer;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.segment-tab.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px rgba(37,71,177,.25)}
.toolbar-card,.search-box.page-search,.date-filter{
    display:flex;
    align-items:center;
    gap:12px;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    padding:12px 16px;
    margin-bottom:16px;
    box-shadow:var(--shadow);
    overflow:visible;
    position:relative;
    z-index:20;
    width:100%;
    min-width:0;
    flex-wrap:wrap;
}
.search-box{position:relative;flex:1}
.search-box svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);width:18px;height:18px}
.search-box input{width:100%;padding:10px 36px 10px 42px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text)}
.search-box input:focus{outline:none;border-color:var(--primary)}
.search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;display:none}
.filter-dropdown{position:relative;display:flex;align-items:center;gap:8px;white-space:nowrap;flex-shrink:0}
.filter-dropdown label{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.85rem}
.filter-control{position:relative;flex-shrink:0}
.filter-trigger{padding:10px 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);cursor:pointer;font-weight:600;font-size:.85rem;min-width:140px;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:8px}
.filter-trigger::after{content:'▾';font-size:.75rem;color:var(--text-muted)}
.filter-menu{position:absolute;left:0;right:0;top:calc(100% + 8px);min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px rgba(15,23,42,.15);padding:6px;z-index:300;display:none;flex-direction:column}
.filter-menu.open{display:flex}
.filter-option{width:100%;padding:10px 12px;border:none;background:none;text-align:left;border-radius:8px;cursor:pointer;font-size:.85rem;color:var(--text)}
.filter-option:hover,.filter-option.active{background:rgba(37,71,177,.08);color:var(--primary)}
.filter-chips.inline{display:flex;gap:8px;flex-wrap:wrap;margin:0;padding:0;background:none;border:none;box-shadow:none}
.chip{padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:.78rem;font-weight:600;cursor:pointer}
.chip.active{border-color:transparent;color:#fff}
.chip.active.primary{background:var(--primary)}
.chip.active.green{background:var(--green)}
.chip.active.yellow{background:var(--yellow);color:#fff}
.chip.active.red{background:var(--red)}
.date-filter svg{flex-shrink:0}
.date-filter label{display:block;font-size:.72rem;color:var(--text-muted)}
.date-range{display:flex;align-items:center;gap:8px;margin-top:4px}
.date-range input{padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text)}

/* Table */
.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:visible;position:relative;z-index:1;width:100%;min-width:0}
.table-scroll{overflow-x:auto;width:100%;-webkit-overflow-scrolling:touch}
.data-table{min-width:900px}
.data-table{width:100%;border-collapse:collapse}
.data-table th,.data-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border);font-size:.85rem}
.data-table th{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--surface-2);font-weight:700}
.data-table .actions-cell{overflow:visible;white-space:nowrap;width:1%}
.user-row{transition:background .15s ease,box-shadow .15s ease}
.user-row:hover{background:rgba(37,71,177,.03)}
[data-theme="dark"] .user-row:hover{background:rgba(255,255,255,.03)}
.user-row.pending{border-left:4px solid var(--yellow)}
.user-row.approved{border-left:4px solid var(--green)}
.user-row.rejected{border-left:4px solid var(--red)}
.user-row td{vertical-align:middle}
.cell-user{display:flex;align-items:center;gap:12px;min-width:180px}
.cell-icon{
    width:38px;height:38px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.cell-icon.dealer{background:rgba(37,71,177,.12);color:var(--primary)}
.cell-icon.customer{background:rgba(16,185,129,.12);color:var(--green)}
.cell-user strong{display:block;font-size:.92rem;font-weight:700;color:var(--text)}
.cell-user small{display:block;color:var(--text-muted);font-size:.78rem;margin-top:2px}
.cell-email{display:inline-block;color:var(--text);font-size:.84rem;word-break:break-all}
.cell-meta{display:inline-block;color:var(--text-muted);font-size:.84rem;font-weight:500}
.row-actions{display:inline-flex;align-items:center;gap:8px}
.row-action-form{display:inline-flex;margin:0}
.action-icon{
    width:36px;height:36px;border-radius:10px;border:1px solid var(--border);
    background:var(--surface);color:var(--text);
    display:inline-flex;align-items:center;justify-content:center;
    cursor:pointer;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease;
}
.action-icon:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(15,23,42,.1)}
.action-icon.success{color:var(--green);border-color:rgba(16,185,129,.25);background:rgba(16,185,129,.08)}
.action-icon.success:hover{background:rgba(16,185,129,.16);border-color:rgba(16,185,129,.4)}
.action-icon.primary{color:var(--primary);border-color:rgba(37,71,177,.25);background:rgba(37,71,177,.08)}
.action-icon.primary:hover{background:rgba(37,71,177,.16);border-color:rgba(37,71,177,.4)}
.action-icon.danger{color:var(--red);border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.08)}
.action-icon.danger:hover{background:rgba(239,68,68,.16);border-color:rgba(239,68,68,.4)}
.actions-menu{position:relative;display:inline-flex}
.actions-dropdown{
    position:absolute;right:0;top:100%;min-width:148px;
    background:var(--surface);border:1px solid var(--border);border-radius:10px;
    box-shadow:0 12px 28px rgba(15,23,42,.14);padding:4px;z-index:1000;margin-top:6px;
}
.actions-dropdown:not(.hidden):empty{display:none}
.actions-dropdown form{display:block}
.actions-dropdown button,.actions-dropdown form button{
    width:100%;padding:10px 12px;border:none;background:none;text-align:left;border-radius:8px;
    cursor:pointer;font-size:.84rem;font-weight:600;color:var(--text);white-space:nowrap;
}
.actions-dropdown button:hover{background:var(--surface-2)}
.kebab-btn{color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border)}

/* Cards grid */
.cards-grid{
    display:grid;
    gap:clamp(12px,2vw,16px);
    width:100%;
    grid-template-columns:minmax(0,1fr);
}
.cards-grid.cols-3{grid-template-columns:minmax(0,1fr)}
@media (min-width:640px){
    .cards-grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (min-width:1024px){
    .cards-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
}
.sale-card,.txn-card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow);
    overflow:hidden;
    display:flex;
    width:100%;
    min-width:0;
    transition:box-shadow .25s ease,border-color .25s ease,transform .25s ease;
}
.sale-card:hover{
    border-color:rgba(37,71,177,.28);
    box-shadow:0 8px 24px rgba(15,23,42,.12);
    transform:translateY(-2px);
}
[data-theme="dark"] .sale-card:hover{
    border-color:rgba(96,165,250,.35);
    box-shadow:0 8px 24px rgba(0,0,0,.35);
}
.sale-accent,.txn-stripe{width:4px;background:var(--primary);flex-shrink:0}
.txn-stripe.success{background:var(--green)}
.txn-stripe.warning{background:var(--yellow)}
.txn-stripe.danger{background:var(--red)}
.sale-card-body,.txn-card-body{padding:16px;flex:1;min-width:0}
.sale-card-top{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.sale-card-top strong{display:block;font-size:.95rem;word-break:break-word}
.sale-card-top .text-primary{display:block;font-size:.78rem;margin-top:4px;word-break:break-word}
.sale-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,140px),1fr));gap:8px;font-size:.78rem;color:var(--text-muted)}
.sale-meta-grid span{display:flex;align-items:flex-start;gap:6px;min-width:0;word-break:break-word}
.txn-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:10px;flex-wrap:wrap}
.txn-main{display:flex;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap;width:100%}
.txn-main strong{display:block;font-size:1rem;word-break:break-word}
.txn-main small{color:var(--text-muted);font-size:.78rem}
.txn-amount{text-align:right}
.txn-amount strong{display:block;font-size:1.15rem}
.txn-amount small{color:var(--text-muted);font-size:.68rem}
.info-tags{display:flex;flex-wrap:wrap;gap:6px}
.info-tag{padding:4px 8px;border-radius:8px;background:var(--surface-2);font-size:.72rem;color:var(--text-muted)}
.txn-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,120px),1fr));gap:10px;margin-top:14px;width:100%}
.tag{padding:3px 8px;border-radius:8px;background:var(--surface-2);font-size:.68rem;color:var(--text-muted);font-weight:600}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border:none;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:.15s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-block{width:100%}
.btn-ghost{background:var(--surface-2);color:var(--text)}
.btn-outline-danger{background:transparent;border:1px solid var(--red);color:var(--red)}
.btn-solid-success{background:var(--green);color:#fff}

/* Modals */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);display:flex;align-items:center;justify-content:center;padding:20px;z-index:300}
.modal-card{background:var(--surface);border-radius:20px;box-shadow:var(--shadow);width:100%;max-width:560px;border:1px solid var(--border)}
.modal-card.sm{max-width:420px}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 20px 0;gap:12px}
.modal-head h3{font-size:1.15rem;font-weight:800}
.modal-title-row{display:flex;gap:12px;align-items:flex-start}
.modal-icon-wrap{width:40px;height:40px;border-radius:12px;background:rgba(37,71,177,.1);color:var(--primary);display:flex;align-items:center;justify-content:center}
.modal-close{width:36px;height:36px;border:none;border-radius:10px;background:var(--surface-2);cursor:pointer;font-size:1.2rem;color:var(--text-muted)}
.modal-body-text{padding:0 20px;color:var(--text-muted);font-size:.9rem}
.modal-sub{padding:0 20px;color:var(--text-muted);font-size:.85rem}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:20px}
.profile-card-inline{display:flex;gap:12px;align-items:center;margin:16px 20px 20px;padding:14px;border-radius:14px;background:var(--surface-2)}
.profile-card-inline small{display:block;color:var(--text-muted);font-size:.78rem;margin-top:2px}
.upload-drop{display:flex;flex-direction:column;align-items:center;gap:10px;margin:16px 20px;padding:36px 20px;border:1.5px dashed rgba(37,71,177,.35);border-radius:16px;background:rgba(37,71,177,.04);cursor:pointer;text-align:center}
.upload-drop strong{font-size:.95rem}
.upload-drop span{color:var(--text-muted);font-size:.82rem}
.upload-preview{display:flex;justify-content:space-between;align-items:center;margin:0 20px 8px;padding:12px 14px;border-radius:12px;background:var(--surface-2)}
.text-danger{color:var(--red);background:none;border:none;font-size:1.2rem;cursor:pointer}

/* Auth */
.auth-body{
    background:linear-gradient(160deg, #eef2fb 0%, #f8fafc 45%, #e8eef9 100%);
    min-height:100vh;
}
[data-theme="dark"] .auth-body{background:linear-gradient(160deg, #0b0f17 0%, #111827 100%)}
.login-page{
    min-height:100vh;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    padding:32px 20px 24px;
    gap:28px;
}
.login-card{
    width:min(420px, 100%);
    background:var(--surface);
    border-radius:24px;
    box-shadow:0 24px 64px rgba(37,71,177,.1), 0 8px 24px rgba(15,23,42,.06);
    padding:40px 36px 32px;
    border:1px solid rgba(255,255,255,.8);
}
[data-theme="dark"] .login-card{border-color:var(--border)}
.login-brand{text-align:center;margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid var(--border)}
.login-logo{
    width:56px;height:56px;margin:0 auto 14px;
    border-radius:16px;
    background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);
    color:#fff;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 10px 24px rgba(37,71,177,.28);
}
.login-brand h1{font-size:1.55rem;font-weight:800;color:var(--text);letter-spacing:-.02em;margin-bottom:8px}
.login-tagline{font-size:.88rem;color:var(--text-muted);line-height:1.55;max-width:300px;margin:0 auto}
.login-form-wrap h2{font-size:1.05rem;font-weight:700;margin-bottom:18px;color:var(--text)}
.login-submit{margin-top:8px;padding:14px;font-size:.95rem;font-weight:600;border-radius:12px;box-shadow:0 8px 20px rgba(37,71,177,.22)}
.login-submit:hover{box-shadow:0 10px 24px rgba(37,71,177,.3)}
.login-footer{font-size:.78rem;color:var(--text-muted);text-align:center}
.auth-body .form-group{margin-bottom:14px}
.auth-body .input-wrapper{position:relative}
.auth-body .form-input{
    width:100%;
    padding:14px 44px 14px 44px;
    border:1px solid transparent;
    border-radius:12px;
    background:#f1f5f9;
    color:var(--text);
    font-size:.9rem;
    transition:border-color .2s, background .2s, box-shadow .2s;
}
[data-theme="dark"] .auth-body .form-input{background:var(--surface-2);border-color:var(--border)}
.auth-body .form-input::placeholder{color:#94a3b8}
.auth-body .form-input:focus{
    outline:none;
    background:#fff;
    border-color:rgba(37,71,177,.35);
    box-shadow:0 0 0 4px rgba(37,71,177,.1);
}
[data-theme="dark"] .auth-body .form-input:focus{background:var(--surface-2);box-shadow:0 0 0 4px rgba(59,89,216,.2)}
.auth-body .input-icon{
    position:absolute;left:14px;top:50%;transform:translateY(-50%);
    width:18px;height:18px;color:var(--primary);pointer-events:none;
}
.auth-body .input-toggle{
    position:absolute;right:12px;top:50%;transform:translateY(-50%);
    background:none;border:none;color:#94a3b8;cursor:pointer;padding:4px;
}
.auth-body .input-toggle:hover{color:var(--text-muted)}
.remember-row{
    display:flex;align-items:center;gap:10px;
    margin:4px 0 18px;cursor:pointer;
    font-size:.85rem;color:var(--text-muted);user-select:none;
}
.remember-row input{position:absolute;opacity:0;width:0;height:0}
.remember-check{
    width:18px;height:18px;border-radius:5px;
    border:2px solid var(--border);background:var(--surface);
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
    transition:background .2s,border-color .2s;
}
.remember-row input:checked + .remember-check{
    background:var(--primary);border-color:var(--primary);
}
.remember-row input:checked + .remember-check::after{
    content:'';width:5px;height:9px;
    border:solid #fff;border-width:0 2px 2px 0;
    transform:rotate(45deg) translate(-1px,-1px);
}

/* Toasts */
.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:360px}
.toast{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:14px;background:var(--surface);border:1px solid var(--border);box-shadow:0 12px 40px rgba(0,0,0,.18);animation:toastIn .3s ease}
.toast.success{border-left:4px solid var(--green)}
.toast.error{border-left:4px solid var(--red)}
.toast.info{border-left:4px solid var(--primary)}
.toast-icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.75rem;font-weight:800}
.toast.success .toast-icon{background:var(--green-bg);color:var(--green)}
.toast.error .toast-icon{background:var(--red-bg);color:var(--red)}
.toast-body strong{display:block;font-size:.875rem;margin-bottom:2px}
.toast-body span{font-size:.8rem;color:var(--text-muted)}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{to{opacity:0;transform:translateX(20px)}}

.empty-inline{padding:40px;text-align:center;color:var(--text-muted)}

@media (prefers-reduced-motion:reduce){
    .stat-card,.panel,.action-card,.list-row{transition:box-shadow .35s ease,border-color .35s ease}
    .stat-card:hover,.panel:hover,.action-card:hover,.list-row:hover{box-shadow:0 12px 24px rgba(15,23,42,.1)}
    .stat-card:hover .stat-icon,.stat-card.is-tilting .stat-icon,
    .action-card:hover .stat-icon,.action-card.is-tilting .stat-icon{transform:none}
    .app-sidebar,.app-content{transition:none}
}

/* Stat grid column breakpoints */
@media (min-width:480px){
    .stat-grid.cols-2,
    .stat-grid.narrow{grid-template-columns:repeat(2,minmax(0,1fr))}
    .stat-grid.cols-3,
    .stat-grid.cols-4,
    .stat-grid.cols-5,
    .stat-grid.upload-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (min-width:640px){
    .stat-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (min-width:768px){
    .stat-grid.cols-4,
    .stat-grid.upload-stats{grid-template-columns:repeat(4,minmax(0,1fr))}
    .stat-grid.cols-5{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (min-width:1024px){
    .stat-grid.cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}
}

@media (max-width:1100px){
    .brand{min-width:auto}
}
@media (max-width:768px){
    .header-top{flex-wrap:wrap;padding:12px 16px;min-height:auto}
    .profile-text{display:none}
    .app-main{padding:16px 12px}
    .page-head{margin-bottom:18px}
    .page-head h1{font-size:clamp(1.25rem,5vw,1.45rem)}
    .page-head p{font-size:.875rem}
    .stat-grid.narrow{grid-template-columns:repeat(2,minmax(0,1fr))}
    .panel-grid{grid-template-columns:minmax(0,1fr)}
    .upload-page-grid{grid-template-columns:minmax(0,1fr)}
    .panel-scroll{max-height:none;min-height:360px}
    .toolbar-card{flex-direction:column;align-items:stretch}
    .toolbar-card .search-box{min-width:0;width:100%}
    .filter-dropdown{width:100%;flex-wrap:wrap;white-space:normal}
    .filter-dropdown label{flex-wrap:wrap;white-space:normal}
    .filter-control{width:100%}
    .filter-trigger{width:100%;min-width:0}
    .date-filter{flex-direction:column;align-items:stretch}
    .sales-toolbar{align-items:stretch}
    .sales-date-filter{min-width:0;width:100%}
    .sales-date-filter .date-range input{flex:1;min-width:0}
    .date-range{flex-wrap:wrap;width:100%}
    .date-range input{width:100%;max-width:none}
    .table-scroll{overflow-x:auto;margin:0 -4px;padding:0 4px}
    .data-table{min-width:720px}
    .page-head.row-between{align-items:stretch}
    .login-card{padding:32px 24px 28px;border-radius:20px}
    .segment-tab{font-size:.78rem;padding:10px 8px;min-width:max(88px,28%)}
    .upload-pagination{flex-direction:column;align-items:stretch;text-align:center}
    .action-grid{grid-template-columns:minmax(0,1fr)}
    .panel-head{flex-wrap:wrap;gap:10px}
    .list-row > div{width:100%}
    .list-row .text-right{text-align:left;margin-top:8px}
}
@media (max-width:480px){
    .app-main{padding:12px 10px}
    .stat-grid.cols-2,
    .stat-grid.cols-3,
    .stat-grid.cols-4,
    .stat-grid.cols-5,
    .stat-grid.upload-stats,
    .stat-grid.narrow{grid-template-columns:minmax(0,1fr)}
    .txn-actions{grid-template-columns:minmax(0,1fr)}
    .sale-meta-grid{grid-template-columns:minmax(0,1fr)}
    .sale-meta-grid .sale-amount{grid-column:1;justify-self:stretch;text-align:left}
    .toast-container{left:12px;right:12px;max-width:none}
    .profile-dropdown{width:min(280px,calc(100vw - 24px))}
    .modal-overlay{padding:12px}
    .data-table{min-width:600px}
    .data-table th,.data-table td{padding:10px 12px;font-size:.8rem}
}
@media (max-width:360px){
    .segment-tab{font-size:.72rem;padding:8px 6px}
    .stat-card strong{font-size:1.2rem}
}
