:root{
  --sage:#758d6e; --sage-d:#5f7459; --cream:#fdf7f0; --ink:#26312a;
  --line:#e3ddd2; --over:#b06a2c; --under:#a33; --ok:#2e7d4f; --rec:#c0392b;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--cream);color:var(--ink);-webkit-tap-highlight-color:transparent}
h1,h2{font-family:Oswald,Inter,sans-serif;font-weight:600;letter-spacing:.3px;margin:.2em 0}
.muted{color:#7a7468;font-size:.9rem}
.error{color:var(--under)} .ok{color:var(--ok)}
a{color:var(--sage-d)} .link{font-size:.9rem}

.card{max-width:620px;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:14px}
.login{display:flex;min-height:100svh;align-items:center;justify-content:center}
.login .card{align-items:center;text-align:center;max-width:560px}
.logo{border-radius:14px}

label{display:flex;flex-direction:column;gap:6px;font-size:.9rem;font-weight:600}
input,select,textarea{font-size:1.1rem;padding:13px;border:1px solid var(--line);
  border-radius:12px;background:#fff;width:100%;font-family:inherit}
button{font-size:1.05rem;font-weight:600;padding:14px 18px;border:0;border-radius:12px;
  background:var(--sage);color:#fff;cursor:pointer}
button:active{background:var(--sage-d)}
button:disabled{opacity:.5}
button.ghost,a.ghost{background:#fff;color:var(--sage-d);border:1px solid var(--line);
  text-decoration:none;display:inline-block;padding:12px 16px;border-radius:12px;text-align:center}
button.danger{background:var(--over)}
.gbtn{display:inline-flex;align-items:center;gap:10px;background:#fff;color:#3c4043;
  border:1px solid var(--line);border-radius:12px;padding:13px 20px;font-weight:600;
  text-decoration:none;font-size:1.05rem}
.gbtn:active{background:#f5f2ec}
.who{font-size:.85rem;color:#7a7468}

.topbar{max-width:620px;margin:0 auto;width:100%;display:flex;justify-content:space-between;
  align-items:center;padding:14px 20px;border-bottom:1px solid var(--line)}
.topbar .brand{display:flex;align-items:center;gap:10px;font-family:Oswald,Inter,sans-serif;
  font-weight:600;font-size:1.1rem}
.topbar img{width:30px;height:30px;border-radius:8px}

/* module launcher (home) */
.modules{display:grid;gap:12px}
.mod{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:16px 18px;text-decoration:none;color:var(--ink)}
.mod:active{background:#f7f3ec}
.mod .ic{font-size:1.6rem;width:40px;text-align:center}
.mod .t{font-family:Oswald,Inter,sans-serif;font-weight:600;font-size:1.15rem}
.mod.soon{opacity:.55;pointer-events:none}
.mod .tag{margin-left:auto;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;
  background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:3px 10px;color:#7a7468}

/* PO list */
.polist{display:grid;gap:10px}
.po{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:14px 16px;text-align:left;color:var(--ink);width:100%}
.po:active{background:#f7f3ec}
.po .no{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:700}
.po .sup{color:#7a7468;font-size:.9rem}
.po .chev{margin-left:auto;color:var(--sage-d);font-size:1.3rem}

/* receive lines */
.rline{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;
  display:grid;gap:8px;margin-top:10px}
.rline.hit{border-color:var(--sage);box-shadow:0 0 0 2px rgba(117,141,110,.15)}
.rline .prod{font-weight:600}
.rline .meta{font-size:.8rem;color:#7a7468}
.rline .grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.rline .grid.three{grid-template-columns:80px 1fr 1fr}
.rline input{font-size:1rem;padding:10px}
.trk{font-size:.7rem;text-transform:uppercase;letter-spacing:.4px;color:var(--over)}

/* create-PO search results */
.reslist{display:grid;gap:6px}
.reslist:not(:empty){margin:2px 0 6px}
.resitem{background:#fff;border:1px solid var(--line);border-radius:10px;padding:11px 14px;
  text-align:left;color:var(--ink);font-weight:500;font-size:.98rem}
.resitem:active{background:#f7f3ec}
.chosen:not(:empty){margin:4px 0}
.chip{display:inline-block;background:#eef2ea;border:1px solid var(--sage);color:var(--sage-d);
  border-radius:999px;padding:6px 14px;font-weight:600;font-size:.92rem}
.sugg{background:#fff;border:1px dashed var(--sage);border-radius:12px;padding:10px 12px;
  margin-top:10px;display:grid;gap:6px}
.sugg.miss{border-color:var(--line);border-style:solid}
.sugg-h{font-size:.85rem;color:#7a7468;font-weight:600}

/* voice button */
.voicebar{position:sticky;top:0;z-index:5;background:var(--cream);padding:12px 0;
  display:flex;gap:10px;align-items:center}
.voicebar .newpo{flex:0 0 auto;white-space:nowrap}
.mic{display:flex;align-items:center;justify-content:center;gap:10px;flex:1}
.mic.rec{background:var(--rec)}
.mic.rec::before{content:"";width:12px;height:12px;border-radius:50%;background:#fff;
  animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hint{font-size:.82rem;color:#7a7468;margin-top:2px}

/* QC footer */
.qc{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;
  display:grid;gap:12px;margin-top:16px}
.qc h2{margin:0}
.qc .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.seg{display:flex;gap:8px}
.seg button{flex:1;background:#fff;color:var(--ink);border:1px solid var(--line);padding:11px}
.seg button.on{background:var(--sage);color:#fff;border-color:var(--sage)}

.footerbar{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;padding:14px 0;gap:10px;margin-top:16px}
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:var(--ink);
  color:#fff;padding:12px 18px;border-radius:12px;font-size:.95rem;max-width:90vw;z-index:20}
.spinner{display:inline-block;width:16px;height:16px;border:2px solid #fff;border-top-color:transparent;
  border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}
.banner{background:#fff6e9;border:1px solid #e7cfa6;color:#7a5a20;border-radius:10px;
  padding:10px 12px;font-size:.85rem}

/* stock take */
.progress{height:8px;background:#e9e3d8;border-radius:999px;overflow:hidden;margin:6px 0}
.progress .bar{height:100%;background:var(--sage);transition:width .3s}
.rline.counted{border-color:var(--ok);box-shadow:0 0 0 2px rgba(46,125,79,.12)}
.rline.counted .prod{color:var(--ok)}
.multi{font-size:.82rem;color:#7a7468;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.multi .tog{padding:6px 10px;font-size:.8rem;background:#fff;color:var(--sage-d);border:1px solid var(--line)}
.rline .add{padding:10px;font-size:.95rem}
.lotpick{margin-top:8px;background:#fff6e9;border:1px solid #e7cfa6;border-radius:10px;padding:10px}
.lotpick label{font-size:.82rem}
.lotpick .newlot{margin-top:8px}
/* review table rows: 4 columns */
.srow{display:grid;grid-template-columns:1fr auto auto auto;gap:10px;align-items:center;
  border-bottom:1px solid var(--line);padding:10px 4px}
.srow.head{font-weight:700;font-size:.72rem;text-transform:uppercase;color:#7a7468}
.srow .rvp{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.srow.over span,.srow.over b{color:var(--over)}
.srow.under span,.srow.under b{color:var(--under)}
.srow .lotpick{grid-column:1/-1}

/* finished-products scanner + report */
#reader{width:100%;background:#000;min-height:240px;border-radius:12px;overflow:hidden}
.scanbar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:8px}
.tally{list-style:none;margin:0;padding:0 0 8px}
.code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.qty{display:flex;align-items:center;gap:12px}
.qty b{min-width:24px;text-align:center}
.step{width:40px;height:40px;padding:0;border-radius:10px;background:var(--cream);color:var(--ink);border:1px solid var(--line);font-size:1.3rem}
.frow{display:grid;grid-template-columns:1fr auto auto auto auto auto;gap:8px;align-items:center;
  border-bottom:1px solid var(--line);padding:9px 4px;font-size:.9rem}
.frow.head{font-weight:700;font-size:.66rem;text-transform:uppercase;color:#7a7468}
.frow .rvp{overflow:hidden;text-overflow:ellipsis;min-width:0}
