:root{
  --bg:#0b0f0d; --panel:#11161300; --card:#121814; --card2:#161d18;
  --line:#1f2a23; --line2:#26342b;
  --txt:#e8f0ea; --muted:#8aa093; --faint:#5f7268;
  --acc:#2ee687; --acc-d:#1fbf6e; --acc-ghost:rgba(46,230,135,.12);
  --warn:#e6c12e; --bad:#e6553e; --info:#4ea8e6;
  --r:14px; --r2:10px;
  --shadow:0 8px 30px rgba(0,0,0,.45);
  --font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--txt); font-family:var(--font);
  -webkit-font-smoothing:antialiased; line-height:1.45;
  min-height:100vh;
}
a{color:var(--acc); text-decoration:none}
a:hover{text-decoration:underline}

/* layout */
.wrap{max-width:520px;margin:0 auto;padding:16px 16px 96px}
.wrap-wide{max-width:1400px;margin:0 auto;padding:0}
.hidden{display:none !important}
.row{display:flex;gap:10px;align-items:center}
.row.wrap{flex-wrap:wrap}
.spread{justify-content:space-between}
.grow{flex:1}
.center{text-align:center}
.muted{color:var(--muted)}
.faint{color:var(--faint)}
.small{font-size:13px}
.tiny{font-size:11px;letter-spacing:.04em;text-transform:uppercase}

/* brand / header */
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.02em}
.brand .mark{width:30px;height:30px;border-radius:8px;display:block}
.brand b{color:var(--acc)}
header.bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:rgba(11,15,13,.92);backdrop-filter:blur(8px);z-index:20;
}

/* cards */
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:16px;margin:12px 0;
}
.card.tap{cursor:pointer;transition:border-color .15s, transform .05s}
.card.tap:active{transform:scale(.995)}
.card.tap:hover{border-color:var(--line2)}

/* typography */
h1{font-size:22px;margin:0 0 4px}
h2{font-size:17px;margin:0 0 10px}
h3{font-size:14px;margin:0 0 8px;color:var(--muted);font-weight:600}
.lede{color:var(--muted);margin:0 0 16px}

/* form */
label{display:block;font-size:12px;color:var(--muted);margin:12px 0 6px;letter-spacing:.02em}
input,textarea,select{
  width:100%;background:var(--card2);border:1px solid var(--line2);color:var(--txt);
  border-radius:var(--r2);padding:13px 13px;font-size:16px;font-family:inherit;outline:none;
}
input:focus,textarea:focus{border-color:var(--acc);box-shadow:0 0 0 3px var(--acc-ghost)}
textarea{min-height:74px;resize:vertical}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--acc);color:#062013;border:none;border-radius:var(--r2);
  padding:13px 16px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;
  transition:filter .12s, transform .05s;width:100%;
}
.btn:active{transform:scale(.985)}
.btn:hover{filter:brightness(1.06)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.ghost{background:transparent;color:var(--txt);border:1px solid var(--line2)}
.btn.ghost:hover{border-color:var(--acc);color:var(--acc);filter:none}
.btn.sm{padding:9px 12px;font-size:13px;width:auto}
.btn.danger{background:var(--bad);color:#1a0805}
.btn-rowfit{width:auto;flex:1}

/* badges */
.badge{
  display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;padding:4px 9px;border-radius:999px;
  border:1px solid var(--line2);color:var(--muted);background:var(--card2);white-space:nowrap;
}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--muted)}
.badge.active{color:var(--acc);border-color:rgba(46,230,135,.4);background:var(--acc-ghost)}
.badge.active .dot{background:var(--acc);box-shadow:0 0 0 0 rgba(46,230,135,.6);animation:pulse 1.8s infinite}
.badge.delivered{color:var(--info);border-color:rgba(78,168,230,.35)}
.badge.delivered .dot{background:var(--info)}
.badge.pending .dot{background:var(--warn)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(46,230,135,.5)}70%{box-shadow:0 0 0 7px rgba(46,230,135,0)}100%{box-shadow:0 0 0 0 rgba(46,230,135,0)}}

/* load card */
.load-ref{font-weight:700;font-size:16px}
.route{display:flex;align-items:center;gap:8px;color:var(--txt);margin-top:6px;font-size:14px}
.route .arrow{color:var(--acc);flex:0 0 auto}
.route .leg{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* live banner */
.live-banner{
  position:sticky;top:0;z-index:30;display:none;align-items:center;gap:10px;
  background:linear-gradient(90deg,var(--acc-d),var(--acc));color:#04150c;
  font-weight:700;padding:10px 16px;font-size:14px;
}
.live-banner.show{display:flex}
.live-banner .rad{width:10px;height:10px;border-radius:50%;background:#04150c;animation:pulse2 1.4s infinite}
@keyframes pulse2{0%,100%{opacity:.4}50%{opacity:1}}

/* toast / notes */
#toast{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);z-index:60;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}
.toast{
  background:var(--card2);border:1px solid var(--line2);color:var(--txt);
  padding:10px 16px;border-radius:999px;font-size:13px;box-shadow:var(--shadow);
  animation:tin .2s ease;max-width:90vw;
}
.toast.ok{border-color:rgba(46,230,135,.4);color:var(--acc)}
.toast.warn{border-color:rgba(230,193,46,.4);color:var(--warn)}
.toast.err{border-color:rgba(230,85,62,.4);color:var(--bad)}
@keyframes tin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* queue chip */
.qchip{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--warn);
  border:1px solid rgba(230,193,46,.3);background:rgba(230,193,46,.08);padding:4px 10px;border-radius:999px}
.qchip.empty{color:var(--faint);border-color:var(--line);background:transparent}

/* thumbnails */
.thumbs{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.thumb{width:72px;height:72px;border-radius:10px;object-fit:cover;border:1px solid var(--line2);background:var(--card2)}
.thumb-wrap{position:relative}
.thumb-wrap .tg{position:absolute;left:4px;bottom:4px;font-size:9px;background:rgba(0,0,0,.7);color:#fff;padding:1px 5px;border-radius:5px;text-transform:uppercase;letter-spacing:.04em}

/* signature canvas */
.sigbox{border:1px dashed var(--line2);border-radius:var(--r2);background:#0f1411;touch-action:none}
canvas#sig{display:block;width:100%;height:180px;border-radius:var(--r2)}

/* capture buttons */
.capgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:6px}
.capbtn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;
  background:var(--card2);border:1px solid var(--line2);border-radius:var(--r2);color:var(--txt);
  font-size:12px;font-weight:600;cursor:pointer;transition:border-color .15s}
.capbtn:hover{border-color:var(--acc)}
.capbtn svg{width:24px;height:24px;color:var(--acc)}
.capbtn input[type=file]{display:none}

/* floating action */
.fab{position:fixed;right:16px;bottom:20px;z-index:25;width:auto}
.fab .btn{box-shadow:var(--shadow)}

/* status pills row */
.statusrow{display:flex;gap:10px;margin-top:8px}

/* connecting state */
.conn{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:14px;padding:20px 0;justify-content:center}
.spin{width:16px;height:16px;border:2px solid var(--line2);border-top-color:var(--acc);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* empty state */
.empty{text-align:center;color:var(--faint);padding:40px 20px}
.empty svg{width:42px;height:42px;color:var(--line2);margin-bottom:10px}

/* ====== DISPATCH ====== */
.dispatch-grid{display:grid;grid-template-columns:1fr 420px;height:calc(100vh - 58px)}
#map{width:100%;height:100%;background:#0f1411}
.sidepanel{border-left:1px solid var(--line);overflow-y:auto;background:var(--bg)}
.sidepanel .ph{padding:14px 16px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg);z-index:5}
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;color:var(--faint);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:8px 12px;border-bottom:1px solid var(--line);position:sticky;top:51px;background:var(--bg)}
.tbl td{padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
.tbl tr:hover td{background:var(--card)}
.refresh-ind{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--muted)}
.refresh-ind .dot{width:8px;height:8px;border-radius:50%;background:var(--faint)}
.refresh-ind.live .dot{background:var(--acc);animation:pulse 1.8s infinite}
.refresh-ind.err .dot{background:var(--bad)}
.driver-pin{background:var(--acc);width:16px;height:16px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:2px solid #04150c;box-shadow:0 0 0 4px rgba(46,230,135,.25)}
.leaflet-popup-content-wrapper{background:var(--card2);color:var(--txt);border-radius:10px;border:1px solid var(--line2)}
.leaflet-popup-tip{background:var(--card2)}
.leaflet-popup-content{margin:10px 12px;font-family:var(--font);font-size:13px}
.leaflet-container{background:#0f1411;font-family:var(--font)}
.pop-name{font-weight:700;color:var(--acc)}
.medialink{color:var(--info)}

@media(max-width:860px){
  .dispatch-grid{grid-template-columns:1fr;height:auto}
  #map{height:55vh}
  .sidepanel{border-left:none;border-top:1px solid var(--line);max-height:none}
  .tbl th{position:static}
}
