/* ============================================================
   FF WMS — GROVE design system
   Warm fulfillment SaaS: forest sidebar + cream content,
   clay accent, soft depth. Restyles all legacy template classes.
   ============================================================ */
:root{
  --forest:#0f3b33; --forest-2:#0b2e28; --forest-3:#14463d;
  --cream:#f3efe5; --cream-2:#eae4d6; --card:#fffdf8; --ink:#1d2421;
  --soft:#5f6b64; --faint:#909a92;
  --line:#e4ddcd; --line-2:#d6cdb8;
  --clay:#e07a3e; --clay-2:#c5571f; --clay-soft:#fbe4d2;
  --mint:#1f9c6b; --mint-soft:#dcf1e6; --gold:#e8b04b; --gold-soft:#fbeecc;
  --blue:#3f6fb5; --blue-soft:#e9eef6; --red:#d2442c; --red-soft:#f8dcd5;
  --disp:'Bricolage Grotesque',system-ui,sans-serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,sans-serif;
  --shadow:0 4px 18px rgba(20,40,33,.06);
  --shadow-lg:0 14px 40px rgba(15,59,51,.16);
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%}
body{
  font-family:var(--sans); color:var(--ink); background:var(--cream);
  -webkit-font-smoothing:antialiased; display:flex; min-height:100vh;
}
a{color:inherit;text-decoration:none}
::selection{background:var(--clay);color:#fff}

/* ---------- sidebar ---------- */
.side{
  width:248px; flex:none; background:var(--forest); color:#dfeae4;
  padding:22px 14px; display:flex; flex-direction:column;
  position:sticky; top:0; height:100vh; overflow-y:auto;
  background-image:radial-gradient(140% 55% at 8% -8%,rgba(232,176,75,.12),transparent 55%);
}
.logo{display:flex;align-items:center;gap:11px;padding:6px 10px 18px}
.logo .mk{width:34px;height:34px;border-radius:11px;background:var(--clay);display:grid;place-items:center;
  font-family:var(--disp);font-weight:800;color:#2a160a;font-size:18px;box-shadow:0 6px 18px rgba(224,122,62,.4)}
.logo b{font-family:var(--disp);font-weight:800;font-size:18px;letter-spacing:-.01em;color:#fff;line-height:1.1}
.logo span{display:block;font-size:10px;letter-spacing:.18em;color:#7fa193;text-transform:uppercase;margin-top:2px}
.navg{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#5f8377;padding:16px 12px 7px}
.side a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;font-size:14px;font-weight:500;
  color:#c4d6ce;transition:background .15s,color .15s}
.side a .ic{width:18px;text-align:center;opacity:.85;font-size:14px}
.side a:hover{background:var(--forest-3);color:#fff}
.side a.on{background:var(--cream);color:var(--forest);font-weight:700}
.side a.on .ic{opacity:1}
.side .grow{flex:1;min-height:18px}
.uchip{display:flex;align-items:center;gap:11px;padding:10px;border-radius:14px;background:var(--forest-2)}
.uchip .av{width:36px;height:36px;border-radius:50%;background:var(--gold);color:#3a2a06;display:grid;place-items:center;
  font-weight:700;font-family:var(--disp);flex:none}
.uchip-meta{min-width:0;flex:1}
.uchip-meta b{font-size:13px;color:#fff;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.uchip-meta span{font-size:11px;color:#7fa193}
.uchip .logout{width:30px;height:30px;flex:none;display:grid;place-items:center;border-radius:9px;
  color:#9db8ad;background:rgba(255,255,255,.05);font-size:15px}
.uchip .logout:hover{background:var(--clay);color:#fff}

/* ---------- main ---------- */
.main{flex:1;min-width:0;padding:32px clamp(20px,3.5vw,46px) 64px}

/* ---------- typography ---------- */
h1{font-family:var(--disp);font-weight:800;font-size:30px;letter-spacing:-.02em;margin:0 0 18px;line-height:1.05}
h2{font-family:var(--disp);font-weight:700;font-size:21px;letter-spacing:-.01em;margin:0 0 12px}
h3{font-family:var(--disp);font-weight:700;font-size:16px;letter-spacing:-.01em;margin:0 0 4px}
p{line-height:1.55;color:var(--soft)}
small{color:var(--faint)}
.head-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.head-row h1{margin:0}
.muted{color:var(--soft)}

/* ---------- cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:22px;margin:16px 0;
  display:flex;flex-direction:column;gap:14px;max-width:560px;box-shadow:var(--shadow)}
.card h3{margin-bottom:8px}
.card label{display:flex;flex-direction:column;font-size:13px;font-weight:600;color:var(--soft);gap:6px}
.card label.checkbox{flex-direction:row;align-items:center;gap:9px}

/* ---------- forms ---------- */
input,select,textarea{font-family:var(--sans);font-size:14px;color:var(--ink);background:#fff;
  padding:11px 13px;border:1px solid var(--line-2);border-radius:12px;transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--clay);box-shadow:0 0 0 3px var(--clay-soft)}
input::placeholder{color:var(--faint)}
label{font-weight:600}

/* ---------- buttons ---------- */
button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);
  font-size:14px;font-weight:700;background:var(--forest);color:#fff;border:0;border-radius:30px;
  padding:11px 20px;cursor:pointer;text-decoration:none;transition:background .15s,box-shadow .15s,transform .05s;
  box-shadow:0 6px 16px rgba(15,59,51,.18)}
button:hover,.btn:hover{background:var(--clay);box-shadow:0 8px 20px rgba(224,122,62,.3)}
button:active,.btn:active{transform:translateY(1px)}
.btn.ghost,button.ghost{background:transparent;color:var(--forest);border:1.5px solid var(--line-2);box-shadow:none}
.btn.ghost:hover,button.ghost:hover{background:var(--forest);color:#fff;border-color:var(--forest)}
.btn.danger,button.danger{background:var(--red)}
.btn.danger:hover,button.danger:hover{background:#b3331f}
.btn.sm{padding:7px 14px;font-size:12.5px}

/* ---------- links in toolbars ---------- */
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.head-row .row a:not(.btn){font-weight:600;color:var(--clay-2);padding:9px 4px}
.head-row .row a:not(.btn):hover{color:var(--clay)}

/* ---------- tables ---------- */
.grid{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);
  border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.grid th,.grid td{text-align:left;padding:13px 16px;font-size:14px}
.grid th{background:#fbf9f2;color:var(--faint);font-weight:600;font-size:11px;letter-spacing:.05em;
  text-transform:uppercase;border-bottom:1px solid var(--line)}
.grid td{border-bottom:1px solid var(--line)}
.grid tbody tr:last-child td{border-bottom:0}
.grid tbody tr:hover{background:#faf7ef}
.grid a{font-weight:700;color:var(--forest)}
.grid a:hover{color:var(--clay)}
.order-unmatched{background:var(--red-soft)!important}

/* ---------- badges / status ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:20px;font-size:12px;
  font-weight:600;background:var(--cream-2);color:var(--soft)}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.badge.work,.badge.warn{background:var(--clay-soft);color:var(--clay-2)}
.badge.done,.badge.ok{background:var(--mint-soft);color:var(--mint)}
.badge.wait,.badge.info{background:var(--blue-soft);color:var(--blue)}
.badge.bad,.badge.err{background:var(--red-soft);color:var(--red)}
.mp-status{font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.mp-status::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor}
.mp-status.ok{color:var(--mint)}
.mp-status.bad{color:var(--red)}
.mp-status.unknown{color:var(--faint)}
.mp-status small{color:var(--faint);margin-left:6px;font-weight:400}

/* ---------- messages ---------- */
.error{color:var(--red);font-weight:600}
.flash,.notice{background:var(--gold-soft);border:1px solid #ecd9a0;color:#7a5a12;border-radius:14px;
  padding:12px 16px;margin:14px 0;font-weight:500}
.code{font-family:var(--disp);font-weight:800;font-size:26px;letter-spacing:4px;color:var(--forest);
  background:var(--cream-2);border-radius:12px;padding:10px 16px;display:inline-block}

/* ---------- stepper ---------- */
.stepper{list-style:none;display:flex;gap:10px;padding:0;margin:16px 0;flex-wrap:wrap}
.step{flex:1;min-width:150px;border:1px solid var(--line);border-radius:16px;padding:14px;
  background:var(--card);box-shadow:var(--shadow);opacity:.62;transition:.15s}
.step.active{opacity:1;border-color:var(--clay);box-shadow:0 0 0 3px var(--clay-soft),var(--shadow)}
.step.done{opacity:1;background:var(--mint-soft);border-color:#bce0cb}
.step.done .step-name{text-decoration:line-through;color:var(--mint)}
.step .step-no{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;
  background:var(--forest);color:#fff;font-size:12px;font-weight:700;margin-right:8px;font-family:var(--disp)}
.step.done .step-no{background:var(--mint)}
.step.active .step-no{background:var(--clay)}
.step-name{font-weight:600}
.step-meta{display:block;font-size:12px;color:var(--faint);margin-top:7px}

/* ---------- progress bar ---------- */
.prog{background:var(--cream-2);border-radius:20px;height:9px;overflow:hidden}
.prog>span{display:block;height:9px;border-radius:20px;background:linear-gradient(90deg,var(--clay),var(--gold))}

/* ---------- calendar ---------- */
.cal{width:100%;border-collapse:separate;border-spacing:6px}
.cal td{border:1px solid var(--line);background:var(--card);border-radius:12px;vertical-align:top;
  height:78px;width:14%;padding:7px;font-size:12px;box-shadow:var(--shadow)}
.cal td.today{background:var(--gold-soft);border-color:#ecd9a0}
.cal .ev{display:block;background:var(--forest);color:#fff;border-radius:8px;padding:2px 6px;margin-top:3px;
  font-size:11px;font-weight:600;text-decoration:none}
.cal .ev.due{background:var(--clay)}

/* ---------- scan ---------- */
.scan-input{font-size:1.7rem;font-weight:600;padding:16px 18px;width:100%;border-radius:16px;
  border:2px solid var(--line-2);text-align:center}
.scan-input:focus{border-color:var(--clay)}

/* ---------- auth (login) ---------- */
body.auth{align-items:center;justify-content:center;
  background-image:radial-gradient(120% 80% at 50% -20%,#15463c,transparent 60%),
    radial-gradient(100% 70% at 100% 110%,rgba(224,122,62,.18),transparent 55%);
  background-color:var(--forest)}
body.auth .main{flex:none;width:100%;max-width:420px;padding:0;display:flex;flex-direction:column;align-items:center}
body.auth h1{font-family:var(--disp);color:#fff;font-size:34px;text-align:center;margin-bottom:6px}
body.auth h1::before{content:"FF Grove";display:block;font-size:13px;letter-spacing:.22em;font-weight:600;
  color:var(--gold);text-transform:uppercase;margin-bottom:14px}
body.auth .card{width:100%;max-width:none;background:var(--card);box-shadow:var(--shadow-lg);padding:26px}
body.auth .error{text-align:center}

/* ---------- misc ---------- */
.spacer{flex:1}
hr{border:0;border-top:1px solid var(--line);margin:20px 0}
.pill{display:inline-flex;align-items:center;padding:4px 11px;border-radius:20px;font-size:12px;font-weight:600;
  background:var(--cream-2);color:var(--soft)}

/* ---------- dashboard widgets ---------- */
.dash-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.dash-head .hi{font-size:13px;font-weight:600;color:var(--soft)}
.dash-head h1{margin:3px 0 0}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:22px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:20px;box-shadow:var(--shadow)}
.stat .ic{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;font-size:18px;margin-bottom:14px}
.stat .ic.c1{background:var(--clay-soft);color:var(--clay)}
.stat .ic.c2{background:var(--mint-soft);color:var(--mint)}
.stat .ic.c3{background:var(--blue-soft);color:var(--blue)}
.stat .ic.c4{background:var(--gold-soft);color:#b98513}
.stat .ic.c5{background:#e6e9e3;color:var(--forest)}
.stat .lab{font-size:13px;color:var(--soft);font-weight:600}
.stat .v{font-family:var(--disp);font-weight:800;font-size:36px;letter-spacing:-.02em;line-height:1;margin-top:6px;
  font-variant-numeric:tabular-nums}
.stat .v small{font-size:16px;color:var(--soft)}
.stat .chg{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;margin-top:11px;
  padding:3px 9px;border-radius:20px;background:var(--mint-soft);color:var(--mint)}
.dash-cols{display:grid;grid-template-columns:1fr 320px;gap:20px;align-items:start}
.dash-cols .head-row{margin-bottom:12px}
.dash-cols h2{margin:0}
.more{font-size:13px;font-weight:600;color:var(--clay-2)}
.more:hover{color:var(--clay)}
.dash-side{display:flex;flex-direction:column;gap:18px}
.dash-side .card{max-width:none;margin:0}
.ring-card h3{margin-bottom:6px}
.ring-wrap{display:flex;align-items:center;gap:18px}
.ring{width:108px;height:108px;border-radius:50%;flex:none;position:relative}
.ring .hole{position:absolute;inset:14px;background:var(--card);border-radius:50%;display:grid;place-items:center;
  font-family:var(--disp);font-weight:800;font-size:22px;color:var(--ink)}
.ring-wrap .leg{display:flex;flex-direction:column;gap:9px;font-size:13px;color:var(--soft)}
.ring-wrap .leg div{display:flex;align-items:center;gap:8px}
.ring-wrap .leg b{margin-left:auto;color:var(--ink)}
.ring-wrap .leg i{width:10px;height:10px;border-radius:4px}

@media(max-width:980px){.dash-cols{grid-template-columns:1fr}}
@media(max-width:820px){
  body{flex-direction:column}
  .side{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;align-items:center;padding:12px}
  .side .navg{display:none}
  .side .grow{display:none}
  .logo{padding:6px 10px}
  .side a{padding:8px 10px}
  .uchip{margin-left:auto}
  .main{padding:22px 18px 48px}
}
