/* ============================================================================
   Maniac Merch Control Tower — design system. Flat, dense, ops-grade.
   Restrained palette: one accent (amber) + reserved status hues, always labelled.
   ============================================================================ */
:root{
  --bg:#0a0d12; --rail:#0d1117; --panel:#12161d; --panel2:#171c25; --raised:#1b212c;
  --line:rgba(255,255,255,.07); --line2:rgba(255,255,255,.12);
  --txt:#e9eef5; --txt2:#9aa6b4; --txt3:#6b7685;
  --acc:#e8b84b; --acc2:#f0c969; --accbg:rgba(232,184,75,.12);
  --pos:#36b37e; --posbg:rgba(54,179,126,.14);
  --neg:#f0616d; --negbg:rgba(240,97,109,.14);
  --warn:#e8b84b; --warnbg:rgba(232,184,75,.13);
  --pend:#8b7ff0; --pendbg:rgba(139,127,240,.15);
  --info:#48a0f0; --infobg:rgba(72,160,240,.14);
  --teal:#2dc4a7;
  --rad:10px; --rad2:13px;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --shadow:0 1px 0 rgba(255,255,255,.03) inset;
}
:root[data-theme="light"]{
  --bg:#f3f5f8; --rail:#fff; --panel:#fff; --panel2:#f6f8fa; --raised:#fff;
  --line:rgba(16,24,40,.09); --line2:rgba(16,24,40,.16);
  --txt:#16202c; --txt2:#5a6675; --txt3:#8a96a4;
  --acc:#b8860b; --acc2:#9c7200; --accbg:rgba(184,134,11,.10);
  --pos:#1f9d6b; --posbg:rgba(31,157,107,.12); --neg:#d6455a; --negbg:rgba(214,69,90,.10);
  --warn:#b8860b; --warnbg:rgba(184,134,11,.12); --pend:#6b5fd6; --pendbg:rgba(107,95,214,.12);
  --info:#2f7fd6; --infobg:rgba(47,127,214,.10); --teal:#199e85;
  --shadow:0 1px 2px rgba(16,24,40,.04);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--txt);font-family:var(--sans);
  font-size:13px;line-height:1.45;-webkit-font-smoothing:antialiased}
.tnum{font-variant-numeric:tabular-nums}

/* ---- app shell: left rail + main ----------------------------------------- */
#app{display:grid;grid-template-columns:236px 1fr;height:100vh;overflow:hidden}
.rail{background:var(--rail);border-right:1px solid var(--line);
  display:flex;flex-direction:column;height:100vh;overflow:hidden}
.rail .brand{display:flex;align-items:center;gap:11px;padding:18px 18px 14px}
.rail .logo{width:36px;height:36px;border-radius:9px;background:var(--acc);color:#15130b;
  display:grid;place-items:center;font-weight:800;font-size:18px;letter-spacing:-1px}
.rail .brand h1{font-size:14px;margin:0;font-weight:600;letter-spacing:-.2px}
.rail .brand .sub{font-size:11px;color:var(--txt3)}
.nav{padding:6px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1}
.nav .navh{font-size:10.5px;text-transform:uppercase;letter-spacing:.7px;color:var(--txt3);
  padding:14px 10px 5px}
.nav button{display:flex;align-items:center;gap:11px;width:100%;text-align:left;
  background:none;border:none;color:var(--txt2);padding:9px 11px;border-radius:9px;
  cursor:pointer;font-size:13px;font-family:inherit;position:relative}
.nav button .ic{width:18px;height:18px;flex:0 0 18px;opacity:.85;display:grid;place-items:center}
.nav button .ct{margin-left:auto;font-size:11px;color:var(--txt3);
  background:var(--panel2);border-radius:999px;padding:1px 7px;min-width:20px;text-align:center}
.nav button:hover{background:var(--panel2);color:var(--txt)}
.nav button.active{background:var(--accbg);color:var(--txt);font-weight:600}
.nav button.active .ic{opacity:1;color:var(--acc)}
.nav button.active::before{content:"";position:absolute;left:-10px;top:8px;bottom:8px;
  width:3px;border-radius:3px;background:var(--acc)}
.rail .railfoot{padding:12px;border-top:1px solid var(--line);display:flex;gap:8px;align-items:center}
.iconbtn{background:var(--panel2);border:1px solid var(--line);color:var(--txt2);
  width:32px;height:32px;border-radius:8px;cursor:pointer;display:grid;place-items:center}
.iconbtn:hover{color:var(--txt);border-color:var(--line2)}

/* ---- main + header ------------------------------------------------------- */
main{min-width:0;display:flex;flex-direction:column;height:100vh;overflow:hidden}
.header{flex:0 0 auto;z-index:20;background:var(--bg);
  border-bottom:1px solid var(--line);
  padding:13px 22px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.header .htitle{font-size:15px;font-weight:600;letter-spacing:-.2px}
.header .hsub{font-size:11.5px;color:var(--txt3);margin-top:1px}
.header .grow{flex:1}
.search{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);
  border-radius:9px;padding:7px 11px;min-width:210px}
.search input{background:none;border:none;outline:none;color:var(--txt);font-size:13px;
  font-family:inherit;width:100%}
.search .ic{color:var(--txt3);display:grid;place-items:center}
.vendorsel{position:relative}
.vendorsel>button{display:flex;align-items:center;gap:9px;background:var(--panel);
  border:1px solid var(--line);border-radius:9px;padding:7px 12px;color:var(--txt);
  cursor:pointer;font-size:13px;font-family:inherit}
.vendorsel>button .vlab{color:var(--txt2)}
.vendorsel>button b{font-weight:600}
.vmenu{position:absolute;right:0;top:42px;width:280px;max-height:60vh;overflow:auto;
  background:var(--raised);border:1px solid var(--line2);border-radius:12px;padding:7px;
  box-shadow:0 12px 40px rgba(0,0,0,.4);z-index:40;display:none}
.vmenu.open{display:block}
.vmenu input{width:100%;background:var(--panel2);border:1px solid var(--line);border-radius:8px;
  padding:7px 10px;color:var(--txt);font-size:12.5px;margin-bottom:6px;outline:none}
.vmenu button{display:flex;width:100%;justify-content:space-between;gap:8px;background:none;
  border:none;color:var(--txt2);padding:7px 9px;border-radius:7px;cursor:pointer;font-size:12.5px;
  font-family:inherit;text-align:left}
.vmenu button:hover{background:var(--panel2);color:var(--txt)}
.vmenu button.sel{background:var(--accbg);color:var(--txt)}
.vmenu button .vt{font-size:10px;color:var(--txt3)}

/* ---- content ------------------------------------------------------------- */
.content{padding:20px 22px 40px;max-width:1560px;width:100%;flex:1;overflow-y:auto;min-height:0}
.tab{display:none}.tab.active{display:block;animation:fade .18s ease}
@keyframes fade{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}

/* KPI tiles */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:13px;margin-bottom:18px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--rad2);
  padding:14px 16px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi .kl{font-size:11.5px;color:var(--txt2);display:flex;align-items:center;gap:7px}
.kpi .kl .ic{color:var(--txt3);display:grid;place-items:center;width:15px;height:15px;flex:0 0 15px}
.kpi .kl .ic svg{width:15px;height:15px;display:block}
.kpi .kv{font-size:27px;font-weight:650;margin-top:7px;letter-spacing:-.6px;line-height:1.05}
.kpi .ks{font-size:11.5px;color:var(--txt3);margin-top:4px}
.kpi .kv.pos{color:var(--pos)}.kpi .kv.neg{color:var(--neg)}.kpi .kv.pend{color:var(--pend)}
.kpi .kv.warn{color:var(--warn)}.kpi .kv.info{color:var(--info)}.kpi .kv.acc{color:var(--acc)}
.kpi .spark{position:absolute;right:0;bottom:0;opacity:.5}

/* panels + grids */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
.grid3{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:18px}
@media(max-width:1080px){.grid2,.grid3{grid-template-columns:1fr}}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--rad2);
  box-shadow:var(--shadow);overflow:hidden}
.panel>.ph{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line)}
.panel>.ph h3{font-size:13px;font-weight:600;margin:0}
.panel>.ph .pmeta{margin-left:auto;font-size:11px;color:var(--txt3)}
.panel>.pb{padding:14px 16px}
h2.sec{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--txt3);
  margin:22px 0 11px;font-weight:600}

/* action queue */
.acts{display:flex;flex-direction:column}
.act{display:flex;align-items:center;gap:13px;padding:12px 16px;border-bottom:1px solid var(--line);
  cursor:pointer;transition:background .12s}
.act:last-child{border-bottom:none}
.act:hover{background:var(--panel2)}
.act .adot{width:9px;height:9px;border-radius:50%;flex:0 0 9px}
.act .atxt{flex:1;min-width:0}
.act .att{font-size:13px;font-weight:550}
.act .asub{font-size:11.5px;color:var(--txt3);margin-top:1px}
.act .aval{font-size:14px;font-weight:650;font-variant-numeric:tabular-nums;text-align:right}
.act .ago{color:var(--txt3);display:grid;place-items:center}

/* pills + inline bars */
.pill{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:999px;
  font-size:11px;font-weight:600;white-space:nowrap}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.9}
.pill.pos{background:var(--posbg);color:var(--pos)}
.pill.neg{background:var(--negbg);color:var(--neg)}
.pill.warn{background:var(--warnbg);color:var(--warn)}
.pill.pend{background:var(--pendbg);color:var(--pend)}
.pill.info{background:var(--infobg);color:var(--info)}
.pill.mut{background:var(--panel2);color:var(--txt3)}
.pill.np::before{display:none}
.cellbar{display:flex;align-items:center;gap:8px;justify-content:flex-end}
.cellbar .bw{height:6px;border-radius:3px;background:var(--accbg);overflow:hidden;width:64px}
.cellbar .bf{height:100%;border-radius:3px;background:var(--acc)}
.cellbar .bf.pend{background:var(--pend)}.cellbar .bf.neg{background:var(--neg)}

/* data table */
.dtwrap{border:1px solid var(--line);border-radius:var(--rad2);overflow:hidden;background:var(--panel)}
.dttool{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--line)}
.dttool .dsearch{display:flex;align-items:center;gap:7px;background:var(--panel2);
  border:1px solid var(--line);border-radius:8px;padding:6px 10px;min-width:180px}
.dttool .dsearch input{background:none;border:none;outline:none;color:var(--txt);
  font-size:12.5px;font-family:inherit;width:100%}
.dttool .rc{font-size:11.5px;color:var(--txt3)}
.dttool .dl{margin-left:auto;background:var(--panel2);border:1px solid var(--line);color:var(--txt2);
  border-radius:8px;padding:6px 11px;cursor:pointer;font-size:12px;display:flex;gap:6px;align-items:center}
.dttool .dl:hover{color:var(--txt);border-color:var(--line2)}
.dtscroll{max-height:600px;overflow:auto}
table.dt{width:100%;border-collapse:separate;border-spacing:0;font-size:12.5px}
table.dt th,table.dt td{padding:9px 13px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
table.dt th{background:var(--panel2);color:var(--txt2);font-weight:600;position:sticky;top:0;z-index:2;
  cursor:pointer;user-select:none;font-size:11.5px}
table.dt th:hover{color:var(--txt)}
table.dt th.num,table.dt td.num{text-align:right;font-variant-numeric:tabular-nums}
table.dt td{color:var(--txt)}
table.dt tbody tr:hover td{background:var(--panel2)}
table.dt tbody tr:last-child td{border-bottom:none}
.mut{color:var(--txt3)}
.note{color:var(--txt2);font-size:12px;background:var(--panel);border:1px solid var(--line);
  border-left:3px solid var(--acc);padding:10px 13px;border-radius:8px;margin:0 0 16px}
.note b{color:var(--txt)}
.booterr{margin:24px;padding:16px;border:1px solid var(--neg);border-radius:10px;color:var(--neg);background:var(--negbg)}

/* login gate */
.authgate{position:fixed;inset:0;z-index:100;background:var(--bg);display:grid;place-items:center;padding:20px}
.authcard{width:340px;max-width:92vw;background:var(--panel);border:1px solid var(--line);
  border-radius:16px;padding:30px 26px;display:flex;flex-direction:column;gap:13px;box-shadow:0 20px 60px rgba(0,0,0,.45)}
.authcard .authlogo{width:46px;height:46px;border-radius:11px;background:var(--acc);color:#15130b;
  display:grid;place-items:center;font-weight:800;font-size:23px;letter-spacing:-1px;margin:0 auto 2px}
.authcard h2{margin:0;text-align:center;font-size:18px;font-weight:650}
.authcard .authsub{margin:0 0 6px;text-align:center;color:var(--txt3);font-size:12.5px}
.authcard label{display:flex;flex-direction:column;gap:5px;font-size:11.5px;color:var(--txt2)}
.authcard input{background:var(--panel2);border:1px solid var(--line);border-radius:9px;
  padding:10px 12px;color:var(--txt);font-size:14px;font-family:inherit;outline:none}
.authcard input:focus{border-color:var(--acc)}
.authcard button{margin-top:6px;background:var(--acc);color:#15130b;border:none;border-radius:9px;
  padding:11px;font-size:14px;font-weight:650;cursor:pointer;font-family:inherit}
.authcard button:hover{background:var(--acc2)}
.authcard button:disabled{opacity:.6;cursor:default}
.autherr{color:var(--neg);font-size:12px;text-align:center;min-height:14px}
.railfoot .mut{line-height:1.3;overflow:hidden;text-overflow:ellipsis;max-width:150px}

/* QC scan station */
.qcmsg{max-width:460px;margin:14vh auto;padding:24px;text-align:center;color:var(--txt2);
  background:var(--panel);border:1px solid var(--line);border-radius:14px;line-height:1.6}
.qcwrap{max-width:560px;margin:0 auto;padding:14px 14px 60px;min-height:100vh}
.qchead{display:flex;align-items:center;justify-content:space-between;padding:6px 2px 14px}
.qctitle{font-size:17px;font-weight:650}.qcsub{font-size:12px;color:var(--txt3)}
.qcheadbtns{display:flex;gap:8px}
.qcicon{width:38px;height:38px;border-radius:10px;background:var(--panel2);border:1px solid var(--line);
  color:var(--txt2);display:grid;place-items:center;cursor:pointer;text-decoration:none}
.qcicon svg{width:18px;height:18px}.qcicon:hover{color:var(--txt)}
.qcscanbar{display:flex;gap:8px;margin-bottom:10px}
.qcinput{flex:1;display:flex;align-items:center;gap:8px;background:var(--panel);border:2px solid var(--acc);
  border-radius:12px;padding:12px 14px}
.qcinput .qcic{color:var(--txt3);width:18px;height:18px;display:grid;place-items:center}
.qcinput .qcic svg{width:18px;height:18px}
.qcinput input{flex:1;background:none;border:none;outline:none;color:var(--txt);font-size:16px;font-family:inherit}
.qccam{margin-bottom:10px;border-radius:12px;overflow:hidden;background:#000}
.qccam video{width:100%;max-height:240px;object-fit:cover;display:block}
.qcbtn{border:none;border-radius:11px;padding:13px;font-size:15px;font-weight:650;cursor:pointer;font-family:inherit;color:#fff}
.qcbtn.ghost{background:var(--panel2);border:1px solid var(--line);color:var(--txt2);padding:13px 16px}
.qcbtn.pass{background:var(--pos)}.qcbtn.rework{background:var(--warn);color:#1b1405}.qcbtn.reject{background:var(--neg)}
.qcbtn:disabled{opacity:.5}
.qccard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:14px}
.qccard.ok{border-color:var(--pos);background:var(--posbg)}
.qccard.bad{border-color:var(--neg);background:var(--negbg)}
.qcartrow{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.qcpo{font-size:17px;font-weight:650}
.qcsize{font-size:15px;font-weight:700;background:var(--accbg);color:var(--acc);padding:4px 12px;border-radius:9px}
.qccov{font-size:12.5px;color:var(--txt2);margin:12px 0;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.qcbar{flex:1;min-width:80px;height:7px;border-radius:4px;background:var(--panel2);overflow:hidden}
.qcbar span{display:block;height:100%;background:var(--acc);border-radius:4px}
.qcform{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:6px 0 4px}
.qcform label{display:flex;flex-direction:column;gap:5px;font-size:11.5px;color:var(--txt2)}
.qcform label.qcfull{grid-column:1/3}
.qcform input,.qcform select{background:var(--panel2);border:1px solid var(--line);border-radius:9px;
  padding:11px 12px;color:var(--txt);font-size:16px;font-family:inherit;outline:none}
.qcform input:focus,.qcform select:focus{border-color:var(--acc)}
.qcnote{font-size:11.5px;color:var(--txt3);margin:8px 0 12px}
.qcactions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.qclogh{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--txt3);margin:18px 0 8px;display:flex;gap:8px;align-items:center}
.qctag{background:var(--panel2);color:var(--txt2);border-radius:999px;padding:1px 9px;font-size:11px}
.qclog{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.qclogrow{display:grid;grid-template-columns:14px 1fr auto auto;gap:10px;align-items:center;padding:10px 13px;border-bottom:1px solid var(--line);font-size:12.5px}
.qclogrow:last-child{border-bottom:none}
.qcdot{width:9px;height:9px;border-radius:50%}
.qcdot.pass{background:var(--pos)}.qcdot.rework{background:var(--warn)}.qcdot.reject{background:var(--neg)}
/* QC wizard */
.wsteps{display:flex;gap:6px;margin:4px 0 14px}
.wstep{flex:1;display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--txt3);background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:8px 9px;white-space:nowrap;overflow:hidden}
.wstep .wn{width:18px;height:18px;border-radius:50%;background:var(--panel2);display:grid;place-items:center;font-size:11px;flex:0 0 18px}
.wstep.cur{border-color:var(--acc);color:var(--txt)}.wstep.cur .wn{background:var(--acc);color:#15130b;font-weight:700}
.wstep.done{color:var(--txt2)}.wstep.done .wn{background:var(--posbg);color:var(--pos)}
.wctx{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}
.wctx button{background:var(--panel2);border:1px solid var(--line);color:var(--txt2);border-radius:999px;padding:5px 11px;font-size:12px;cursor:pointer;font-family:inherit}
.wctx button b{color:var(--txt)}
.wlabel{font-size:12px;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px;margin:6px 0 10px}
.wlabel2{font-size:12px;color:var(--txt2);font-weight:600;margin-bottom:8px}
.wlist{display:flex;flex-direction:column;gap:8px}
.wlist.wsizes{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}
.wopt{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:14px 15px;color:var(--txt);font-size:15px;cursor:pointer;font-family:inherit;text-align:left}
.wopt:hover{border-color:var(--acc)}.wopt b{font-weight:650}.wopt .mut{font-size:12px}
.wsizes .wopt{flex-direction:column;align-items:flex-start;gap:2px;padding:12px}
.mtable{width:100%;border-collapse:collapse;font-size:13px}
.mtable td{padding:8px 6px;border-bottom:1px solid var(--line);vertical-align:middle}
.mtable td:first-child{font-weight:550}
.mvin{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:9px 10px;color:var(--txt);font-size:16px;font-family:inherit;outline:none;width:84px}
.mvin:focus{border-color:var(--acc)}
.mverdict{font-size:12px;font-weight:700;text-align:right;width:54px}
.mverdict.ok{color:var(--pos)}.mverdict.bad{color:var(--neg)}
.scanok{font-size:12.5px;margin-top:8px;padding:9px 11px;border-radius:9px;background:var(--posbg);color:var(--pos)}
.scanok.warn{background:var(--warnbg);color:var(--warn)}

/* feedback widget */
.fbfab{position:fixed;right:20px;bottom:20px;z-index:90;width:50px;height:50px;border-radius:50%;
  background:var(--acc);color:#15130b;border:none;cursor:pointer;display:grid;place-items:center;
  box-shadow:0 6px 20px rgba(0,0,0,.35)}
.fbfab svg{width:23px;height:23px}.fbfab:hover{background:var(--acc2)}
.fbmodal{position:fixed;inset:0;z-index:110;background:rgba(0,0,0,.5);display:none;align-items:flex-end;justify-content:center;padding:0}
.fbmodal.open{display:flex}
@media(min-width:640px){.fbmodal{align-items:center;padding:20px}}
.fbcard{width:100%;max-width:460px;background:var(--panel);border:1px solid var(--line2);
  border-radius:16px 16px 0 0;padding:18px 18px 20px}
@media(min-width:640px){.fbcard{border-radius:16px}}
.fbhead{display:flex;align-items:center;justify-content:space-between;font-size:15px}
.fbx{background:none;border:none;color:var(--txt3);font-size:17px;cursor:pointer}
.fbsub{font-size:12.5px;color:var(--txt3);margin:6px 0 12px}
.fbsel{width:100%;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:10px 11px;color:var(--txt);font-size:14px;font-family:inherit;margin-bottom:9px;outline:none}
.fbta{width:100%;min-height:96px;resize:vertical;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:11px;color:var(--txt);font-size:15px;font-family:inherit;outline:none}
.fbta:focus,.fbsel:focus{border-color:var(--acc)}
.fbactions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}
.fbactions .mut{font-size:11px}
.fbsend{background:var(--acc);color:#15130b;border:none;border-radius:9px;padding:10px 22px;font-size:14px;font-weight:650;cursor:pointer;font-family:inherit}
.fbsend:disabled{opacity:.6}
.fbdone{font-size:12.5px;color:var(--pos);margin-top:9px;min-height:14px;text-align:right}

/* sample follow-up */
.srow{display:flex;align-items:center;justify-content:space-between;margin:18px 0 12px}
.sgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.scard{background:var(--panel);border:1px solid var(--line);border-radius:13px;overflow:hidden;box-shadow:var(--shadow)}
.simg{aspect-ratio:4/3;background:var(--panel2);display:grid;place-items:center;overflow:hidden}
.simg img{width:100%;height:100%;object-fit:cover;cursor:zoom-in;display:block}
.snoimg{color:var(--txt3)}.snoimg svg{width:34px;height:34px}
.sbody{padding:12px 13px}
.srowtop{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:3px}
.srowtop b{font-size:14px}
.smeta{font-size:12px;color:var(--txt2)}
.smeta2{display:flex;justify-content:space-between;font-size:12px;color:var(--txt3);margin-top:4px}
.sage{color:var(--neg);font-weight:600}
.snote{font-size:11.5px;color:var(--txt3);margin-top:6px;border-top:1px solid var(--line);padding-top:6px}
.sactions{display:flex;flex-wrap:wrap;gap:5px;margin-top:9px}
.schip{background:var(--panel2);border:1px solid var(--line);color:var(--txt2);border-radius:7px;padding:4px 9px;font-size:11px;cursor:pointer;font-family:inherit}
.schip:hover{color:var(--txt);border-color:var(--line2)}.schip.ed{margin-left:auto}
.sform{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sform label{display:flex;flex-direction:column;gap:5px;font-size:11.5px;color:var(--txt2)}
.sform label.sfull{grid-column:1/3}
.sform input,.sform select{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:10px 11px;color:var(--txt);font-size:14px;font-family:inherit;outline:none}
.sform input:focus,.sform select:focus{border-color:var(--acc)}
.scur{grid-column:1/3;font-size:11.5px;color:var(--txt3);margin-top:-4px}

/* sticker sheet (print) */
.stkbar{display:flex;gap:10px;align-items:center;padding:14px;flex-wrap:wrap}
.stkbar input{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:8px 11px;color:var(--txt);font-size:13px;outline:none;min-width:200px}
.stkgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:10px;padding:0 14px 30px}
.stk{border:1px solid #d0d0d0;border-radius:8px;padding:10px;background:#fff;color:#000}
.stk .stkpo{font-size:12px;font-weight:700}
.stk .stkmeta{font-size:10.5px;color:#333;margin:1px 0 6px}
.stk .stksize{float:right;font-size:13px;font-weight:800}
.stk svg{width:100%;height:54px}
.stk .stkcode{font-size:9px;color:#444;word-break:break-all;margin-top:3px}
@media print{ .stkbar,.noprint{display:none!important} body{background:#fff} .stkgrid{padding:0} .stk{break-inside:avoid} }

/* vendor portal */
.vppick{display:flex;align-items:center;gap:9px;margin:2px 0 10px}
.vppick select{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:9px 11px;color:var(--txt);font-size:14px;font-family:inherit}
.vpname{font-size:15px;font-weight:650;margin:4px 2px 12px}
.vpcard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:15px;margin-bottom:12px}
.vpcardtop{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.vpstage{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:var(--accbg);color:var(--acc);padding:3px 10px;border-radius:8px}
.vppend{font-size:12px;font-weight:650;color:var(--pend)}
.vplot{font-size:16px;font-weight:650}
.vpmeta{font-size:12px;color:var(--txt3);margin:3px 0 12px}
.vpform{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.vpform label{display:flex;flex-direction:column;gap:5px;font-size:11.5px;color:var(--txt2)}
.vpform label.vpfull{grid-column:1/3}
.vpform input,.vpform select{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:11px 12px;color:var(--txt);font-size:16px;font-family:inherit;outline:none}
.vpform input:focus,.vpform select:focus{border-color:var(--acc)}
.vpactions{display:flex;align-items:center;gap:12px;margin-top:12px}
.vpactions .qcbtn{flex:0 0 auto;padding:12px 22px}
.vpsaved{font-size:11.5px;color:var(--pos)}
.legend{display:flex;flex-wrap:wrap;gap:14px;font-size:11.5px;color:var(--txt2);margin-top:4px}
.legend span{display:flex;align-items:center;gap:6px}
.legend i{width:9px;height:9px;border-radius:2px;display:inline-block}

/* responsive: collapse rail to top bar */
@media(max-width:860px){
  #app{grid-template-columns:1fr;height:auto;overflow:visible}
  main{height:auto;overflow:visible}
  .content{overflow:visible}
  .rail{height:auto;flex-direction:row;align-items:center;overflow-x:auto;
    border-right:none;border-bottom:1px solid var(--line)}
  .rail .brand{padding:12px 14px}.rail .brand .sub{display:none}
  .nav{flex-direction:row;padding:8px;gap:4px}.nav .navh{display:none}
  .nav button{white-space:nowrap}.nav button .ct{display:none}
  .rail .railfoot{border-top:none;border-left:1px solid var(--line)}
  .header{padding:11px 14px}.content{padding:16px 14px 36px}
}
