:root{
  --bg:#f4f5f7; --surface:#fff; --surface-2:#f9fafb;
  --border:#e6e8ec; --border-2:#eef0f3;
  --ink:#1f2430; --ink-2:#3a4150; --muted:#6b7280; --muted-2:#9aa1ac;
  --accent:#fb6a00; --accent-ink:#c85400; --accent-soft:#fff3ea;
  --green:#15925a; --green-s:#e8f6ee; --amber:#c77700; --amber-s:#fbf1e0;
  --red:#d33a2c; --red-s:#fcecea; --blue:#2563eb; --blue-s:#eaf1fe;
  --purple:#7c3aed; --purple-s:#f2ecfd; --indigo:#4f46e5; --indigo-s:#ececfb;
  --sh:0 1px 2px rgba(16,24,40,.04),0 1px 3px rgba(16,24,40,.06);
  --sh-md:0 4px 12px rgba(16,24,40,.08);
  --side-w:236px; --top-h:56px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Microsoft YaHei",system-ui,sans-serif;
  background:var(--bg);color:var(--ink);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
#app{display:flex;flex-direction:column;height:100vh;overflow:hidden}

/* ───────── 顶栏：品牌 + 店铺胶囊 + 工具 ───────── */
.topbar{height:var(--top-h);flex:0 0 var(--top-h);display:flex;align-items:center;gap:12px;
  padding:0 16px;background:var(--surface);border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:9px;flex:0 0 auto}
.logo{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#fb6a00,#ff8a33);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:17px;box-shadow:0 3px 8px rgba(251,106,0,.28)}
.brand-t{font-size:14px;font-weight:700;letter-spacing:-.2px;white-space:nowrap}
.alltoday{flex:0 0 auto;display:flex;flex-direction:column;justify-content:center;line-height:1.15;padding:0 12px;
  border-left:1px solid var(--border-2);white-space:nowrap}
.alltoday small{font-size:10.5px;color:var(--muted-2)}
.alltoday b{font-size:18px;font-weight:800;color:var(--accent-ink);letter-spacing:-.3px}
.spill .tday{font-size:10.5px;color:var(--green);font-weight:700}
.spill.stale{opacity:.6}
.spill .staleflag{font-size:9.5px;background:#fdecec;color:var(--red);border-radius:4px;padding:0 4px;font-weight:700}
.stores{flex:1;display:flex;align-items:center;gap:5px;overflow-x:auto;min-width:0;height:100%;
  padding:0 6px;margin:0 2px;border-left:1px solid var(--border-2);border-right:1px solid var(--border-2)}
.stores::-webkit-scrollbar{height:3px}.stores::-webkit-scrollbar-thumb{background:#dfe2e7;border-radius:3px}
.spill{display:inline-flex;align-items:center;gap:7px;padding:6px 11px;border-radius:8px;cursor:pointer;white-space:nowrap;
  font-weight:600;color:var(--ink-2);border:1px solid transparent;font-size:12.5px;transition:.12s}
.spill:hover{background:var(--surface-2)}
.spill.on{background:var(--accent-soft);color:var(--accent-ink);border-color:#ffd9bb}
.spill .ct{font-size:11px;color:var(--muted-2);font-weight:700;background:var(--surface-2);border-radius:10px;padding:0 6px}
.spill.on .ct{color:var(--accent-ink);background:#fff}
.spill .fr{font-size:10.5px;color:var(--accent)}
.tb-right{flex:0 0 auto;display:flex;align-items:center;gap:8px}
.srch{position:relative}
.srch input{width:180px;padding:7px 11px 7px 30px;border:1px solid var(--border);border-radius:8px;font-size:12.5px;
  background:var(--surface-2);outline:none;transition:.15s}
.srch input:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-soft)}
.srch::before{content:"🔍";position:absolute;left:9px;top:50%;transform:translateY(-50%);font-size:12px;opacity:.5}
.btn{border:1px solid var(--border);background:var(--surface);color:var(--ink-2);border-radius:8px;padding:7px 12px;
  font-weight:600;cursor:pointer;font-size:12.5px;transition:.12s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.btn:hover{background:var(--surface-2);border-color:#d5d9e0}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-ink);border-color:var(--accent-ink)}
.btn:disabled{opacity:.5;cursor:default}
select.btn{padding-right:8px}

/* 内容区：整页滚动。KPI/决策条随滚动移出，表格列头吸顶 → 数据区最大化 */
.content{flex:1;overflow:auto;padding:12px 16px}

/* ───────── KPI 条（紧凑，可随页滚走） ───────── */
.kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:10px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:12px 14px;box-shadow:var(--sh)}
.kpi small{font-size:11.5px;color:var(--muted);display:block;font-weight:600}
.kpi b{font-size:22px;font-weight:800;display:block;margin-top:2px;letter-spacing:-.5px;line-height:1.15}
.kpi .d{font-size:11px;color:var(--muted-2);margin-top:1px}
.kpi.g b{color:var(--green)} .kpi.a b{color:var(--amber)} .kpi.r b{color:var(--red)} .kpi.t b{color:var(--accent-ink)}

/* ───────── 决策筛选芯片条 ───────── */
.opsbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px;padding:9px 13px;
  background:var(--surface);border:1px solid var(--border);border-radius:11px;box-shadow:var(--sh)}
.opsbar .lb{font-size:11.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-right:2px}
.ochip{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border-radius:8px;cursor:pointer;
  font-size:12.5px;font-weight:600;border:1px solid transparent;transition:.12s;background:var(--surface-2);color:var(--ink-2)}
.ochip:hover{border-color:#d5d9e0}
.ochip .n{font-weight:800;font-variant-numeric:tabular-nums}
.ochip.on{outline:2px solid currentColor;outline-offset:-1px}
.ochip.hot{background:var(--accent-soft);color:var(--accent-ink)}
.ochip.afs{background:var(--amber-s);color:var(--amber)}
.ochip.rest{background:var(--blue-s);color:var(--blue)}
.ochip.sold{background:var(--red-s);color:var(--red)}
.ochip.qual{background:var(--purple-s);color:var(--purple)}
.ochip.drop{background:var(--indigo-s);color:var(--indigo)}
.ochip.dead{background:#eef0f3;color:#5b6472}
.ochip.flux{background:var(--green-s);color:var(--green)}
.ochip.clear{margin-left:auto;color:var(--muted)}

/* ───────── 数据表卡片（列头随页滚动吸顶） ───────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--sh)}
.card-h{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 16px;border-bottom:1px solid var(--border-2)}
.card-h h2{font-size:14px;font-weight:700;margin:0}
.card-h .sub{font-size:12px;color:var(--muted-2)}
.card-tools{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.card-tools .cnt{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}
.card-tools label{display:flex;align-items:center;gap:5px;cursor:pointer;user-select:none;font-size:12.5px;color:var(--ink-2);font-weight:600}

.gridwrap{overflow:visible}
table.grid{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}
.grid th,.grid td{padding:3px 7px;text-align:center;white-space:nowrap;border-bottom:1px solid var(--border-2)}
.grid th{vertical-align:middle}
.grid td{vertical-align:top}
.grid tbody td{line-height:1.28}
.grid td.left,.grid th.left{text-align:left}
.grid td.code{text-align:center;font-weight:600}
.grid thead th{background:var(--surface-2);color:var(--muted);font-weight:600;text-align:center;position:sticky;top:0;z-index:3;
  border-bottom:1px solid var(--border);font-size:12px}
.grid thead tr.g2 th{top:24px;font-size:11.5px;color:var(--muted-2);font-weight:600}
.grid thead th:not(:last-child){border-right:1px solid var(--border-2)}
.grid td:not(:last-child){border-right:1px solid var(--border-2)}
.grid td.left,.grid th.left{text-align:left}
.grid td.center,.grid th.center{text-align:center}
.grid tbody tr:hover td{background:#fcfcfd}
.grid tr.prodtop td{border-top:1px solid var(--border)}
.grid tr.total td{background:var(--surface-2);font-weight:700;color:var(--ink-2)}
.grid tbody td{font-variant-numeric:tabular-nums}

.pic{width:72px;height:72px;object-fit:cover;border-radius:8px;background:#eef0f3;display:block}
/* 商品信息列：窄栏 + 竖排（货号→SPU→类目→名字） */
.grid td.pinfo,.grid th.pinfo{max-width:150px;width:150px;white-space:normal;line-height:1.32}
.i-skc{font-weight:800;color:var(--ink);font-size:13px}
.i-spu{color:var(--muted-2);font-size:11.5px}
.i-cat{color:var(--muted);font-size:11.5px}
.i-name{color:var(--ink-2);font-size:12px;line-height:1.28;margin-top:1px;
  overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.meta{color:var(--muted-2);font-size:11px}
.price{color:var(--red);font-weight:800;font-size:12.5px}
.hi{color:var(--red);font-weight:800}

.tg{display:inline-block;border-radius:4px;padding:0 5px;font-size:10px;font-weight:700;margin-left:3px;vertical-align:middle}
.tg-hot{background:var(--accent-soft);color:var(--accent-ink)}
.tg-ad{background:var(--blue-s);color:var(--blue)}
.tg-flaw{background:var(--amber-s);color:var(--amber)}
.tg-lack{background:var(--red-s);color:var(--red)}
.tg-ill{background:var(--purple-s);color:var(--purple)}

.qtag{display:inline-block;border-radius:6px;padding:2px 8px;font-weight:800;color:#fff;min-width:34px;text-align:center;font-size:12px}
.stockpill{display:inline-block;min-width:30px;border-radius:5px;padding:1px 7px;font-weight:700;color:#fff;text-align:center;font-size:12px}
.rest{color:var(--amber);font-weight:800}.enough{color:var(--green);font-weight:600}.sell{color:var(--red);font-weight:800}
.up{color:var(--green);font-weight:700;font-size:11px}.down{color:var(--red);font-weight:700;font-size:11px}

.act-tag{display:inline-block;border-radius:6px;padding:3px 9px;font-weight:700;font-size:11.5px;white-space:nowrap}
.act-hot{background:var(--accent-soft);color:var(--accent-ink)}
.act-rest{background:var(--blue-s);color:var(--blue)}
.act-sold{background:var(--red-s);color:var(--red)}
.act-afs{background:var(--amber-s);color:var(--amber)}
.act-qual{background:var(--purple-s);color:var(--purple)}
.act-drop{background:var(--indigo-s);color:var(--indigo)}
.act-dead{background:#eef0f3;color:#5b6472}
.act-flux{background:var(--green-s);color:var(--green)}
.act-ok{background:#f1f3f5;color:#8a929e}

.pager{display:flex;gap:12px;align-items:center;justify-content:flex-end;padding:10px 16px;font-size:12.5px;color:var(--muted);border-top:1px solid var(--border-2);flex:0 0 auto}
.pager button{padding:6px 13px;border:1px solid var(--border);border-radius:7px;background:var(--surface);cursor:pointer;font-weight:600;color:var(--ink-2)}
.pager button:hover:not(:disabled){background:var(--surface-2)}
.pager button:disabled{opacity:.4;cursor:default}

.loading{padding:80px;text-align:center;color:var(--muted-2);font-size:14px}
.empty{padding:60px;text-align:center;color:var(--muted-2)}

/* 窄屏 */
@media(max-width:820px){
  .topbar{flex-wrap:wrap;height:auto;padding:8px 12px;gap:8px}
  .brand{order:1}.tb-right{order:2;margin-left:auto}
  .stores{order:3;width:100%;flex-basis:100%;border-left:none;border-right:none;padding:0}
  .srch input{width:130px}
  .kpis{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}
}
