/* Handoff Warehouse — design tokens from the handoff README */
:root{
  --accent:#E65100; --accent-press:rgba(230,81,0,.42);
  --crit:#D32F2F; --crit-text:#C62828; --crit-bg:#FCEBEA;
  --ok-text:#1B7A43; --ok-bg:#E6F4EC; --ok-border:#C9E6D4;
  --work-text:#A14708; --work-bg:#FFF1E2; --work-border:#F3D9B5;
  --repair-text:#C62828; --repair-bg:#FBE3E1; --repair-border:#F0BAB5;
  --asset-text:#2A4C7D; --asset-bg:#E6EEF8;
  --page:#E9E6E1; --screen:#F6F5F2; --card:#fff;
  --text:#1A1A18; --text2:#6B665D; --muted:#A7A29A;
  --dark:#211F1C; --b1:#E8E5DF; --b2:#E2DED7; --b3:#ECE9E3;
  --warn-bg:#FFF4E5; --warn-bg2:#FBE3E1;
  --mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;color:var(--text);
  background:var(--screen);-webkit-text-size-adjust:100%;}
.num{font-variant-numeric:tabular-nums;font-weight:800}
.mono{font-family:var(--mono)}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit;font-size:15px}
a{color:var(--accent);text-decoration:none}
.hidden{display:none!important}

/* buttons */
.btn{height:50px;border-radius:13px;border:none;font-size:15px;font-weight:700;
  padding:0 18px;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn.primary{background:var(--accent);color:#fff;box-shadow:0 6px 16px var(--accent-press)}
.btn.outline{background:#fff;color:var(--dark);border:1.5px solid var(--dark)}
.btn.ghost{background:transparent;color:var(--text2);border:1px solid var(--b1)}
.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}
.btn.sm{height:38px;font-size:13px;border-radius:10px;padding:0 12px}
.btn.danger{background:var(--crit);color:#fff}

.chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;
  font-size:11px;font-weight:700}
.chip.store{background:var(--ok-bg);color:var(--ok-text)}
.chip.work{background:var(--work-bg);color:var(--work-text)}
.chip.repair{background:var(--repair-bg);color:var(--repair-text)}
.chip.scrapped{background:#eee;color:#888}
.chip.asset{background:var(--asset-bg);color:var(--asset-text)}
.chip.green{background:var(--ok-bg);color:var(--ok-text)}
.chip.yellow{background:var(--warn-bg);color:var(--work-text)}
.chip.red{background:var(--crit-bg);color:var(--crit-text)}

/* ===== login ===== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--page);padding:20px}
.login{width:340px;background:#fff;border-radius:22px;padding:28px;
  box-shadow:0 20px 60px rgba(0,0,0,.18)}
.logo{width:62px;height:62px;border-radius:18px;background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800;
  margin-bottom:16px}
.login h1{font-size:24px;margin:6px 0 2px}
.login .sub{color:var(--text2);font-size:13px;margin-bottom:18px}
.field{margin-bottom:12px}
.field label{display:block;font-size:12px;color:var(--text2);margin-bottom:5px}
.field input{width:100%;height:48px;border:1.5px solid var(--b1);border-radius:13px;
  padding:0 14px;background:#fff}
.note{font-size:12px;color:var(--muted);margin-top:14px;line-height:1.5}
.err{color:var(--crit-text);font-size:13px;margin:8px 0}

/* ===== app shell ===== */
.shell{max-width:1180px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}
.accountbar{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;
  border-bottom:1px solid var(--b1);position:sticky;top:0;z-index:30}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800}
.accountbar .who{font-weight:700;font-size:14px}
.accountbar .role{font-size:11px;color:var(--text2)}
.pill{margin-left:auto;font-size:11px;font-weight:700;padding:5px 10px;border-radius:11px;
  background:var(--ok-bg);color:var(--ok-text)}
.offline-banner{background:var(--warn-bg);color:var(--work-text);font-size:13px;
  padding:8px 16px;border-bottom:1px solid var(--work-border)}

.main{flex:1;padding:14px 16px 90px;background:var(--screen)}
.screen-title{font-size:26px;font-weight:800;margin:6px 0 2px}
.screen-sub{color:var(--text2);font-size:13px;margin-bottom:14px}

/* cards / lists */
.card{background:var(--card);border:1px solid var(--b1);border-radius:15px;padding:14px;
  margin-bottom:12px}
.cat-head{position:sticky;top:58px;background:var(--screen);font-size:12px;font-weight:800;
  letter-spacing:.04em;color:var(--text2);padding:10px 2px 6px;z-index:5}
.row{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--b1);
  border-radius:14px;padding:12px;margin-bottom:8px}
.row .thumb{width:46px;height:46px;border-radius:10px;background:var(--b3);flex:none;
  background-size:cover;background-position:center}
.row .grow{flex:1;min-width:0}
.row .name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis}
.row .meta{font-size:12px;color:var(--text2);margin-top:2px}
.row .qty{font-size:29px;text-align:right}
.row .limit{font-size:11px;color:var(--text2);text-align:right}
.row.low{background:var(--crit-bg);border-left:4px solid var(--crit)}
.row.low .qty,.row.low .limit{color:var(--crit-text)}

.kpi{font-size:62px}
.fab{position:fixed;right:20px;bottom:84px;width:58px;height:58px;border-radius:18px;
  background:var(--accent);color:#fff;border:none;font-size:30px;
  box-shadow:0 12px 28px var(--accent-press);z-index:40}

/* bottom nav (mobile) */
.bottomnav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--b1);
  display:flex;z-index:35;max-width:1180px;margin:0 auto}
.bottomnav button{flex:1;border:none;background:none;padding:10px 0 12px;font-size:11px;
  color:var(--text2);display:flex;flex-direction:column;align-items:center;gap:3px}
.bottomnav button.active{color:var(--accent);font-weight:700}
.bottomnav .badge{position:absolute;transform:translate(14px,-4px);background:var(--crit);
  color:#fff;border-radius:10px;font-size:10px;padding:1px 6px;font-weight:700}

/* moto widget */
.moto-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;margin-bottom:8px}
.moto-card{flex:none;width:138px;border:1px solid var(--b1);border-radius:14px;padding:12px;
  background:#fff}
.moto-card.due{background:var(--warn-bg)}
.moto-card.stale{background:var(--warn-bg2)}
.moto-card .mh{font-size:23px;margin:6px 0 2px}
.moto-card .mi{font-size:11px;color:var(--text2)}
.moto-card.today .mi{color:var(--ok-text)}
.moto-card.due .mi{color:var(--work-text)}
.moto-card.stale .mi{color:var(--crit-text)}

/* sheet / modal */
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:50;
  animation:fadeIn .18s ease}
.sheet{position:fixed;left:0;right:0;bottom:0;background:#fff;border-radius:26px 26px 0 0;
  padding:18px 18px 24px;z-index:51;max-width:1180px;margin:0 auto;
  animation:sheetUp .26s cubic-bezier(.22,1,.36,1);max-height:88vh;overflow:auto}
.sheet h3{margin:2px 0 14px;font-size:18px}
.seg{display:flex;background:var(--b3);border-radius:12px;padding:3px;margin-bottom:12px}
.seg button{flex:1;border:none;background:none;padding:9px;border-radius:9px;font-size:13px;
  font-weight:700;color:var(--text2)}
.seg button.active{background:#fff;color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.1)}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* toast */
.toast{position:fixed;left:50%;bottom:100px;transform:translateX(-50%);background:#26241F;
  color:#fff;padding:12px 18px;border-radius:12px;font-size:14px;z-index:60;
  box-shadow:0 14px 34px rgba(0,0,0,.3);animation:fadeIn .24s ease;max-width:90%}
.toast.crit{background:var(--crit)}

/* timeline */
.timeline{border-left:2px solid var(--b1);margin-left:6px;padding-left:16px}
.tl-item{position:relative;margin-bottom:14px}
.tl-item::before{content:"";position:absolute;left:-23px;top:3px;width:10px;height:10px;
  border-radius:50%;background:var(--b1)}
.tl-item:first-child::before{background:var(--accent)}
.tl-title{font-weight:700;font-size:14px}
.tl-meta{font-size:12px;color:var(--text2)}
.tl-comment{font-size:13px;background:var(--card);border-left:3px solid var(--accent);
  padding:6px 10px;border-radius:8px;margin-top:5px;background:#FCEFE6}

/* tables (web) */
.tbl{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;
  border:1px solid var(--b1)}
.tbl th,.tbl td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--b3);font-size:14px}
.tbl th{font-size:12px;color:var(--text2);background:#FAF9F7}
.tbl tr.low{background:var(--crit-bg)}
.tbl input.lim{width:70px;height:34px;border:1.5px solid var(--b1);border-radius:8px;padding:0 8px}
.grid2{display:grid;grid-template-columns:1fr;gap:14px}

/* sidebar (web wide) */
.layout{display:flex;flex:1}
.sidebar{display:none}
@media(min-width:860px){
  .sidebar{display:flex;flex-direction:column;width:210px;background:#fff;
    border-right:1px solid var(--b1);padding:14px 10px;gap:4px}
  .sidebar button{text-align:left;border:none;background:none;padding:11px 12px;border-radius:10px;
    font-size:14px;color:var(--text);font-weight:600}
  .sidebar button.active{background:#FCEFE6;color:var(--accent)}
  .bottomnav{display:none}
  .main{padding-bottom:30px}
  .grid2{grid-template-columns:1fr 1fr}
  .fab{right:30px;bottom:30px}
}
.dash-card h4{margin:0 0 10px;font-size:15px}
.bar{height:10px;background:var(--b3);border-radius:6px;overflow:hidden;margin-top:4px}
.bar>i{display:block;height:100%;background:var(--accent)}
.field-row{display:flex;gap:8px}
.field-row>*{flex:1}
.empty{color:var(--muted);text-align:center;padding:30px;font-size:14px}
