:root{
  --sage:#758d6e; --sage-d:#5f7459; --cream:#fdf7f0; --ink:#26312a;
  --line:#e3ddd2; --over:#b06a2c; --under:#a33; --ok:#2e7d4f;
}
*{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:560px;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}
.logo{border-radius:14px}

label{display:flex;flex-direction:column;gap:6px;font-size:.9rem;font-weight:600}
input,select{font-size:1.1rem;padding:13px;border:1px solid var(--line);border-radius:12px;
  background:#fff;width:100%}
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.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:560px;margin:0 auto;width:100%;display:flex;justify-content:space-between;
  align-items:center;padding:14px 20px;border-bottom:1px solid var(--line)}

/* scanner */
#reader{width:100%;background:#000;min-height:280px}
.scanbar{max-width:560px;margin:0 auto;width:100%;display:flex;justify-content:space-between;
  align-items:center;padding:10px 16px;gap:10px}
.pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 14px;
  font-size:.95rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pill.open{color:var(--sage-d)} .pill.finalized{color:var(--over)} .pill.pushed{color:var(--ok)}
.tally{list-style:none;margin:0 auto;padding:0 12px 96px;max-width:560px}
.tally li{display:flex;justify-content:space-between;align-items:center;
  background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 14px;margin-top:8px}
.code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.95rem}
.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}
.footerbar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;padding:12px 16px;gap:10px}
.actions{display:flex;gap:10px;align-items:center}

/* admin review */
.admin .card{max-width:840px}
.srow{display:flex;justify-content:space-between;align-items:center;gap:10px;
  border-bottom:1px solid var(--line);padding:10px 4px}
.srow.head{font-weight:700;font-size:.8rem;text-transform:uppercase;color:#7a7468}
.srow.over b,.srow.over span{color:var(--over)}
.srow.under b,.srow.under span{color:var(--under)}
.srow.error{background:#fbeaea}
.srow .pill{flex:0 0 auto;font-size:.75rem;padding:3px 10px}
