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

*,*::before,*::after{box-sizing:border-box}
:root{
  --bg:#ffffff;
  --muted:#f4f4f5;
  --muted-2:#fafafa;
  --border:#e4e4e7;
  --border-strong:#d4d4d8;
  --fg:#09090b;
  --fg-muted:#71717a;
  --fg-soft:#a1a1aa;
  --primary:#2563eb;
  --primary-hover:#1d4ed8;
  --primary-soft:#eff6ff;
  --green:#16a34a;
  --green-soft:#f0fdf4;
  --red:#dc2626;
  --red-soft:#fef2f2;
  --amber:#d97706;
  --amber-soft:#fffbeb;
  --shadow-sm:0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow:0 1px 3px 0 rgb(0 0 0 / 0.06), 0 1px 2px -1px rgb(0 0 0 / 0.06);
  --radius:10px;
}
html,body{margin:0;padding:0;background:#f7f7f8;color:var(--fg);font-family:'Inter',sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

.shell{width:1440px;max-width:100%;margin:0 auto;background:var(--bg);min-height:100vh;display:grid;grid-template-columns:248px 1fr}

/* Sidebar */
.sidebar{position:sticky;top:0;align-self:start;height:100vh;border-right:1px solid var(--border);background:#fafafa;padding:18px 14px;display:flex;flex-direction:column;gap:18px;overflow-y:auto}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px}
.brand-mark{width:30px;height:30px;border-radius:8px;background:#09090b;color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;letter-spacing:.5px}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text b{font-weight:600;font-size:13.5px}
.brand-text span{font-size:11px;color:var(--fg-muted)}
.season-pill{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:12.5px;cursor:pointer}
.season-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--green)}
.season-pill b{font-weight:600}
.season-pill .chev{margin-left:auto;color:var(--fg-soft)}
.nav-section{display:flex;flex-direction:column;gap:2px}
.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-soft);padding:6px 10px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:7px;color:#3f3f46;font-size:13px;cursor:pointer;text-decoration:none}
.nav-item:hover{background:var(--muted)}
.nav-item.active{background:#09090b;color:#fff}
.nav-item .badge{margin-left:auto;font-size:10.5px;background:var(--muted);color:#52525b;padding:1px 6px;border-radius:999px}
.nav-item.active .badge{background:rgba(255,255,255,.15);color:#e4e4e7}
.nav-icon{width:16px;height:16px;display:inline-block;flex-shrink:0}

.side-foot{margin-top:auto;border-top:1px solid var(--border);padding-top:12px;display:flex;align-items:center;gap:10px}
.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#fbbf24,#dc2626);color:#fff;display:grid;place-items:center;font-weight:600;font-size:12px}
.who b{display:block;font-size:12.5px;font-weight:600}
.who span{font-size:11px;color:var(--fg-muted)}

/* Topbar */
.top{position:sticky;top:0;z-index:5;background:#ffffffee;backdrop-filter:saturate(180%) blur(6px);border-bottom:1px solid var(--border);padding:10px 28px;display:flex;align-items:center;gap:14px}
.crumbs{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--fg-muted)}
.crumbs b{color:var(--fg);font-weight:500}
.crumbs .sep{color:var(--fg-soft)}
.search{margin-left:18px;flex:1;max-width:380px;position:relative}
.search input{width:100%;height:34px;border:1px solid var(--border);border-radius:8px;padding:0 12px 0 32px;font:inherit;background:#fff;outline:none}
.search input:focus{border-color:#a1a1aa;box-shadow:0 0 0 3px #f4f4f5}
.search svg{position:absolute;left:10px;top:9px;color:var(--fg-soft)}
.search kbd{position:absolute;right:8px;top:7px;font:500 10.5px Inter;background:var(--muted);border:1px solid var(--border);padding:2px 5px;border-radius:5px;color:var(--fg-muted)}
.top .actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.icon-btn{width:34px;height:34px;border:1px solid var(--border);background:#fff;border-radius:8px;display:grid;place-items:center;cursor:pointer;color:#3f3f46;position:relative}
.icon-btn:hover{background:var(--muted)}
.icon-btn .nd{position:absolute;top:6px;right:6px;width:7px;height:7px;background:var(--red);border-radius:50%;border:1.5px solid #fff}
.btn{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 12px;border-radius:8px;font:500 13px Inter;cursor:pointer;border:1px solid var(--border);background:#fff;color:var(--fg);text-decoration:none}
.btn:hover{background:var(--muted)}
.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn.primary:hover{background:var(--primary-hover)}
.btn.ghost{border-color:transparent;background:transparent}
.btn.ghost:hover{background:var(--muted)}
.btn.dark{background:#09090b;color:#fff;border-color:#09090b}
.btn.dark:hover{background:#27272a}
.btn.lg{height:40px;padding:0 18px;font-size:14px}
.btn.danger{background:var(--red);color:#fff;border-color:var(--red)}
.btn.danger:hover{background:#b91c1c}

/* Page */
.page{padding:24px 28px 40px}
.page-head{display:flex;align-items:flex-start;gap:18px;margin-bottom:18px}
.page-head h1{margin:0 0 4px 0;font-size:22px;font-weight:600;letter-spacing:-.01em}
.page-head p{margin:0;color:var(--fg-muted);font-size:13px;max-width:740px}
.head-meta{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:#fff;font-size:12px;color:#3f3f46}
.chip .dot{width:6px;height:6px;border-radius:50%;background:var(--amber)}
.chip.green .dot{background:var(--green)}
.chip.blue .dot{background:var(--primary)}
.chip.red .dot{background:var(--red)}

/* KPI strip */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.kpis.three{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.kpi{padding:16px}
.kpi .lab{font-size:12px;color:var(--fg-muted);font-weight:500;display:flex;align-items:center;gap:6px}
.kpi .val{font-size:24px;font-weight:600;letter-spacing:-.02em;margin-top:6px}
.kpi .sub{margin-top:8px;font-size:12px;color:var(--fg-muted);display:flex;align-items:center;gap:8px}
.delta{display:inline-flex;align-items:center;gap:3px;font-weight:500;padding:1px 6px;border-radius:5px;font-size:11.5px}
.delta.up{color:#15803d;background:var(--green-soft)}
.delta.down{color:#b91c1c;background:var(--red-soft)}
.delta.warn{color:#a16207;background:var(--amber-soft)}
.delta.flat{color:var(--fg-muted)}

/* Toolbar */
.toolbar{display:flex;align-items:center;gap:8px;padding:12px;border:1px solid var(--border);border-bottom:none;border-radius:var(--radius) var(--radius) 0 0;background:#fff;flex-wrap:wrap}
.tabs{display:flex;background:var(--muted);padding:3px;border-radius:8px;gap:2px}
.tab{padding:5px 11px;font-size:12.5px;font-weight:500;color:#52525b;border-radius:6px;cursor:pointer}
.tab.active{background:#fff;color:var(--fg);box-shadow:var(--shadow-sm)}
.tool-sep{width:1px;height:22px;background:var(--border);margin:0 4px}
.filter-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--border);border-radius:7px;font-size:12.5px;cursor:pointer;background:#fff;color:#3f3f46}
.filter-btn:hover{background:var(--muted)}
.filter-btn .x{color:var(--fg-soft)}
.toolbar .right{margin-left:auto;display:flex;align-items:center;gap:8px}
.saving{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--fg-muted)}
.saving .pulse{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(22,163,74,.5);animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(22,163,74,.5)}70%{box-shadow:0 0 0 6px rgba(22,163,74,0)}100%{box-shadow:0 0 0 0 rgba(22,163,74,0)}}

/* Grid table */
.grid-card{border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);overflow:hidden;background:#fff}
.grid-card.standalone{border-radius:var(--radius)}
table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
thead th{position:sticky;top:0;background:#fafafa;text-align:left;font-weight:500;color:#52525b;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap}
thead th .h-sub{display:block;font-weight:400;text-transform:none;letter-spacing:0;color:var(--fg-soft);font-size:11px;margin-top:2px}
th.num,td.num{text-align:right;font-variant-numeric:tabular-nums}
tbody td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr:hover td{background:#fafafa}
tbody tr.cat-row td{background:#f4f4f5;font-weight:600;color:#3f3f46;font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:7px 12px}
tbody tr.cat-row td .ci{display:flex;align-items:center;gap:8px}
tbody tr.cat-row .pill{font-size:11px;font-weight:500;text-transform:none;letter-spacing:0;color:var(--fg-muted);background:#fff;border:1px solid var(--border);padding:1px 7px;border-radius:999px}
.sku{display:flex;align-items:center;gap:10px}
.swatch{width:30px;height:30px;border-radius:6px;border:1px solid var(--border);flex-shrink:0;background:#fafafa;display:grid;place-items:center;font-size:10px;color:var(--fg-soft);font-weight:500}
.sku b{display:block;font-weight:500;font-size:13px;color:var(--fg)}
.sku span{display:block;font-size:11.5px;color:var(--fg-muted);margin-top:1px}
.qty-input{width:78px;height:30px;border:1px solid var(--border);border-radius:6px;padding:0 8px;font:500 13px Inter;text-align:right;background:#fff;color:var(--fg);outline:none}
.qty-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
.qty-input.changed{border-color:var(--amber);background:#fffdf6}
.qty-input.locked{background:var(--muted);color:var(--fg-muted);cursor:not-allowed}
.delta-cell{display:inline-flex;gap:4px;align-items:center;font-size:12px;font-variant-numeric:tabular-nums}
.badge-soft{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;padding:2px 7px;border-radius:5px}
.b-blue{color:#1d4ed8;background:var(--primary-soft)}
.b-green{color:#15803d;background:var(--green-soft)}
.b-amber{color:#a16207;background:var(--amber-soft)}
.b-red{color:#b91c1c;background:var(--red-soft)}
.b-zinc{color:#52525b;background:var(--muted)}
.row-action{color:var(--fg-soft);cursor:pointer;padding:4px;border-radius:4px}
.row-action:hover{background:var(--muted);color:var(--fg)}

tfoot td{padding:12px;background:#fafafa;font-weight:600;border-top:1px solid var(--border-strong);font-size:13px}
tfoot td .sublab{font-size:11px;font-weight:400;color:var(--fg-muted);display:block;margin-top:1px}

.grid-footer{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--border);background:#fafafa;font-size:12.5px;color:var(--fg-muted)}
.grid-footer .right{margin-left:auto;display:flex;align-items:center;gap:6px}
.pager-btn{width:28px;height:28px;border:1px solid var(--border);background:#fff;border-radius:6px;display:grid;place-items:center;cursor:pointer;color:#52525b}
.pager-btn:hover{background:var(--muted)}
.page-num{padding:0 9px;height:28px;border:1px solid var(--border);background:#fff;border-radius:6px;display:grid;place-items:center;font-size:12.5px;cursor:pointer}
.page-num.active{background:#09090b;color:#fff;border-color:#09090b}

/* Sticky commit bar */
.commit-bar{margin-top:18px;display:flex;align-items:center;gap:14px;padding:14px 16px;background:#0b0b0d;color:#fff;border-radius:var(--radius);flex-wrap:wrap}
.commit-bar .cb-meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.cb-stat span{display:block;font-size:11px;color:#a1a1aa}
.cb-stat b{font-weight:600;font-size:15px}
.cb-actions{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.cb-actions .btn{background:transparent;color:#fff;border-color:#27272a}
.cb-actions .btn:hover{background:#18181b}
.cb-actions .btn.primary{background:#fff;color:#09090b;border-color:#fff}
.cb-actions .btn.primary:hover{background:#e4e4e7}
.cb-divider{width:1px;height:26px;background:#27272a}

hr.r{border:none;border-top:1px solid var(--border);margin:0}

/* Form controls (admin / login) */
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;font-weight:500;color:#3f3f46}
.field .hint{font-size:11.5px;color:var(--fg-muted)}
.input,.select,.textarea{width:100%;height:36px;border:1px solid var(--border);border-radius:8px;padding:0 12px;font:inherit;background:#fff;color:var(--fg);outline:none}
.textarea{height:auto;min-height:84px;padding:10px 12px}
.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
.select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,#a1a1aa 50%),linear-gradient(135deg,#a1a1aa 50%,transparent 50%);background-position:calc(100% - 16px) 15px,calc(100% - 11px) 15px;background-size:5px 5px;background-repeat:no-repeat;padding-right:32px}

.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}

/* Login screen */
.auth-shell{min-height:100vh;display:grid;grid-template-columns:1fr 520px;background:#09090b;color:#fff}
.auth-hero{position:relative;padding:48px;display:flex;flex-direction:column;justify-content:space-between;background:radial-gradient(1200px 600px at 20% 0%,#1e1b4b 0%,#09090b 60%)}
.auth-hero .brand{padding:0;color:#fff}
.auth-hero .brand-mark{background:#fff;color:#09090b}
.auth-hero .brand-text b{color:#fff}
.auth-hero .brand-text span{color:#a1a1aa}
.auth-hero h2{font-size:34px;font-weight:600;letter-spacing:-.02em;line-height:1.18;margin:0 0 14px;max-width:520px}
.auth-hero p{color:#a1a1aa;max-width:480px;font-size:14px;margin:0 0 20px}
.auth-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:520px}
.auth-stats .card{background:#0f0f12;border-color:#27272a;color:#fff}
.auth-stats .kpi .val{color:#fff}
.auth-stats .kpi .lab{color:#a1a1aa}
.auth-stats .kpi .sub{color:#71717a}
.auth-form{background:#fff;color:var(--fg);padding:48px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.auth-form h1{margin:0;font-size:24px;font-weight:600;letter-spacing:-.01em}
.auth-form .sub{color:var(--fg-muted);margin:-8px 0 8px;font-size:13px}
.auth-roles{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.auth-role{padding:10px 12px;border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:12.5px;display:flex;flex-direction:column;gap:2px}
.auth-role.active{border-color:var(--primary);background:var(--primary-soft);color:#1d4ed8}
.auth-role b{font-weight:600;font-size:13px}
.auth-role span{color:var(--fg-muted);font-size:11.5px}
.auth-role.active span{color:#1d4ed8;opacity:.85}

/* Season selection */
.role-card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.season-card{display:flex;flex-direction:column;gap:10px;padding:18px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;text-decoration:none;color:inherit;cursor:pointer}
.season-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}
.season-card .head{display:flex;align-items:center;justify-content:space-between}
.season-card h3{margin:0;font-size:16px;font-weight:600}
.season-card .meta{font-size:12px;color:var(--fg-muted);display:flex;gap:10px}
.season-card .meta b{color:var(--fg);font-weight:600}
.season-card .progress{height:6px;background:var(--muted);border-radius:999px;overflow:hidden}
.season-card .progress > i{display:block;height:100%;background:var(--green)}

.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tile{padding:18px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;display:flex;flex-direction:column;gap:8px;cursor:pointer;text-decoration:none;color:inherit}
.tile:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}
.tile .ti{width:34px;height:34px;border-radius:8px;background:#09090b;color:#fff;display:grid;place-items:center}
.tile h4{margin:0;font-size:14px;font-weight:600}
.tile p{margin:0;font-size:12.5px;color:var(--fg-muted)}

/* Two col split */
.split{display:grid;grid-template-columns:2fr 1fr;gap:18px}
.split-3-2{display:grid;grid-template-columns:3fr 2fr;gap:18px}

.section-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-muted);margin:0 0 10px}
.section-title-row{display:flex;align-items:center;justify-content:space-between;margin:0 0 10px}
.section-title-row h3{margin:0;font-size:16px;font-weight:600}
.section-title-row .meta{font-size:12px;color:var(--fg-muted)}

.list{display:flex;flex-direction:column}
.list .row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}
.list .row:last-child{border-bottom:none}
.list .row:hover{background:var(--muted-2)}
.list .row b{font-weight:500;font-size:13px}
.list .row span{font-size:12px;color:var(--fg-muted)}
.list .row .right{margin-left:auto;display:flex;align-items:center;gap:8px}

/* File upload boxes */
.upload-zone{border:1.5px dashed var(--border-strong);border-radius:var(--radius);padding:24px;text-align:center;background:var(--muted-2);color:var(--fg-muted);font-size:13px;cursor:pointer}
.upload-zone:hover{background:#f4f4f5;border-color:#a1a1aa;color:var(--fg)}
.upload-zone .ico{width:42px;height:42px;border-radius:50%;background:#fff;border:1px solid var(--border);display:grid;place-items:center;margin:0 auto 8px;color:#3f3f46}
.upload-zone b{display:block;color:var(--fg);font-weight:600;font-size:14px;margin-bottom:4px}

/* Stat row mini */
.stat-row{display:flex;gap:18px;flex-wrap:wrap;padding:14px;border-bottom:1px solid var(--border);background:#fafafa;border-radius:var(--radius) var(--radius) 0 0}
.stat-row .stat span{display:block;font-size:11px;color:var(--fg-muted)}
.stat-row .stat b{font-weight:600;font-size:15px}

/* Toggle/switch */
.switch{display:inline-flex;align-items:center;gap:8px;cursor:pointer}
.switch .track{width:30px;height:18px;background:var(--border);border-radius:999px;position:relative;transition:.15s}
.switch .knob{position:absolute;width:14px;height:14px;border-radius:50%;background:#fff;top:2px;left:2px;transition:.15s;box-shadow:var(--shadow-sm)}
.switch.on .track{background:var(--primary)}
.switch.on .knob{left:14px}

/* Footer for centered pages */
.center-foot{margin-top:24px;font-size:12px;color:var(--fg-muted);text-align:center}

/* Modals are not used here, but utility classes */
.row-flex{display:flex;align-items:center;gap:8px}
.gap-2{gap:8px}
.gap-3{gap:12px}
.muted{color:var(--fg-muted)}
.right{margin-left:auto}

/* Two-col bar charts (lightweight) */
.bar-chart{display:flex;flex-direction:column;gap:8px;padding:14px}
.bar-chart .row{display:grid;grid-template-columns:140px 1fr 60px;gap:10px;align-items:center;font-size:12.5px}
.bar-chart .row .lab{color:#3f3f46}
.bar-chart .row .bar{height:10px;background:var(--muted);border-radius:999px;overflow:hidden}
.bar-chart .row .bar > i{display:block;height:100%;background:var(--primary)}
.bar-chart .row .val{font-variant-numeric:tabular-nums;text-align:right;color:#3f3f46}

/* Notification / banners */
.banner{padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;display:flex;align-items:center;gap:12px;margin-bottom:14px}
.banner.info{background:var(--primary-soft);border-color:#bfdbfe;color:#1d4ed8}
.banner.warn{background:var(--amber-soft);border-color:#fed7aa;color:#a16207}
.banner.ok{background:var(--green-soft);border-color:#bbf7d0;color:#15803d}
.banner.err{background:var(--red-soft);border-color:#fecaca;color:#b91c1c}
.banner b{font-weight:600}

/* Status pills inline */
.pill-status{display:inline-flex;align-items:center;gap:6px;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:500;background:var(--muted);color:#52525b}
.pill-status.draft{background:var(--amber-soft);color:#a16207}
.pill-status.committed{background:var(--green-soft);color:#15803d}
.pill-status.locked{background:var(--muted);color:#52525b}
.pill-status.open{background:var(--primary-soft);color:#1d4ed8}
.pill-status.closed{background:var(--muted);color:#52525b}
.pill-status.error{background:var(--red-soft);color:#b91c1c}
.pill-status .dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* Modal-ish dialog (not interactive) */

/* Responsive guard */
@media (max-width: 1100px){
  .shell{grid-template-columns:200px 1fr}
  .sidebar{padding:14px 10px}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .tile-grid,.role-card-grid{grid-template-columns:repeat(2,1fr)}
  .form-grid.three{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 720px){
  .shell{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;border-right:none;border-bottom:1px solid var(--border)}
  .auth-shell{grid-template-columns:1fr}
  .auth-hero{padding:24px}
  .auth-form{padding:24px}
  .kpis{grid-template-columns:1fr}
  .tile-grid,.role-card-grid{grid-template-columns:1fr}
  .form-grid,.form-grid.three{grid-template-columns:1fr}
  .split,.split-3-2{grid-template-columns:1fr}
}
