/* ════════════════════════════════════════════════════════════
   Stock Aging Dashboard — VCAN design system
   Parchment (light) primary · Espresso (dark) toggle
   ════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ─── Theme tokens (shared with landing page) ─── */
:root, [data-theme="light"] {
  --bg-0:#ede4cf; --bg-1:#faf5e8; --surface:#ffffff; --surface-hi:#fbf6ea;
  --surface-2:#f4ecda;
  --line:rgba(42,29,8,.10); --line-hi:rgba(42,29,8,.20);
  --text:#2a1d08; --text-mute:#7a6e5c; --text-dim:#a99a80;
  --gold:#8c6418; --gold-soft:#c79433; --gold-ink:#fff8ed;
  --gold-wash:rgba(199,147,51,.12);
  --green:#3f8f3a; --green-soft:#5ba34f;
  --grade-b:#9333ea;
  --noise:0;
  --zebra:rgba(42,29,8,.022);
  --shadow:0 1px 2px rgba(42,29,8,.05), 0 6px 22px -16px rgba(42,29,8,.30);
}
[data-theme="dark"] {
  --bg-0:#0a0705; --bg-1:#140e0b; --surface:#1d1612; --surface-hi:#241c16;
  --surface-2:#2a201a;
  --line:rgba(239,230,216,.08); --line-hi:rgba(239,230,216,.20);
  --text:#f4ecdd; --text-mute:#b8a98f; --text-dim:#7a6e5c;
  --gold:#f0b340; --gold-soft:#ffd27a; --gold-ink:#2a1d08;
  --gold-wash:rgba(240,179,64,.10);
  --green:#9fcf63; --green-soft:#b6dd86;
  --grade-b:#c79bed;
  --noise:.05;
  --zebra:rgba(239,230,216,.022);
  --shadow:0 1px 2px rgba(0,0,0,.4), 0 18px 38px -24px rgba(0,0,0,.8);
}

/* fixed espresso tokens — used by the masthead in BOTH themes (a letterhead) */
:root {
  --ink-0:#16100c; --ink-1:#1d1612; --ink-2:#2a201a;
  --ink-line:rgba(239,230,216,.10); --ink-line-hi:rgba(239,230,216,.18);
  --ink-text:#f4ecdd; --ink-mute:#b8a98f; --ink-dim:#7a6e5c;
  --ink-gold:#f0b340; --ink-gold-soft:#ffd27a;
}

/* status — vivid functional signals, kept consistent across themes */
:root {
  --s-expired:#dc2626; --s-critical:#ea580c; --s-warning:#d4900b; --s-safe:#16a34a;
  --s-expired-bg:rgba(220,38,38,.10); --s-critical-bg:rgba(234,88,12,.10);
  --s-warning-bg:rgba(212,144,11,.13); --s-safe-bg:rgba(22,163,74,.11);
  --s-unknown:#94a3b8; --s-unknown-bg:rgba(148,163,184,.12);
}
[data-theme="dark"] {
  --s-warning:#e3a82a;
  --s-expired-bg:rgba(220,38,38,.16); --s-critical-bg:rgba(234,88,12,.16);
  --s-warning-bg:rgba(227,168,42,.16); --s-safe-bg:rgba(22,163,74,.18);
}

html { background:var(--bg-0); }
body {
  font-family:'Inter', system-ui, sans-serif;
  background:var(--bg-1);
  color:var(--text);
  font-size:14px; line-height:1.45;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  position:relative;
}
[data-theme="dark"] body {
  background:radial-gradient(ellipse at 50% -8%, #221912 0%, #140e0b 46%, #0a0705 100%);
}
body::after {
  content:""; position:fixed; inset:0; pointer-events:none; z-index:9999;
  opacity:var(--noise); mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/></svg>");
}

.mono { font-family:'JetBrains Mono', ui-monospace, monospace; }
.serif { font-family:'Fraunces', Georgia, serif; }
.tnum { font-variant-numeric:tabular-nums; }

/* ════════ Masthead (espresso letterhead) ════════ */
.masthead {
  background:linear-gradient(120deg, var(--ink-1) 0%, var(--ink-2) 60%, var(--ink-1) 100%);
  border-bottom:1px solid var(--ink-line-hi);
  color:var(--ink-text);
  padding:16px 26px;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  position:relative; overflow:hidden;
}
.masthead::before {
  content:""; position:absolute; right:-80px; top:-120px; width:420px; height:300px;
  background:radial-gradient(ellipse at center, rgba(240,179,64,.14) 0%, transparent 62%);
  pointer-events:none;
}
.mh-left { display:flex; align-items:center; gap:15px; position:relative; z-index:1; }
.mh-mark {
  width:44px; height:44px; flex-shrink:0;
  background:var(--ink-gold); color:#2a1d08; border-radius:11px;
  display:flex; align-items:center; justify-content:center;
  font-family:'Fraunces', serif; font-weight:700; font-size:23px;
  box-shadow:0 0 0 1px rgba(255,210,122,.35), 0 8px 22px -8px rgba(240,179,64,.6);
}
.mh-titles .eyebrow {
  font-family:'JetBrains Mono', monospace; font-size:9.5px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-dim); margin-bottom:4px;
}
.mh-titles h1 {
  font-family:'Fraunces', Georgia, serif; font-weight:500; font-size:26px;
  letter-spacing:-.02em; line-height:1; color:var(--ink-text);
}
.mh-titles h1 em { font-style:italic; color:var(--ink-gold); font-weight:400; }
.mh-right { display:flex; align-items:center; gap:18px; position:relative; z-index:1; }
.mh-reports { display:flex; gap:9px; }
.rep-chip {
  display:flex; align-items:center; gap:8px;
  background:rgba(239,230,216,.05); border:1px solid var(--ink-line);
  border-radius:8px; padding:6px 11px;
}
.rep-chip .rc-co {
  font-family:'JetBrains Mono', monospace; font-size:9px; font-weight:600;
  letter-spacing:.1em; padding:2px 6px; border-radius:4px;
}
.rep-chip .rc-co.moola { color:#d8a7e8; background:rgba(216,167,232,.14); }
.rep-chip .rc-co.vcan  { color:var(--ink-gold-soft); background:rgba(255,210,122,.12); }
.rep-chip .rc-dt {
  font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--ink-text);
  font-weight:500;
}
.mh-gen {
  text-align:right; font-family:'JetBrains Mono', monospace; font-size:9.5px;
  line-height:1.55; color:var(--ink-dim); letter-spacing:.05em;
}
.mh-gen b { display:block; color:var(--ink-mute); font-weight:500; }
.theme-btn {
  width:34px; height:34px; border-radius:8px; flex-shrink:0;
  border:1px solid var(--ink-line-hi); background:rgba(239,230,216,.04);
  color:var(--ink-gold); cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:background .15s;
}
.theme-btn:hover { background:rgba(239,230,216,.1); }
.theme-btn svg { width:15px; height:15px; pointer-events:none; }
.icon-sun { display:none; } .icon-moon { display:block; }
[data-theme="light"] .icon-sun { display:block; } [data-theme="light"] .icon-moon { display:none; }

/* ════════ Shell ════════ */
.shell { padding:18px 26px 40px; max-width:1640px; margin:0 auto; }
.card {
  background:var(--surface); border:1px solid var(--line); border-radius:14px;
  box-shadow:var(--shadow);
}

/* ════════ KPI section ════════ */
.kpi-head {
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:16px; margin-bottom:13px; flex-wrap:wrap;
}
.section-label {
  font-family:'JetBrains Mono', monospace; font-size:10px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--text-dim);
  display:flex; align-items:center; gap:9px;
}
.section-label::before {
  content:""; width:18px; height:2px; background:var(--gold-soft); border-radius:2px;
}
.kpi-overview {
  font-family:'Fraunces', Georgia, serif; font-size:19px; font-weight:500;
  letter-spacing:-.01em; color:var(--text); margin-top:2px;
}
.kpi-overview .total { color:var(--gold); }

/* variation switcher */
.seg {
  display:inline-flex; background:var(--surface-2); border:1px solid var(--line);
  border-radius:9px; padding:3px; gap:2px;
}
.seg button {
  font-family:'JetBrains Mono', monospace; font-size:10.5px; font-weight:600;
  letter-spacing:.04em; color:var(--text-mute); background:transparent;
  border:none; border-radius:6px; padding:6px 13px; cursor:pointer;
  transition:all .14s; white-space:nowrap;
}
.seg button:hover { color:var(--text); }
.seg button.on {
  background:var(--surface); color:var(--gold);
  box-shadow:0 1px 2px rgba(42,29,8,.12); border:1px solid var(--line-hi);
  padding:5px 12px;
}
[data-theme="dark"] .seg button.on { background:var(--ink-2); }
.seg-cap {
  font-family:'JetBrains Mono', monospace; font-size:9px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--text-dim); margin-right:9px;
}

/* ===== KPI Layout A — refined stat cards ===== */
.kpiA { display:grid; grid-template-columns:repeat(7, 1fr); gap:11px; }
.kpiA .k {
  background:var(--surface); border:1px solid var(--line); border-radius:12px;
  padding:15px 16px 14px; box-shadow:var(--shadow); position:relative; overflow:hidden;
}
.kpiA .k::before {
  content:""; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:var(--kc, var(--gold-soft));
}
.kpiA .k .kl {
  font-family:'JetBrains Mono', monospace; font-size:9.5px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--text-mute); margin-bottom:9px;
}
.kpiA .k .kv {
  font-family:'Fraunces', Georgia, serif; font-weight:600; font-size:30px;
  line-height:.95; color:var(--kc-ink, var(--text)); letter-spacing:-.01em;
}
.kpiA .k .ks {
  font-family:'JetBrains Mono', monospace; font-size:9.5px; color:var(--text-dim);
  margin-top:7px; letter-spacing:.02em;
}

/* ===== KPI Layout B — ledger band ===== */
.kpiB {
  display:flex; background:var(--surface); border:1px solid var(--line);
  border-radius:14px; box-shadow:var(--shadow); overflow:hidden;
}
.kpiB .k {
  flex:1; padding:18px 20px; border-left:1px solid var(--line); position:relative;
  min-width:0;
}
.kpiB .k:first-child { border-left:none; }
.kpiB .k .kl {
  font-family:'JetBrains Mono', monospace; font-size:9.5px; font-weight:600;
  letter-spacing:.11em; text-transform:uppercase; color:var(--text-mute);
  margin-bottom:11px; display:flex; align-items:center; gap:7px;
}
.kpiB .k .kl::before {
  content:""; width:7px; height:7px; border-radius:50%; background:var(--kc, var(--gold-soft));
  flex-shrink:0;
}
.kpiB .k .kv {
  font-family:'Fraunces', Georgia, serif; font-weight:600; font-size:34px;
  line-height:.9; color:var(--kc-ink, var(--text)); letter-spacing:-.015em;
}
.kpiB .k .ks {
  font-family:'JetBrains Mono', monospace; font-size:9.5px; color:var(--text-dim);
  margin-top:8px;
}

/* ===== KPI Layout C — proportional bars ===== */
.kpiC { display:grid; grid-template-columns:repeat(5, 1fr) 1.1fr; gap:11px; }
.kpiC .k {
  background:var(--surface); border:1px solid var(--line); border-radius:12px;
  padding:15px 16px 13px; box-shadow:var(--shadow);
}
.kpiC .k .ktop { display:flex; align-items:baseline; justify-content:space-between; gap:8px; }
.kpiC .k .kl {
  font-family:'JetBrains Mono', monospace; font-size:9.5px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--text-mute);
}
.kpiC .k .kv {
  font-family:'Fraunces', Georgia, serif; font-weight:600; font-size:26px;
  line-height:1; color:var(--kc-ink, var(--text)); letter-spacing:-.01em;
}
.kpiC .k .kbar {
  height:6px; border-radius:3px; background:var(--surface-2); margin-top:11px; overflow:hidden;
}
.kpiC .k .kbar i {
  display:block; height:100%; border-radius:3px; background:var(--kc, var(--gold-soft));
}
.kpiC .k .ks {
  font-family:'JetBrains Mono', monospace; font-size:9px; color:var(--text-dim); margin-top:7px;
}
/* the wide qty cell in layout C */
.kpiC .k.kwide { display:flex; flex-direction:column; justify-content:center; gap:10px; }
.kpiC .k.kwide .qrow { display:flex; align-items:baseline; justify-content:space-between; }
.kpiC .k.kwide .qv { font-family:'Fraunces', serif; font-weight:600; font-size:21px; }
.kpiC .k.kwide .qv.dmg { color:var(--s-expired); }

/* accent classes for KPI cards */
.kc-blue   { --kc:var(--gold-soft); --kc-ink:var(--gold); }
.kc-exp    { --kc:var(--s-expired);  --kc-ink:var(--s-expired); }
.kc-crit   { --kc:var(--s-critical); --kc-ink:var(--s-critical); }
.kc-warn   { --kc:var(--s-warning);  --kc-ink:var(--s-warning); }
.kc-safe   { --kc:var(--s-safe);     --kc-ink:var(--s-safe); }
.kc-good   { --kc:var(--green-soft); --kc-ink:var(--green); }
.kc-dmg    { --kc:var(--s-expired);  --kc-ink:var(--s-expired); }

/* ════════ Filter bar ════════ */
.filter-bar {
  background:var(--surface); border:1px solid var(--line); border-radius:14px;
  box-shadow:var(--shadow); padding:14px 18px; margin:16px 0;
}
.filter-row { display:flex; flex-wrap:wrap; gap:20px 22px; align-items:flex-end; }
.fg { display:flex; flex-direction:column; gap:7px; }
.fg-label {
  font-family:'JetBrains Mono', monospace; font-size:9px; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase; color:var(--text-dim);
}
.btn-grp { display:flex; gap:5px; flex-wrap:wrap; }
.tog {
  font-family:'Inter', sans-serif; padding:6px 12px; border-radius:7px;
  border:1px solid var(--line-hi); background:var(--surface-hi); color:var(--text-mute);
  font-size:12px; font-weight:500; cursor:pointer; transition:all .12s; line-height:1.4;
}
.tog:hover { border-color:var(--gold-soft); color:var(--text); }
.tog.on { border-color:var(--gold); background:var(--gold-wash); color:var(--gold); font-weight:600; }
.tog.on.t-expired  { border-color:var(--s-expired);  background:var(--s-expired-bg);  color:var(--s-expired); }
.tog.on.t-critical { border-color:var(--s-critical); background:var(--s-critical-bg); color:var(--s-critical); }
.tog.on.t-warning  { border-color:var(--s-warning);  background:var(--s-warning-bg);  color:var(--s-warning); }
.tog.on.t-safe     { border-color:var(--s-safe);     background:var(--s-safe-bg);     color:var(--s-safe); }
.tog.on.t-pet  { border-color:#9b6dd6; background:rgba(155,109,214,.13); color:#8a55d0; }
.tog.on.t-wmf  { border-color:#1399b8; background:rgba(19,153,184,.13); color:#0e7e98; }
.tog.on.t-fmcg { border-color:#2f9e6f; background:rgba(47,158,111,.13); color:#268059; }
[data-theme="dark"] .tog.on.t-pet  { color:#bd97e8; }
[data-theme="dark"] .tog.on.t-wmf  { color:#5cc7df; }
[data-theme="dark"] .tog.on.t-fmcg { color:#6fd0a0; }

.filter-sel {
  font-family:'Inter', sans-serif; padding:7px 10px; border:1px solid var(--line-hi);
  border-radius:7px; font-size:12px; background:var(--surface-hi); color:var(--text);
  outline:none; cursor:pointer; min-width:120px;
}
.filter-sel:focus { border-color:var(--gold); }
.search-wrap { position:relative; width:100%; }
.search-wrap svg {
  position:absolute; left:11px; top:50%; transform:translateY(-50%);
  width:14px; height:14px; color:var(--text-dim); pointer-events:none;
}
.search-box {
  font-family:'Inter', sans-serif; padding:8px 12px 8px 33px; border:1px solid var(--line-hi);
  border-radius:7px; font-size:13px; width:100%; min-width:320px; outline:none;
  background:var(--surface-hi); color:var(--text);
}
.search-box:focus { border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-wash); }
.search-box::placeholder { color:var(--text-dim); }
.fg.grow { margin-left:auto; }

/* ════════ Mid row (combo card stacked over summary) ════════ */
.mid-row { display:flex; flex-direction:column; gap:14px; margin-bottom:18px; }
.mid-left { display:flex; flex-direction:column; gap:14px; min-width:0; }
.mid-left .panel { flex:0 0 auto; }
.panel { padding:16px; display:flex; flex-direction:column; }
.panel-h {
  font-family:'JetBrains Mono', monospace; font-size:10px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--text-dim); margin-bottom:15px;
  display:flex; align-items:center; gap:9px;
}
.panel-h::before { content:""; width:16px; height:2px; background:var(--gold-soft); border-radius:2px; }
.panel-h .ph-count {
  margin-left:auto; font-family:'JetBrains Mono', monospace; font-size:10px; font-weight:600;
  color:var(--gold); background:var(--gold-wash); padding:2px 8px; border-radius:999px; letter-spacing:0;
}

/* priority "expiring soon" list */
.pri-scroll { overflow:auto; max-height:188px; margin:0 -4px; padding:0 4px; }
.pri-row { display:flex; align-items:center; gap:11px; padding:7px 0; border-bottom:1px solid var(--line); }
.pri-row:last-child { border-bottom:none; }
.pri-dl {
  font-family:'JetBrains Mono', monospace; font-weight:600; font-size:12px;
  min-width:48px; text-align:right; flex-shrink:0; font-variant-numeric:tabular-nums;
}
.pri-body { min-width:0; flex:1; }
.pri-name {
  font-size:12px; color:var(--text); line-height:1.3;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.pri-sub {
  display:flex; align-items:center; gap:6px; margin-top:3px;
  font-family:'JetBrains Mono', monospace; font-size:10px; color:var(--text-mute);
}
.pri-empty {
  font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--s-safe);
  padding:24px 8px; text-align:center; line-height:1.5;
}

/* combined Expiry + Expiring-soon card — split left | right */
.panel.combo { flex-direction:row; gap:18px; align-items:stretch; padding:16px; }
.combo-half { display:flex; flex-direction:column; min-width:0; }
.combo-half.donut-half { flex:0 0 230px; }
.combo-half.grow { flex:1; min-width:0; }
.combo-vdiv { width:1px; background:var(--line); align-self:stretch; flex:0 0 1px; }
.panel.combo .pri-scroll { max-height:210px; }
@media (max-width:760px) {
  .panel.combo { flex-direction:column; }
  .combo-half.donut-half { flex:0 0 auto; }
  .combo-vdiv { width:auto; height:1px; }
}

/* UOM chips — color-coded so units read apart at a glance */
.uom {
  display:inline-block; padding:2px 8px; border-radius:5px;
  font-family:'JetBrains Mono', monospace; font-size:9.5px; font-weight:600; letter-spacing:.05em;
  background:var(--surface-2); color:var(--text-mute); border:1px solid var(--line);
}
.uom.u-ctn  { background:var(--gold-wash); color:var(--gold); border-color:transparent; }
.uom.u-pcs  { background:rgba(19,153,184,.13);  color:#0e7e98; border-color:transparent; }
.uom.u-pack { background:rgba(47,158,111,.13);  color:#268059; border-color:transparent; }
.uom.u-pkt  { background:rgba(47,158,111,.13);  color:#268059; border-color:transparent; }
.uom.u-box  { background:rgba(155,109,214,.13); color:#8a55d0; border-color:transparent; }
.uom.u-bag  { background:rgba(155,109,214,.13); color:#8a55d0; border-color:transparent; }
.uom.u-set  { background:rgba(214,120,60,.13);  color:#bd6a2e; border-color:transparent; }
[data-theme="dark"] .uom.u-pcs  { color:#5cc7df; }
[data-theme="dark"] .uom.u-pack { color:#6fd0a0; }
[data-theme="dark"] .uom.u-pkt  { color:#6fd0a0; }
[data-theme="dark"] .uom.u-box  { color:#bd97e8; }
[data-theme="dark"] .uom.u-bag  { color:#bd97e8; }
[data-theme="dark"] .uom.u-set  { color:#e0a071; }
.chart-wrap { position:relative; height:140px; }
.chart-center {
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; pointer-events:none;
}
.chart-center .cc-num { font-family:'Fraunces', serif; font-weight:600; font-size:25px; line-height:1; color:var(--text); }
.chart-center .cc-lbl { font-family:'JetBrains Mono', monospace; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--text-dim); margin-top:4px; }
.chart-legend { margin-top:11px; display:flex; flex-direction:column; gap:6px; }
.leg-item { display:flex; align-items:center; gap:9px; font-size:12px; }
.leg-dot { width:9px; height:9px; border-radius:3px; flex-shrink:0; }
.leg-item .lg-name { color:var(--text-mute); flex:1; }
.leg-item .lg-val { font-family:'JetBrains Mono', monospace; font-weight:600; color:var(--text); }
.leg-item .lg-pct { font-family:'JetBrains Mono', monospace; font-size:10px; color:var(--text-dim); width:38px; text-align:right; }

/* ════════ Tables ════════ */
.tbl-section { margin-bottom:22px; }
.tbl-hdr { display:flex; align-items:baseline; justify-content:space-between; gap:14px; margin-bottom:11px; }
.tbl-hdr h2 {
  font-family:'Fraunces', Georgia, serif; font-weight:500; font-size:20px;
  letter-spacing:-.01em; color:var(--text);
}
.tbl-hdr .hint { font-family:'JetBrains Mono', monospace; font-size:10px; color:var(--text-dim); letter-spacing:.04em; }
.rec-count { font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--text-mute); letter-spacing:.03em; }
.rec-count b { color:var(--gold); font-weight:600; }

.tbl-wrap {
  background:var(--surface); border:1px solid var(--line); border-radius:14px;
  box-shadow:var(--shadow); overflow:auto; max-height:620px;
}
table.t { width:100%; border-collapse:separate; border-spacing:0; font-size:12.5px; }
table.t.wide { min-width:1180px; }
table.t thead th {
  background:var(--ink-1); color:var(--ink-mute);
  font-family:'JetBrains Mono', monospace; font-weight:600; font-size:10px;
  letter-spacing:.07em; text-transform:uppercase;
  padding:11px 13px; text-align:left; white-space:nowrap;
  position:sticky; top:0; z-index:2; cursor:pointer; user-select:none;
  border-bottom:1px solid var(--ink-line-hi);
}
table.t thead th:first-child { border-top-left-radius:0; }
table.t thead th.num { text-align:right; }
table.t thead th:hover { background:var(--ink-2); color:var(--ink-text); }
table.t thead th.sorted { color:var(--ink-gold); }
table.t thead th .si { margin-left:4px; opacity:.35; font-size:9px; }
table.t thead th.sorted .si { opacity:1; }

table.t tbody td {
  padding:9px 13px; border-bottom:1px solid var(--line);
  white-space:nowrap; color:var(--text); vertical-align:middle;
}
table.t tbody tr:nth-child(even) td { background:var(--zebra); }
table.t tbody tr:hover td { background:var(--gold-wash); }
table.t tbody tr:last-child td { border-bottom:none; }
td.num { text-align:right; font-family:'JetBrains Mono', monospace; font-variant-numeric:tabular-nums; }
td.idx { color:var(--text-dim); font-family:'JetBrains Mono', monospace; font-size:10.5px; width:34px; }
td.code { font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--text-mute); }
td.name { white-space:normal; min-width:210px; max-width:320px; line-height:1.35; color:var(--text); font-weight:450; }
td.muted { color:var(--text-mute); }

/* row status accent on detail table */
table.t tbody tr.r-expired  td:first-child { box-shadow:inset 3px 0 0 var(--s-expired); }
table.t tbody tr.r-critical td:first-child { box-shadow:inset 3px 0 0 var(--s-critical); }
table.t tbody tr.r-warning  td:first-child { box-shadow:inset 3px 0 0 var(--s-warning); }
table.t tbody tr.r-safe     td:first-child { box-shadow:inset 3px 0 0 var(--s-safe); }
table.t tbody tr.r-unknown  td:first-child { box-shadow:inset 3px 0 0 var(--s-unknown); }

/* quantity bar cell — "what's left" at a glance */
.qcell { position:relative; display:flex; align-items:center; justify-content:flex-end; gap:0; }
.qbar {
  position:absolute; right:0; top:50%; transform:translateY(-50%);
  height:21px; border-radius:4px; background:var(--gold-wash);
  border:1px solid color-mix(in srgb, var(--gold) 18%, transparent);
  z-index:0;
}
.qval {
  position:relative; z-index:1; font-family:'JetBrains Mono', monospace;
  font-variant-numeric:tabular-nums; font-weight:600; padding:0 7px;
}
.qval.zero { color:var(--text-dim); font-weight:400; }

/* badges */
.badge {
  display:inline-block; padding:2px 8px; border-radius:5px;
  font-family:'JetBrains Mono', monospace; font-size:9.5px; font-weight:600; letter-spacing:.04em;
  white-space:nowrap;
}
.b-expired  { background:var(--s-expired-bg);  color:var(--s-expired); }
.b-critical { background:var(--s-critical-bg); color:var(--s-critical); }
.b-warning  { background:var(--s-warning-bg);  color:var(--s-warning); }
.b-safe     { background:var(--s-safe-bg);     color:var(--s-safe); }
.b-unknown  { background:var(--s-unknown-bg);  color:var(--s-unknown); }
.b-moola    { background:rgba(155,109,214,.14); color:#8a55d0; }
.b-vcan     { background:var(--gold-wash); color:var(--gold); }
.b-pet      { background:rgba(155,109,214,.13); color:#8a55d0; }
.b-wmf      { background:rgba(19,153,184,.13); color:#0e7e98; }
.b-fmcg     { background:rgba(47,158,111,.13); color:#268059; }
[data-theme="dark"] .b-moola { color:#bd97e8; } [data-theme="dark"] .b-pet { color:#bd97e8; }
[data-theme="dark"] .b-wmf { color:#5cc7df; } [data-theme="dark"] .b-fmcg { color:#6fd0a0; }

.d-expired  { color:var(--s-expired);  font-weight:600; }
.d-critical { color:var(--s-critical); font-weight:600; }
.d-warning  { color:var(--s-warning);  font-weight:600; }
.d-safe     { color:var(--s-safe); }
.d-unknown  { color:var(--text-dim); }

/* summary table */
.sum-scroll { overflow:auto; max-height:236px; border-radius:8px; }
table.sum { width:100%; border-collapse:separate; border-spacing:0; font-size:11.5px; }
table.sum th {
  background:var(--surface-2); color:var(--text-mute);
  font-family:'JetBrains Mono', monospace; font-weight:600; font-size:9.5px;
  letter-spacing:.05em; text-transform:uppercase;
  padding:8px 10px; text-align:left; white-space:nowrap;
  position:sticky; top:0; border-bottom:1px solid var(--line-hi); z-index:1;
}
table.sum th.num { text-align:right; }
table.sum td { padding:7px 10px; border-bottom:1px solid var(--line); white-space:nowrap; }
table.sum td.num { text-align:right; font-family:'JetBrains Mono', monospace; font-variant-numeric:tabular-nums; }
table.sum tbody tr:hover td { background:var(--gold-wash); }

.no-data { text-align:center; padding:54px; color:var(--text-dim); font-size:13px; font-family:'JetBrains Mono', monospace; }
.footer {
  text-align:center; padding:22px; font-family:'JetBrains Mono', monospace;
  font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--text-dim);
}
.footer b { color:var(--gold); font-weight:500; }

/* ════════ Responsive ════════ */
@media (max-width:1280px) {
  .kpiA, .kpiC { grid-template-columns:repeat(4, 1fr); }
  .kpiB { flex-wrap:wrap; }
  .kpiB .k { flex:1 1 25%; border-bottom:1px solid var(--line); }
  .mid-row { grid-template-columns:1fr; }
}
@media (max-width:760px) {
  .kpiA, .kpiC { grid-template-columns:repeat(2, 1fr); }
  .shell { padding:14px 16px 32px; }
  .masthead { flex-direction:column; align-items:flex-start; gap:14px; }
  .mh-right { align-self:stretch; flex-wrap:wrap; }
  .mh-reports { flex-wrap:wrap; }
  /* Make KPI values slightly smaller on tablet */
  .kpiA .k .kv, .kpiB .k .kv { font-size:26px; }
  /* Table overflow scroll on mobile */
  .tbl-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; }
}
@media (max-width:480px) {
  .kpiA, .kpiC { grid-template-columns:1fr 1fr; }
  .kpiB { flex-direction:column; }
  .kpiB .k { flex:none; border-left:none; border-bottom:1px solid var(--line); }
  /* Tap-friendly password modal inputs & buttons */
  .pw-box input { min-height:44px; }
  .pw-box button { min-height:44px; }
  /* Shrink chart wrap height on phone */
  .chart-wrap { height:200px; }
  .shell { padding:10px 12px 28px; }
  .masthead { padding:12px 14px; }
  .mh-titles h1 { font-size:20px; }
  .filter-bar { padding:12px 14px; }
  .filter-row { gap:14px 16px; }
}

/* ════════ Password modal ════════ */
dialog.pw-modal {
  position:fixed; top:50%; left:50%; transform:translate(-50%,-50%);
  border:none; border-radius:14px; padding:0; background:transparent; box-shadow:none;
  max-width:380px; width:90%;
}
dialog.pw-modal::backdrop { background:rgba(14,10,8,.92); backdrop-filter:blur(7px); }
.pw-box {
  background:var(--ink-1); border:1px solid var(--ink-line-hi); border-radius:14px; padding:36px;
  box-shadow:0 30px 70px -30px rgba(0,0,0,.85);
}
.pw-brand { font-family:'Fraunces', Georgia, serif; font-size:24px; font-weight:600; color:var(--ink-text); letter-spacing:-.02em; margin-bottom:5px; }
.pw-brand em { font-style:italic; color:var(--ink-gold); font-weight:400; }
.pw-sub { font-family:'JetBrains Mono', monospace; font-size:10px; color:var(--ink-gold-soft); margin-bottom:24px; text-transform:uppercase; letter-spacing:.12em; }
.pw-box input {
  width:100%; padding:11px 14px; border-radius:8px; border:1px solid var(--ink-line-hi);
  background:#0e0a08; color:#f4ecdd; font-family:'Inter', sans-serif; font-size:13px;
  outline:none; margin-bottom:12px;
}
.pw-box input:focus { border-color:var(--ink-gold); }
.pw-err { color:#f08a8a; font-family:'JetBrains Mono', monospace; font-size:10.5px; margin-bottom:10px; min-height:1.3em; }
.pw-box button {
  width:100%; padding:11px; border-radius:8px; border:none; background:var(--ink-gold);
  color:#2a1d08; font-family:'Inter', sans-serif; font-size:13px; font-weight:700; cursor:pointer;
  transition:background .15s;
}
.pw-box button:hover:not(:disabled) { background:var(--ink-gold-soft); }
.pw-box button:disabled { opacity:.5; cursor:not-allowed; }

/* ── Light-mode password modal ── */
[data-theme="light"] .pw-box {
  background:var(--surface-2); border-color:var(--line-hi);
  box-shadow:0 30px 70px -30px rgba(42,29,8,.22);
}
[data-theme="light"] .pw-brand { color:var(--text); }
[data-theme="light"] .pw-sub { color:var(--gold-soft); }
[data-theme="light"] .pw-box input {
  background:var(--surface); border-color:var(--line-hi); color:var(--text);
}
[data-theme="light"] .pw-box input::placeholder { color:var(--text-dim); }
[data-theme="light"] .pw-box input:focus { border-color:var(--gold); }
[data-theme="light"] .pw-box button { background:var(--gold-soft); color:#2a1d08; }
[data-theme="light"] .pw-box button:hover:not(:disabled) { background:var(--gold); color:#fff8ed; }
[data-theme="light"] .pw-err { color:#8c1c1c; }
