:root,html[data-theme="dark"]{
  --bg:#0a0e1a;--bg2:rgba(30,41,59,.72);--bg3:rgba(51,65,85,.5);--bg-solid:#1e293b;
  --primary:#0ea5e9;--accent:#6366f1;
  --green:#22c55e;--amber:#f59e0b;--red:#ef4444;--rose:#f43f5e;
  --txt:#f8fafc;--txt2:#cbd5e1;--txt3:#94a3b8;--txt4:#64748b;
  --r:20px;--r2:14px;--r3:10px;--r4:24px;
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --glass:rgba(255,255,255,.04);
  --glass-border:rgba(255,255,255,.08);
  --card:rgba(30,41,59,.85);
  --surface-nav:rgba(15,23,42,.78);
  --surface-drawer:rgba(15,23,42,.95);
  --surface-toast:rgba(15,23,42,.95);
  --surface-splash:#0f172a;
  --hero-grad:linear-gradient(135deg,#1e1b4b 0%,#0c4a6e 60%,#164e63 100%);
  --shadow-lg:0 12px 40px rgba(0,0,0,.4),0 4px 12px rgba(0,0,0,.3);
  --shadow-glow:0 8px 32px rgba(99,102,241,.25);
  color-scheme:dark;
}
html[data-theme="light"]{
  --bg:#f5f7fb;--bg2:rgba(255,255,255,.72);--bg3:rgba(226,232,240,.55);--bg-solid:#ffffff;
  --primary:#0ea5e9;--accent:#6366f1;
  --green:#16a34a;--amber:#d97706;--red:#dc2626;--rose:#e11d48;
  --txt:#0f172a;--txt2:#334155;--txt3:#64748b;--txt4:#94a3b8;
  --glass:rgba(255,255,255,.65);
  --glass-border:rgba(15,23,42,.08);
  --card:rgba(255,255,255,.92);
  --surface-nav:rgba(255,255,255,.86);
  --surface-drawer:rgba(255,255,255,.96);
  --surface-toast:rgba(15,23,42,.92);
  --surface-splash:#f5f7fb;
  --hero-grad:linear-gradient(135deg,color-mix(in srgb,var(--primary) 92%,#1e293b) 0%,color-mix(in srgb,var(--accent) 88%,#1e1b4b) 60%,color-mix(in srgb,var(--accent) 70%,#0f172a) 100%);
  --shadow-lg:0 12px 40px rgba(15,23,42,.10),0 4px 12px rgba(15,23,42,.06);
  --shadow-glow:0 8px 32px rgba(99,102,241,.18);
  color-scheme:light;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--txt);font-family:Inter,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;letter-spacing:-.01em}
body{background:
  radial-gradient(ellipse 800px 600px at 0% 0%, color-mix(in srgb, var(--primary) 22%, transparent), transparent 60%),
  radial-gradient(ellipse 700px 500px at 100% 0%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 55%),
  radial-gradient(ellipse 600px 400px at 50% 100%, color-mix(in srgb, var(--rose) 12%, transparent), transparent 60%),
  var(--bg);
  background-attachment:fixed}
button{font-family:inherit;font-weight:600}
input,textarea{font-family:inherit;color:inherit}
.hidden{display:none!important}

.boot{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;z-index:1000;background:inherit}
.boot-logo{width:80px;height:80px;border-radius:28px;background:linear-gradient(135deg,var(--primary),var(--accent));box-shadow:var(--shadow-glow);animation:pulse 1.6s ease-in-out infinite}
.boot-title{font-weight:800;font-size:20px;letter-spacing:-.02em}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.92);opacity:.75}}

#app{display:flex;flex-direction:column;height:100%;padding-top:max(var(--safe-top),12px);position:relative;transition:padding-top .2s}
body.cf-duty-on #app{padding-top:calc(max(var(--safe-top),12px) + 36px)}

.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 10px;flex-shrink:0;position:relative;z-index:10}
.topbar-logo{display:flex;align-items:center;gap:11px;font-weight:800;font-size:17px;letter-spacing:-.02em}
.topbar-logo .dot{width:34px;height:34px;border-radius:11px;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:15px;box-shadow:0 4px 14px color-mix(in srgb, var(--primary) 45%, transparent)}
.topbar-actions{display:flex;align-items:center;gap:8px}
.topbar-btn{width:42px;height:42px;border-radius:50%;background:var(--glass);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);border:1px solid var(--glass-border);color:var(--txt2);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:transform .15s,background .15s}
.topbar-btn:active{transform:scale(.92)}
.topbar-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.topbar-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;cursor:pointer;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.3);transition:transform .15s}
.topbar-avatar:active{transform:scale(.92)}html{transition:background-color .25s ease}body{transition:background-color .25s ease,color .25s ease}.topbar-btn.theme-btn svg{transition:transform .35s cubic-bezier(.34,1.56,.64,1)}.topbar-btn.theme-btn:active svg{transform:rotate(180deg) scale(.85)}
.online-dot{position:absolute;top:6px;right:6px;width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 0 2px var(--bg-solid),0 0 10px var(--green)}
.online-dot.off{background:var(--red);box-shadow:0 0 0 2px var(--bg-solid)}
.notif-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;border-radius:9px;background:linear-gradient(135deg,var(--red),var(--rose));color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 2px 8px rgba(239,68,68,.4)}
.notif-badge.sev-red{background:linear-gradient(135deg,var(--red),var(--rose));box-shadow:0 2px 8px rgba(239,68,68,.45)}
.notif-badge.sev-amber{background:linear-gradient(135deg,var(--amber),#fbbf24);box-shadow:0 2px 8px rgba(245,158,11,.5)}
.notif-badge.sev-blue{background:linear-gradient(135deg,var(--primary),var(--accent));box-shadow:0 2px 8px rgba(14,165,233,.5)}
.notif-badge.pulsing{animation:notifBadgePulse 1.7s ease-in-out infinite}
@keyframes notifBadgePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
.topbar-btn.alerting{animation:notifBellGlow 1.9s ease-in-out infinite}
.topbar-btn.alerting svg{color:var(--sevc,rgba(239,68,68,.6))}
@keyframes notifBellGlow{0%,100%{box-shadow:0 0 0 0 transparent}50%{box-shadow:0 0 14px 2px var(--sevc,rgba(239,68,68,.6)),inset 0 0 0 1px var(--sevc,rgba(239,68,68,.6))}}
.topbar-btn.ring-once{animation:notifBellRing 1.1s cubic-bezier(.36,.07,.19,.97) 1}
@keyframes notifBellRing{0%{box-shadow:0 0 0 0 var(--sevc,rgba(239,68,68,.6))}10%{transform:rotate(-12deg)}20%{transform:rotate(12deg)}30%{transform:rotate(-9deg)}40%{transform:rotate(7deg)}55%{transform:rotate(0)}60%{box-shadow:0 0 0 8px transparent,0 0 22px 4px var(--sevc,rgba(239,68,68,.6))}100%{box-shadow:0 0 0 0 transparent}}

.screen{flex:1;overflow-y:auto;padding:0;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}
.screen::-webkit-scrollbar{width:0;background:transparent}
.screen-inner{padding:6px 18px 120px}

.bottom-nav{position:fixed;left:0;right:0;bottom:0;background:var(--surface-nav);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--glass-border);border-radius:18px 18px 0 0;display:flex;flex-shrink:0;padding:2px 4px 2px;z-index:60;box-shadow:0 -6px 20px rgba(0,0,0,.14)}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3px 2px 1px;gap:1px;font-size:9.5px;font-weight:700;color:var(--txt4);border:none;background:none;cursor:pointer;transition:color .2s,background .2s,transform .15s;border-radius:14px;letter-spacing:.02em;min-height:40px}
.nav-btn:active{transform:scale(.94)}
.nav-btn.active{color:#fff;background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 90%,transparent),color-mix(in srgb,var(--accent) 90%,transparent));box-shadow:0 4px 14px color-mix(in srgb,var(--primary) 35%,transparent)}
.nav-btn svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}

.hero{position:relative;background:var(--hero-grad);border-radius:var(--r4);padding:24px 22px;margin-bottom:18px;overflow:hidden;border:1px solid var(--glass-border);box-shadow:var(--shadow-lg)}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 0%, color-mix(in srgb,var(--primary) 35%,transparent) 0%, transparent 50%),radial-gradient(circle at 0% 100%,color-mix(in srgb,var(--accent) 25%,transparent) 0%,transparent 50%);pointer-events:none}
.hero::after{content:'';position:absolute;right:-40px;top:-40px;width:180px;height:180px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);border-radius:50%}
.hero-greeting{font-size:13px;color:rgba(255,255,255,.65);margin-bottom:4px;position:relative;font-weight:500}
.hero-name{font-size:26px;font-weight:800;margin-bottom:18px;position:relative;letter-spacing:-.03em;line-height:1.15}
.hero-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;position:relative}
.hero-stat{background:rgba(255,255,255,.06);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:var(--r2);padding:12px 8px;text-align:center;transition:transform .15s}
.hero-stat:active{transform:scale(.96)}
.hero-stat-val{font-size:22px;font-weight:800;letter-spacing:-.03em;line-height:1}
.hero-stat-lbl{font-size:10px;color:rgba(255,255,255,.6);margin-top:5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}

.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}
.qa-btn{background:var(--glass);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border:1px solid var(--glass-border);border-radius:var(--r2);padding:16px 4px;display:flex;flex-direction:column;align-items:center;gap:7px;color:var(--txt);cursor:pointer;font-size:11px;font-weight:700;transition:transform .12s,background .15s;letter-spacing:.01em}
.qa-btn:active{transform:scale(.93)}
.qa-btn svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.qa-btn.primary{color:var(--primary)}
.qa-btn.accent{color:var(--accent)}
.qa-btn.green{color:var(--green)}

/* ── Operations Command Center ─────────────────────────────── */
.cc-dash{display:flex;flex-direction:column;gap:18px;margin-top:18px}
.cc-sec{animation:ccUp .4s ease both}
.cc-sec-h{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--txt3);margin:0 2px 10px}
.cc-sec-h a{font-size:12px;color:var(--primary);text-transform:none;letter-spacing:0;font-weight:600;cursor:pointer}
.cc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cc-grid.c3{grid-template-columns:1fr 1fr 1fr}
@media(min-width:560px){.cc-grid{grid-template-columns:1fr 1fr 1fr 1fr}.cc-grid.c3{grid-template-columns:1fr 1fr 1fr}}
.cc-card{position:relative;background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r2);padding:12px 13px;display:flex;flex-direction:column;gap:1px;overflow:hidden;transition:transform .15s,border-color .15s;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.cc-card:active{transform:scale(.97)}
.cc-card .cc-ic{position:absolute;top:11px;right:11px;width:17px;height:17px;opacity:.45;color:var(--txt3)}
.cc-card .cc-ic svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.cc-v{font-size:23px;font-weight:800;letter-spacing:-.02em;line-height:1.15;color:var(--txt)}
.cc-l{font-size:11px;font-weight:600;color:var(--txt3);line-height:1.25}
.cc-sub{font-size:10.5px;color:var(--txt4);margin-top:1px}
.cc-card.good .cc-v{color:var(--green)} .cc-card.good .cc-ic{color:var(--green);opacity:.65}
.cc-card.warn .cc-v{color:var(--amber)} .cc-card.warn .cc-ic{color:var(--amber);opacity:.7}
.cc-card.bad{border-color:color-mix(in srgb,var(--red) 38%,transparent)} .cc-card.bad .cc-v{color:var(--red)} .cc-card.bad .cc-ic{color:var(--red);opacity:.7}
.cc-card.info .cc-v{color:var(--primary)} .cc-card.info .cc-ic{color:var(--primary);opacity:.7}
.cc-trend{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;margin-top:5px;padding:2px 7px;border-radius:999px;align-self:flex-start}
.cc-trend.up{color:var(--green);background:color-mix(in srgb,var(--green) 15%,transparent)}
.cc-trend.down{color:var(--red);background:color-mix(in srgb,var(--red) 15%,transparent)}
.cc-trend.flat{color:var(--txt3);background:var(--glass)}
.cc-hero-score{display:flex;align-items:center;gap:15px;position:relative;margin-top:15px}
.cc-ring{position:relative;width:84px;height:84px;flex:0 0 84px}
.cc-ring svg{transform:rotate(-90deg)}
.cc-ring .rbg{stroke:rgba(255,255,255,.20)}
.cc-ring .rfg{stroke:#fff;stroke-linecap:round;transition:stroke-dasharray 1s cubic-bezier(.4,0,.2,1)}
.cc-ring-txt{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}
.cc-ring-txt b{font-size:25px;font-weight:800;line-height:1}
.cc-ring-txt span{font-size:8.5px;font-weight:700;letter-spacing:.09em;opacity:.85;text-transform:uppercase;margin-top:2px}
.cc-hero-meta{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}
.cc-hero-pill{display:flex;align-items:center;justify-content:space-between;gap:8px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.16);border-radius:11px;padding:6px 11px;color:#fff;backdrop-filter:blur(8px)}
.cc-hero-pill .pl{font-size:11px;font-weight:600;opacity:.85}
.cc-hero-pill .pv{font-size:14px;font-weight:800;white-space:nowrap}
.cc-lb{display:flex;flex-direction:column;gap:6px}
.cc-lb-row{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r3);padding:9px 11px}
.cc-lb-row.me{border-color:color-mix(in srgb,var(--primary) 50%,transparent);background:color-mix(in srgb,var(--primary) 10%,var(--card))}
.cc-lb-pos{width:24px;height:24px;border-radius:8px;background:var(--glass);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:var(--txt2);flex:0 0 24px}
.cc-lb-row:first-child .cc-lb-pos{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1206}
.cc-lb-nm{flex:1;font-size:13.5px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:7px}
.cc-lb-sc{font-size:14px;font-weight:800;color:var(--primary)}
.cc-lb-me-tag{font-size:8.5px;font-weight:800;color:var(--primary);background:color-mix(in srgb,var(--primary) 16%,transparent);padding:1px 6px;border-radius:999px;letter-spacing:.05em}
.cc-veh{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r2);padding:14px}
.cc-veh-ic{width:46px;height:46px;border-radius:13px;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;flex:0 0 46px}
.cc-veh-ic svg{width:24px;height:24px;fill:none;stroke:#fff;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.cc-veh-b{flex:1;min-width:0}
.cc-veh-nm{font-size:15px;font-weight:800;color:var(--txt)}
.cc-veh-meta{display:flex;gap:13px;margin-top:3px;font-size:11.5px;color:var(--txt3);flex-wrap:wrap}
.cc-veh-meta .on{color:var(--green);font-weight:700} .cc-veh-meta .off{color:var(--red);font-weight:700}
@keyframes ccUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.qa-btn.red{color:var(--red)}

.sos-pill{position:fixed;right:18px;bottom:calc(var(--safe-bottom) + 64px);width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--red),var(--rose));color:#fff;font-weight:800;font-size:14px;border:none;box-shadow:0 10px 28px rgba(239,68,68,.5),0 0 0 4px rgba(239,68,68,.12);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:55;letter-spacing:.05em;transition:transform .15s}
.sos-pill:active{transform:scale(.92)}
.sos-pill.arming{animation:sosArm 1.5s linear forwards}
@keyframes sosArm{0%{box-shadow:0 10px 28px rgba(239,68,68,.5)}100%{box-shadow:0 0 0 12px rgba(239,68,68,.25),0 0 0 26px rgba(239,68,68,.12),0 10px 28px rgba(239,68,68,.6)}}

.section-hdr{font-size:11px;font-weight:800;color:var(--txt3);text-transform:uppercase;letter-spacing:.1em;margin:14px 4px 12px;display:flex;justify-content:space-between;align-items:center}
.section-hdr-link{font-weight:700;color:var(--primary);font-size:12px;text-decoration:none;text-transform:none;letter-spacing:0;cursor:pointer;display:inline-flex;align-items:center;gap:3px}

.trip-row{background:var(--glass);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);border:1px solid var(--glass-border);border-radius:var(--r2);padding:14px 16px;margin-bottom:10px;border-left:4px solid transparent;cursor:pointer;transition:transform .12s,background .15s;position:relative;overflow:hidden}
.trip-row:active{transform:scale(.985)}
.trip-row.state-in_progress{border-left-color:var(--primary)}
.trip-row.state-in_progress::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary);box-shadow:0 0 12px var(--primary);animation:livePulse 2s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.5}}
.trip-row.state-confirmed{border-left-color:var(--accent)}
.trip-row.state-done{border-left-color:var(--green);opacity:.6}
.trip-row-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:7px;gap:8px}
.trip-name{font-weight:800;font-size:14px;letter-spacing:-.01em}
.badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:800;padding:4px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.05em;border:1px solid transparent}
.badge-primary{background:color-mix(in srgb,var(--primary) 16%,transparent);color:var(--primary);border-color:color-mix(in srgb,var(--primary) 25%,transparent)}
.badge-accent{background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 25%,transparent)}
.badge-green{background:color-mix(in srgb,var(--green) 16%,transparent);color:var(--green);border-color:color-mix(in srgb,var(--green) 25%,transparent)}
.badge-amber{background:color-mix(in srgb,var(--amber) 16%,transparent);color:var(--amber);border-color:color-mix(in srgb,var(--amber) 25%,transparent)}
.badge-red{background:color-mix(in srgb,var(--red) 16%,transparent);color:var(--red);border-color:color-mix(in srgb,var(--red) 30%,transparent)}
.trip-route{font-size:13px;color:var(--txt2);margin-bottom:7px;display:flex;align-items:center;gap:6px;font-weight:600}
.trip-route-arrow{color:var(--txt4)}
.trip-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:11px;color:var(--txt3);font-weight:600}
.trip-meta span{display:inline-flex;align-items:center;gap:3px;background:rgba(255,255,255,.04);padding:3px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.06)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--r2);border:none;cursor:pointer;font-weight:700;font-size:15px;padding:14px 18px;transition:opacity .15s,transform .1s,background .15s,box-shadow .15s;min-height:48px;letter-spacing:-.01em}
.btn:active{transform:scale(.97);opacity:.92}
.btn-block{width:100%}
.btn-primary{background:linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 80%,var(--accent)));color:#fff;box-shadow:0 6px 18px color-mix(in srgb,var(--primary) 35%,transparent)}
.btn-accent{background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 75%,var(--primary)));color:#fff;box-shadow:0 6px 18px color-mix(in srgb,var(--accent) 35%,transparent)}
.btn-success{background:linear-gradient(135deg,var(--green),#16a34a);color:#fff;box-shadow:0 6px 18px rgba(34,197,94,.3)}
.btn-danger{background:linear-gradient(135deg,var(--red),var(--rose));color:#fff;box-shadow:0 6px 18px rgba(239,68,68,.35)}
.btn-ghost{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--txt);border:1px solid var(--glass-border);font-size:13px;padding:12px 14px;min-height:44px}
.btn-outline{background:transparent;color:var(--txt);border:1px solid var(--bg3)}

.card{background:var(--glass);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border:1px solid var(--glass-border);border-radius:var(--r);padding:16px 18px;margin-bottom:12px}
.card-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:14px;font-weight:500}
.card-row:first-child{padding-top:4px}
.card-row:last-child{border-bottom:none;padding-bottom:4px}
.card-row-lbl{color:var(--txt3);font-weight:600;font-size:13px}

.jfm-stages{display:flex;align-items:center;justify-content:space-between;margin:6px 0 14px;padding:0 2px}
.jfm-step{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--txt4);flex:0 0 auto}
.jfm-step .jfm-dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;background:var(--bg3);color:var(--txt3);border:2px solid var(--bg3);transition:all .2s}
.jfm-step.now{color:var(--primary,#0ea5e9)}
.jfm-step.now .jfm-dot{background:var(--primary,#0ea5e9);color:#fff;border-color:var(--primary,#0ea5e9);box-shadow:0 0 0 4px rgba(14,165,233,.18)}
.jfm-step.done{color:var(--success)}
.jfm-step.done .jfm-dot{background:var(--success);color:#fff;border-color:var(--success)}
.jfm-link{flex:1 1 auto;height:2px;background:var(--bg3);margin:0 4px;margin-bottom:16px}
.jfm-link.done{background:var(--success)}

.tn-card{margin-top:18px;border-radius:var(--r);padding:16px;background:linear-gradient(135deg,rgba(99,102,241,.16),rgba(14,165,233,.10));border:1px solid rgba(99,102,241,.25)}
.tn-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}
.tn-title{font-size:15px;font-weight:800;color:var(--txt)}
.tn-sub{font-size:11px;color:var(--txt3)}
.tn-stats{display:flex;gap:10px;margin-bottom:12px}
.tn-stat{flex:1;text-align:center;background:var(--bg2);border-radius:12px;padding:10px 4px}
.tn-stat b{display:block;font-size:22px;font-weight:800;color:var(--primary,#0ea5e9);line-height:1.1}
.tn-stat span{font-size:11px;color:var(--txt3);font-weight:600}
.tn-routes{display:flex;flex-direction:column;gap:6px}
.tn-route{display:flex;justify-content:space-between;align-items:center;width:100%;text-align:left;background:var(--bg2);border:none;border-radius:10px;padding:10px 12px;cursor:pointer;color:var(--txt)}
.tn-route:active{transform:scale(.99)}
.tn-route-main{display:flex;align-items:center;gap:8px;min-width:0}
.tn-route-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tn-route-meta{font-size:12px;color:var(--txt3);font-weight:600;flex:0 0 auto;margin-left:8px}
.tn-live{font-size:10px;font-weight:800;color:var(--success)}
.wt-card{margin-top:18px;border-radius:var(--r);padding:16px;background:var(--bg2);border:1px solid var(--bg3)}
.wt-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.wt-title{font-size:15px;font-weight:800;color:var(--txt)}
.wt-link{background:none;border:none;color:var(--primary,#0ea5e9);font-size:12px;font-weight:700;cursor:pointer}
.wt-status{font-size:13px;margin-bottom:10px;color:var(--txt2)}
.wt-status.on{color:var(--success)}
.wt-status b{color:var(--txt);font-weight:800}
.wt-stats{display:flex;justify-content:space-between;margin-top:12px;font-size:12px;color:var(--txt3)}
.wt-stats b{color:var(--txt);font-weight:800}
.wt-warn{margin-top:10px;font-size:11px;font-weight:700;color:#b91c1c;background:rgba(239,68,68,.12);border-radius:8px;padding:7px 10px}
.wt-viol{font-size:10px;font-weight:800;color:var(--danger)}
.tn-foot{font-size:11px;color:var(--txt3);text-align:center;margin-top:10px}
.tn-mix{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.tn-chip{font-size:11px;font-weight:600;color:var(--txt2);background:var(--bg2);border-radius:8px;padding:4px 9px;white-space:nowrap}
.tn-chip b{color:var(--primary,#0ea5e9);font-weight:800}
.tn-chip-more{color:var(--txt3)}
.tn-refresh{display:inline-flex;align-items:center;gap:5px;background:var(--bg2);border:none;border-radius:20px;padding:5px 10px;font-size:11px;font-weight:700;color:var(--txt2);cursor:pointer}
.tn-refresh span{color:var(--txt3);font-weight:600}
.tn-refresh.spin{animation:spin 1s linear infinite}

.drawer{position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .25s}
.drawer.open{opacity:1;pointer-events:auto}
.drawer-card{margin-top:auto;background:var(--surface-drawer);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-top:1px solid var(--glass-border);border-radius:28px 28px 0 0;padding:14px 20px calc(var(--safe-bottom) + 22px);max-height:90vh;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .32s cubic-bezier(.22,1,.36,1);box-shadow:0 -12px 50px rgba(0,0,0,.4)}
.drawer.open .drawer-card{transform:translateY(0)}
.drawer-handle{width:48px;height:5px;border-radius:3px;background:var(--bg3);margin:0 auto 16px;cursor:pointer;position:relative}.drawer-handle::before{content:"";position:absolute;left:-60px;right:-60px;top:-14px;bottom:-14px}.drawer-x{position:absolute;top:10px;right:14px;width:38px;height:38px;border-radius:50%;background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);color:var(--txt);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;font-weight:300;line-height:1;z-index:5;transition:transform .15s,background .15s}.drawer-x:hover{background:var(--bg3)}.drawer-x:active{transform:scale(.9)}.more-options{margin:14px 0 6px;border-radius:14px;background:var(--card);border:1px solid var(--glass-border);overflow:hidden}.more-options>summary{cursor:pointer;list-style:none;padding:13px 16px;font-weight:700;font-size:14px;color:var(--txt2);display:flex;align-items:center;justify-content:space-between;user-select:none}.more-options>summary::-webkit-details-marker{display:none}.more-options>summary::after{content:"BE";font-size:13px;opacity:.6;transition:transform .2s}.more-options[open]>summary::after{transform:rotate(180deg)}.more-options[open]>summary{border-bottom:1px solid var(--glass-border)}.more-options>*:not(summary){padding:0 14px 12px;margin-top:10px}.load-tabs{display:flex;gap:6px;margin:6px 0 14px;padding:5px;background:var(--bg2);border-radius:12px}.load-tabs button{flex:1;border:0;background:transparent;color:var(--txt2);padding:9px 6px;border-radius:9px;font-weight:700;font-size:13px;cursor:pointer;transition:background .15s,color .15s}.load-tabs button{position:relative;overflow:hidden}.load-tabs button.on{background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);color:#fff;box-shadow:0 4px 14px -4px var(--primary),0 2px 4px rgba(0,0,0,.2);transform:translateY(-1px);}.load-tabs button.on::after{content:"";position:absolute;inset:0;border-radius:9px;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,0) 55%);}.load-item{display:flex;align-items:center;gap:10px;padding:10px 4px;border-bottom:1px solid var(--glass-border)}.load-item:last-child{border-bottom:0}.load-item-icon{width:34px;height:34px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:9px;background:var(--bg2);font-size:18px}.load-item-body{flex:1;min-width:0}.load-item-name{font-weight:600;font-size:14px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.load-item-sub{font-size:11px;color:var(--txt3);margin-top:2px;text-transform:uppercase;letter-spacing:.04em}.load-item-qty{font-weight:800;font-size:18px;color:var(--primary);text-align:right;min-width:48px}.load-item-qty small{font-weight:600;font-size:11px;color:var(--txt3);margin-left:3px}.load-cat-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:10px;background:var(--bg2);font-size:12px;font-weight:700;color:var(--txt2)}.load-cat-chip b{color:var(--txt);font-size:13px}.load-trip-blk{margin-bottom:14px;border-radius:14px;background:var(--card);border:1px solid var(--glass-border);overflow:hidden}.load-trip-blk>header{padding:11px 14px;background:var(--bg2);font-weight:700;display:flex;justify-content:space-between;align-items:center}.load-trip-blk>header b{font-size:15px}.load-trip-blk>div{padding:4px 14px 8px}
.drawer-title{font-size:22px;font-weight:800;margin-bottom:3px;letter-spacing:-.02em}
.drawer-sub{font-size:13px;color:var(--txt3);margin-bottom:18px;font-weight:500}
.drawer-body{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;padding:0 2px 4px;margin:-2px}
.drawer-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}

/* Multi-stop list inside the trip drawer */
.stop-list{padding:0;overflow:hidden}
.stop-row{display:flex;align-items:flex-start;gap:12px;padding:14px 14px;border-bottom:1px solid rgba(255,255,255,.06);cursor:pointer;transition:background .12s;touch-action:pan-y;will-change:transform}
.stop-row:last-child{border-bottom:none}
.stop-row:active{background:rgba(255,255,255,.04)}
.stop-row.stop-state-done{opacity:.6}
.stop-row.stop-state-failed{background:color-mix(in srgb,var(--red) 8%,transparent)}
.stop-row.stop-state-skipped{opacity:.45}
.stop-seq{flex:0 0 32px;height:32px;border-radius:50%;background:var(--bg3);color:var(--txt);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800}
.ord-bar{display:flex;gap:7px;margin:2px 2px 8px}
.ord-btn{flex:1;padding:9px 6px;border-radius:11px;border:1px solid var(--glass-border);background:var(--card);color:var(--txt);font-weight:700;font-size:12.5px;cursor:pointer}
.ord-btn:active{transform:scale(.97)}
.ro-list{display:flex;flex-direction:column;gap:7px;max-height:55vh;overflow-y:auto}
.ro-row{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:12px;background:var(--card);border:1px solid var(--glass-border)}
.ro-num{flex:0 0 26px;height:26px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px}
.ro-addr{flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ro-addr small{display:block;font-weight:600;color:var(--txt3);font-size:11px;margin-top:1px}
.ro-arrows{display:flex;gap:4px}
.ro-arrows button{width:38px;height:34px;border-radius:9px;border:1px solid var(--glass-border);background:var(--bg2);color:var(--txt);font-size:15px;cursor:pointer}
.ro-arrows button:active{background:var(--primary);color:#fff}
.ex-lbl{display:block;font-size:11px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.04em;margin:10px 2px 4px}
.ex-in{width:100%;padding:12px 14px;border-radius:11px;border:1px solid var(--glass-border);background:var(--glass);color:var(--txt);font-size:15px;font-family:inherit}
.ex-in:focus{outline:none;border-color:var(--accent)}
.ex-hint{font-size:12px;color:var(--txt3);margin:12px 2px 6px}
.ex-cands{display:flex;flex-direction:column;gap:6px}
.ex-cand{text-align:left;padding:11px 13px;border-radius:11px;border:1px solid var(--glass-border);background:var(--card);color:var(--txt);font-size:13.5px;font-weight:600;cursor:pointer}
.ex-cand.on{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);font-weight:800}
.ocr-ov{position:fixed;inset:0;z-index:4500;display:flex;flex-direction:column;background:#000}
.ocr-bar{display:flex;align-items:center;gap:12px;padding:calc(env(safe-area-inset-top,0) + 10px) 14px 10px;background:rgba(0,0,0,.6)}
.ocr-title{color:#fff;font-weight:800;font-size:14px}
.ocr-view{position:relative;flex:1;overflow:hidden;background:#000}
.ocr-view video{width:100%;height:100%;object-fit:cover}
.ocr-box{position:absolute;left:6%;right:6%;top:34%;height:32%;border:2px solid rgba(255,255,255,.9);border-radius:12px;box-shadow:0 0 0 100vmax rgba(0,0,0,.45)}
.ocr-readout{padding:14px 16px;background:rgba(0,0,0,.8);color:#fff;font-size:14px;min-height:30px;text-align:center}
.ocr-readout b{color:#7dd3fc}
.ocr-actions{padding:12px 16px calc(env(safe-area-inset-bottom,0) + 16px);background:#000}
.ct-add{display:flex;gap:8px;margin-top:10px}
.ct-add .btn{flex:1}
.ct-list{display:flex;flex-direction:column;gap:6px;max-height:42vh;overflow-y:auto}
.ct-row{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:11px;background:var(--card);border:1px solid var(--glass-border)}
.ct-n{flex:0 0 24px;height:24px;border-radius:50%;background:var(--success,#16a34a);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:11px}
.ct-a{flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ct-empty{text-align:center;color:var(--txt3);font-size:13px;padding:18px 10px}
.stop-row.stop-state-done .stop-seq{background:var(--green);color:#fff}
.stop-row.stop-state-failed .stop-seq{background:var(--red);color:#fff}
.stop-row.stop-state-arrived .stop-seq,.stop-row.stop-state-en_route .stop-seq{background:var(--amber);color:#fff}
.stop-main{flex:1;min-width:0}
.stop-title{font-weight:700;font-size:14px;color:var(--txt);line-height:1.3}
.stop-addr{font-size:12px;color:var(--txt3);margin-top:2px;line-height:1.4}
.stop-item{font-size:12.5px;font-weight:700;color:var(--accent,#6ea8fe);margin-top:3px}
.stop-sub{font-size:11px;color:var(--txt3);margin-top:4px;font-weight:600}
.stop-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.stop-icon-btn{width:36px;height:36px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:15px;cursor:pointer;color:var(--txt)}
.stop-icon-btn:active{background:color-mix(in srgb,var(--primary) 18%,transparent)}
.stop-instr{margin-top:7px;padding:8px 11px;border-radius:9px;background:color-mix(in srgb,var(--warn,#f59e0b) 22%,transparent);border-left:3px solid var(--warn,#f59e0b);color:var(--txt);font-size:12.5px;font-weight:600;line-height:1.5}
.stop-instr .ti{display:block;font-size:10.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;opacity:.8;margin-bottom:2px}
.stop-row.stop-state-done .stop-instr,.stop-row.stop-state-failed .stop-instr{opacity:.85}
.bldg-card{border-bottom:1px solid rgba(255,255,255,.06);border-left:4px solid var(--warn,#f59e0b);background:color-mix(in srgb,var(--warn,#f59e0b) 7%,transparent)}
.bldg-hdr{display:flex;align-items:center;gap:10px;padding:13px 12px;background:color-mix(in srgb,var(--warn,#f59e0b) 18%,transparent);cursor:pointer}
.bldg-ico{font-size:22px}
.bldg-hdr .bldg-main{flex:1;min-width:0}
.bldg-name{font-weight:800;font-size:15.5px}
.bldg-sub{font-size:12px;font-weight:700;color:var(--warn,#f59e0b)}
.bldg-chev{flex:0 0 auto;font-size:15px;color:var(--warn,#f59e0b);font-weight:800;transition:transform .15s}
.bldg-card.bldg-open{background:color-mix(in srgb,var(--warn,#f59e0b) 10%,transparent)}
.bldg-card.bldg-open .bldg-hdr{background:color-mix(in srgb,var(--warn,#f59e0b) 26%,transparent)}
.bldg-all-btn{display:block;width:calc(100% - 24px);margin:8px 12px 10px;padding:11px;border-radius:11px;background:var(--success);color:#fff;border:none;font-weight:800;font-size:14px}
.bldg-units{padding:2px 0}
.bldg-unit{display:flex;align-items:center;gap:8px;padding:9px 12px 9px 14px;border-top:1px solid rgba(255,255,255,.04)}
.bldg-unit .bu-main{flex:1;min-width:0;display:flex;flex-direction:column}
.bu-seq{flex:0 0 auto;min-width:30px;height:30px;border-radius:9px;background:color-mix(in srgb,var(--primary) 20%,transparent);color:var(--txt);font-weight:800;font-size:12.5px;display:flex;align-items:center;justify-content:center}
.bu-label{font-weight:700;font-size:13.5px}
.bu-rec{display:block;font-size:11.5px;color:var(--txt2)}
.bu-item{display:block;font-size:12px;font-weight:700;color:var(--accent,#6ea8fe);margin-top:1px}
.bu-instr{font-size:11px;color:var(--warn,#f59e0b);font-weight:600;margin-top:2px}
.bu-btn{flex:0 0 auto;width:38px;height:38px;border-radius:11px;font-size:16px;font-weight:800;border:1px solid var(--glass-border);background:var(--glass);color:var(--txt)}
.bu-deliver{background:var(--success);color:#fff;border-color:transparent}
.bu-prob{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 40%,transparent)}
.focus-card{position:sticky;bottom:10px;z-index:6;margin:14px 2px 6px;padding:11px 14px;border-radius:18px;background:color-mix(in srgb,var(--primary) 13%,var(--bg2,#10141c));border:1px solid var(--glass-border);box-shadow:0 10px 30px rgba(0,0,0,.5);backdrop-filter:blur(10px);touch-action:pan-y;will-change:transform}
.focus-top{display:flex;align-items:center;gap:11px}
.focus-seq{flex:0 0 auto;width:42px;height:42px;border-radius:13px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px}
.focus-meta{flex:1;min-width:0}
.focus-addr{font-weight:700;font-size:16.5px;line-height:1.2}
.focus-addr2{font-size:12px;color:var(--txt3);margin-top:2px}
.focus-item{font-size:14px;font-weight:800;color:var(--accent,#6ea8fe);margin-top:4px}
.focus-rec{font-size:12.5px;color:var(--txt2);margin-top:2px}
.focus-prox{display:inline-block;font-size:12.5px;font-weight:700;color:var(--txt3);margin-top:5px}
.focus-prox.prox-near{color:var(--warn,#f59e0b)}
/* ONLY the "you are at the spot" pill turns green — nothing else */
.focus-prox.prox-here{color:#fff;background:#16a34a;font-size:14px;font-weight:800;padding:6px 14px;border-radius:999px;margin-top:6px;animation:proxpulse 1.1s ease-in-out infinite}
@keyframes proxpulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.6)}50%{box-shadow:0 0 0 9px rgba(34,197,94,0)}}
.bu-nav{color:var(--accent,#6ea8fe)}
.focus-left{font-size:11px;color:var(--txt3);margin-top:3px}
.focus-cam{flex:0 0 auto;width:46px;height:46px;border-radius:13px;background:var(--glass);border:1px solid var(--glass-border);font-size:19px;color:var(--txt)}
.focus-photo{margin-top:8px;font-size:12px;font-weight:700;color:var(--warn,#f59e0b)}
.focus-btns{display:flex;gap:10px;margin-top:11px}
.focus-btn{flex:1;padding:14px 8px;border-radius:14px;font-size:16px;font-weight:800;border:none;cursor:pointer}
.focus-prob{flex:0 0 38%;background:color-mix(in srgb,var(--danger) 20%,transparent);color:var(--danger);border:1px solid color-mix(in srgb,var(--danger) 45%,transparent)}
.focus-deliver{background:var(--success);color:#fff}
.focus-partial-link{color:var(--warn,#f59e0b);font-weight:700;cursor:pointer;text-decoration:underline;text-underline-offset:2px}
.focus-hint{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px;color:var(--txt3);margin-top:9px}
.sh{display:inline-flex;align-items:center;gap:3px;font-weight:800;font-size:12px;letter-spacing:.02em}
.sh-prob{color:#f0566b}
.sh-deliver{color:#2fd07a}
.sh-arrows{display:inline-flex}
.sh-arrows i{font-style:normal;font-size:16px;line-height:1;opacity:.2}
.sh-deliver .sh-arrows i{animation:shflowR 1.15s infinite}
.sh-prob .sh-arrows i{animation:shflowL 1.15s infinite}
.sh-deliver .sh-arrows i:nth-child(1){animation-delay:0s}
.sh-deliver .sh-arrows i:nth-child(2){animation-delay:.14s}
.sh-deliver .sh-arrows i:nth-child(3){animation-delay:.28s}
.sh-prob .sh-arrows i:nth-child(3){animation-delay:0s}
.sh-prob .sh-arrows i:nth-child(2){animation-delay:.14s}
.sh-prob .sh-arrows i:nth-child(1){animation-delay:.28s}
@keyframes shflowR{0%,100%{opacity:.18;transform:translateX(-2px)}50%{opacity:1;transform:translateX(2px)}}
@keyframes shflowL{0%,100%{opacity:.18;transform:translateX(2px)}50%{opacity:1;transform:translateX(-2px)}}
@media (prefers-reduced-motion:reduce){.sh-arrows i{animation:none!important;opacity:.6}}
.fuel-banner{position:fixed;left:10px;right:10px;bottom:14px;z-index:60;padding:14px 16px;border-radius:16px;background:color-mix(in srgb,var(--warn,#f59e0b) 20%,var(--bg2,#10141c));border:1px solid var(--warn,#f59e0b);box-shadow:0 12px 34px rgba(0,0,0,.55);backdrop-filter:blur(10px)}
.fuel-banner-txt{font-size:14px;font-weight:600;line-height:1.45;margin-bottom:11px}
.fuel-banner-btns{display:flex;gap:8px}
.fuel-banner-btns .btn{flex:1}
.perk-card{padding:18px;border-radius:18px;background:linear-gradient(135deg,color-mix(in srgb,var(--success) 18%,var(--bg2,#10141c)),color-mix(in srgb,var(--primary) 12%,var(--bg2,#10141c)));border:1px solid color-mix(in srgb,var(--success) 35%,transparent)}
.perk-big{font-size:30px;font-weight:800;color:var(--success);line-height:1}
.perk-sub{font-size:13.5px;color:var(--txt);margin-top:8px;line-height:1.5}
.perk-hint{font-size:11.5px;color:var(--txt3);margin-top:8px}
.chat-badge{display:inline-block;min-width:18px;height:18px;line-height:18px;padding:0 5px;border-radius:9px;background:var(--danger);color:#fff;font-size:11px;font-weight:800;text-align:center;margin-left:6px}
.chat-badge.hidden{display:none}
.chat-card{display:flex;flex-direction:column;height:80vh;max-height:80vh;padding:0}
.chat-hdr{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--glass-border);font-weight:800;font-size:16px}
.chat-body{flex:1;overflow-y:auto;padding:14px 14px 4px;display:flex;flex-direction:column;gap:8px}
.chat-msg{display:flex}
.chat-msg.me{justify-content:flex-end}
.chat-bubble{max-width:78%;padding:9px 12px;border-radius:14px;font-size:14px;line-height:1.4;background:var(--glass);border:1px solid var(--glass-border)}
.chat-msg.me .chat-bubble{background:var(--primary);color:#fff;border-color:transparent}
.chat-when{font-size:10px;opacity:.65;margin-top:3px}
.chat-input{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--glass-border)}
.chat-input input{flex:1;padding:11px 12px;border-radius:12px;border:1px solid var(--glass-border);background:var(--glass);color:var(--txt);font-size:14px}
.chat-input button{padding:11px 16px;border-radius:12px;border:none;background:var(--primary);color:#fff;font-weight:700}

.scan-wrap{display:flex;flex-direction:column;align-items:center;padding:20px 18px}
.scan-frame{width:100%;max-width:340px;aspect-ratio:1;background:#000;border-radius:var(--r);position:relative;overflow:hidden;margin-bottom:20px;border:2px solid var(--bg3);box-shadow:var(--shadow-lg)}
.scan-frame video,.scan-frame canvas{width:100%;height:100%;object-fit:cover}
.scan-frame.idle{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(14,165,233,.08))}
.scan-frame.idle svg{width:72px;height:72px;stroke:var(--txt4);fill:none;stroke-width:1.5;opacity:.5}
.scan-overlay{position:absolute;inset:14%;border:3px solid var(--primary);border-radius:var(--r3);box-shadow:0 0 0 9999px rgba(0,0,0,.3),0 0 30px var(--primary);pointer-events:none;animation:scanGlow 2s ease-in-out infinite}
@keyframes scanGlow{0%,100%{box-shadow:0 0 0 9999px rgba(0,0,0,.3),0 0 30px var(--primary)}50%{box-shadow:0 0 0 9999px rgba(0,0,0,.3),0 0 50px var(--primary)}}
.scan-title{font-size:22px;font-weight:800;margin-bottom:8px;text-align:center;letter-spacing:-.02em}
.scan-sub{font-size:13px;color:var(--txt3);text-align:center;max-width:320px;margin-bottom:20px;line-height:1.6;font-weight:500}
.login-or{width:100%;display:flex;align-items:center;gap:12px;margin:22px 0 14px;color:var(--txt4);font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}
.login-or::before,.login-or::after{content:"";flex:1;height:1px;background:var(--bg3)}
.phone-login{width:100%;display:flex;flex-direction:column;gap:10px}
.phone-login .input{margin:0}
.pl-hint{font-size:13px;color:var(--txt2);text-align:center;margin:2px 0 4px;line-height:1.5}
/* ── Sign-in screen (unauthenticated) ───────────────────────────── */
.cf-unauth .topbar,.cf-unauth .bottom-nav,.cf-unauth .sos-pill,.cf-unauth #install-banner{display:none!important}
.login-wrap{display:flex;flex-direction:column;justify-content:center;gap:8px;padding:32px 22px;min-height:100vh;max-width:440px;margin:0 auto}
.login-brand{text-align:center;margin-bottom:28px;display:flex;flex-direction:column;align-items:center;gap:10px}
.login-logo{width:74px;height:74px;border-radius:22px;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:33px;box-shadow:0 12px 34px color-mix(in srgb,var(--primary) 42%,transparent)}
.login-brand-name{font-size:24px;font-weight:800;letter-spacing:-.02em}
.login-brand-sub{font-size:13px;color:var(--txt3);font-weight:600;margin-top:-4px}
.login-methods{display:flex;flex-direction:column;gap:12px}
.login-method{display:flex;align-items:center;gap:14px;padding:17px 16px;background:var(--bg2);border:1px solid var(--bg3);border-radius:16px;cursor:pointer;text-align:left;transition:transform .15s,border-color .15s}
.login-method:active{transform:scale(.985)}
.login-method:hover{border-color:color-mix(in srgb,var(--primary) 55%,var(--bg3))}
.login-method .lm-ic{width:46px;height:46px;flex-shrink:0;border-radius:13px;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center}
.login-method .lm-ic svg{width:23px;height:23px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.login-method .lm-tx{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}
.login-method .lm-tx b{font-size:16px;font-weight:700}
.login-method .lm-tx i{font-size:12.5px;color:var(--txt3);font-style:normal;line-height:1.4}
.login-method .lm-arrow{color:var(--txt4);font-size:22px;font-weight:700;flex-shrink:0}
.login-pane{display:flex;flex-direction:column;align-items:center}
.login-back{align-self:flex-start;background:none;border:none;color:var(--txt3);font-size:14px;font-weight:600;cursor:pointer;padding:2px 0 18px}
.login-pane-title{font-size:19px;font-weight:800;text-align:center;margin-bottom:6px;align-self:stretch}
.login-pane-sub{font-size:13px;color:var(--txt3);text-align:center;margin-bottom:18px;line-height:1.5;align-self:stretch}
.input{width:100%;background:var(--glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border);border-radius:var(--r2);padding:14px 16px;color:var(--txt);font-size:15px;outline:none;margin-bottom:8px;font-weight:500;transition:border-color .15s,box-shadow .15s}
.input:focus{border-color:var(--primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 18%,transparent)}

.profile-avatar{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:800;margin:14px auto 16px;color:#fff;box-shadow:0 10px 30px color-mix(in srgb,var(--primary) 35%,transparent),0 0 0 6px var(--glass)}
.profile-name{text-align:center;font-size:22px;font-weight:800;letter-spacing:-.02em}
.profile-sub{text-align:center;color:var(--txt3);font-size:13px;margin-bottom:22px;font-weight:600}

.unauth-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 28px;text-align:center;gap:18px;min-height:55vh}
.unauth-icon{width:96px;height:96px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 36px color-mix(in srgb,var(--primary) 40%,transparent)}
.unauth-icon svg{width:48px;height:48px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.map-frame{width:100%;height:calc(100vh - 240px);border:none;border-radius:var(--r);background:var(--bg2);box-shadow:var(--shadow-lg);border:1px solid var(--glass-border)}
.rmap-screen{height:100%;display:flex;flex-direction:column;position:relative;background:var(--bg)}
.rmap-bar{display:flex;align-items:center;gap:12px;padding:12px 16px 10px;background:var(--card);border-bottom:1px solid var(--glass-border)}
.rmap-title{font-weight:800;font-size:15px;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rmap-host{flex:1;width:100%;background:var(--bg2);min-height:200px}
.rmap-nav{position:absolute;left:14px;right:14px;bottom:14px;z-index:5;padding:15px;border:0;border-radius:14px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);color:#fff;font-weight:800;font-size:15px;box-shadow:0 8px 24px -6px var(--primary);cursor:pointer}
.rmap-pin,.leaflet-div-icon{background:none;border:none}
.rmap-num{width:30px;height:30px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 6px rgba(0,0,0,.4);border:2px solid #fff}
.rmap-num>span{transform:rotate(45deg);display:block;font-weight:800;font-size:13px;line-height:1}
.rmap-instr{margin-top:10px;padding:10px 12px;border-radius:10px;background:rgba(217,119,6,.12);border:1px solid rgba(217,119,6,.35);color:var(--txt);font-size:13px;font-weight:600}
.rmap-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;padding:30px}
.rmap-empty-t{font-weight:800;font-size:17px;color:var(--txt)}
.rmap-empty-s{font-size:13px;color:var(--txt2);max-width:280px;line-height:1.5}
.eta-chip{background:color-mix(in srgb,var(--amber) 14%,transparent)!important;color:var(--amber)!important;font-weight:700;border-color:color-mix(in srgb,var(--amber) 25%,transparent)!important}
.co2-chip{background:color-mix(in srgb,var(--green) 12%,transparent)!important;color:var(--green)!important;font-weight:700;border-color:color-mix(in srgb,var(--green) 22%,transparent)!important}

.empty{text-align:center;padding:52px 18px;color:var(--txt4)}
.empty svg{width:56px;height:56px;stroke:var(--bg3);fill:none;stroke-width:1.5;margin-bottom:14px}
.empty>div{font-size:14px;font-weight:600}
.loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--txt4)}
.spin{animation:spin .9s linear infinite;width:26px;height:26px;stroke:var(--txt4);fill:none;stroke-width:2.5;stroke-linecap:round}
@keyframes spin{to{transform:rotate(360deg)}}

.toast{position:fixed;left:50%;bottom:calc(var(--safe-bottom) + 72px);transform:translateX(-50%) translateY(20px);background:var(--surface-toast);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--glass-border);color:#fff;padding:13px 20px;border-radius:24px;font-size:14px;font-weight:700;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:500;box-shadow:var(--shadow-lg);max-width:90vw;text-align:center;letter-spacing:-.01em}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.success{background:linear-gradient(135deg,var(--green),#16a34a);color:#fff;border-color:transparent}
.toast.error{background:linear-gradient(135deg,var(--red),var(--rose));color:#fff;border-color:transparent}

.install-banner{position:fixed;left:14px;right:14px;bottom:calc(var(--safe-bottom) + 60px);background:linear-gradient(135deg,color-mix(in srgb,var(--primary) 22%,transparent),color-mix(in srgb,var(--accent) 22%,transparent)),var(--surface-drawer);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid rgba(148,163,184,.25);border-radius:20px;padding:16px 18px 14px;z-index:70;box-shadow:0 20px 50px rgba(0,0,0,.5);animation:cfInstallSlide .45s cubic-bezier(.34,1.56,.64,1)}
@keyframes cfInstallSlide{0%{opacity:0;transform:translateY(40px)}100%{opacity:1;transform:translateY(0)}}
.install-banner.hidden{display:none!important}
.install-banner-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.install-banner-icon{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--accent));flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:22px;box-shadow:0 6px 18px color-mix(in srgb,var(--primary) 50%,transparent)}
.install-banner-text{flex:1;line-height:1.35}
.install-banner-text b{font-weight:800;color:var(--txt);font-size:15px;display:block;letter-spacing:-.01em}
.install-banner-text span{font-size:12px;color:var(--txt2);font-weight:500}
.install-banner-x{background:transparent;border:none;color:var(--txt4);cursor:pointer;font-size:18px;padding:4px 6px;border-radius:8px;line-height:1}
.install-banner-x:hover{color:var(--txt2);background:rgba(148,163,184,.1)}
.install-banner-perks{display:flex;gap:10px;margin-bottom:12px;padding:0 2px}
.install-banner-perks span{flex:1;font-size:11px;color:var(--txt2);font-weight:600;display:flex;align-items:center;gap:5px;line-height:1.3}
.install-banner-perks span::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);flex-shrink:0}
.install-banner-actions{display:flex;gap:8px}
.install-banner-actions button{flex:1;font-size:14px;padding:11px 16px;border-radius:12px;border:none;cursor:pointer;font-weight:700;transition:transform .1s,box-shadow .2s}
.install-banner-actions button:active{transform:scale(.97)}
.install-banner .btn-go{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;box-shadow:0 6px 16px color-mix(in srgb,var(--primary) 40%,transparent)}
.install-banner .btn-later{background:transparent;color:var(--txt3);border:1px solid var(--glass-border);flex:0 0 90px}

/* ── First-run welcome splash (after install) ───────────────────── */
.cf-splash{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;padding:24px;
    background:radial-gradient(circle at 30% 20%,rgba(14,165,233,.30),transparent 55%),
               radial-gradient(circle at 70% 80%,rgba(99,102,241,.28),transparent 55%),var(--surface-splash);
    animation:cfSplashIn .35s ease-out}
.cf-splash.show{display:flex}
@keyframes cfSplashIn{0%{opacity:0}100%{opacity:1}}
.cf-splash-card{background:var(--card);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
    border:1px solid rgba(148,163,184,.18);border-radius:28px;padding:34px 26px 26px;
    max-width:400px;width:100%;text-align:center;
    box-shadow:0 30px 70px rgba(0,0,0,.6);
    animation:cfSplashPop .55s cubic-bezier(.34,1.56,.64,1) .1s both}
@keyframes cfSplashPop{0%{opacity:0;transform:scale(.85) translateY(30px)}100%{opacity:1;transform:scale(1) translateY(0)}}
.cf-splash-logo{width:88px;height:88px;border-radius:22px;margin:0 auto 18px;
    background:linear-gradient(135deg,var(--primary),var(--accent));
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 12px 36px color-mix(in srgb,var(--primary) 50%,transparent);
    animation:cfLogoSpin .8s cubic-bezier(.34,1.56,.64,1) .2s both;color:#fff;font-weight:900;font-size:38px;letter-spacing:-.04em}
@keyframes cfLogoSpin{0%{transform:scale(0) rotate(-90deg)}100%{transform:scale(1) rotate(0)}}
.cf-splash-title{font-size:24px;font-weight:800;color:var(--txt);margin-bottom:8px;letter-spacing:-.4px}
.cf-splash-sub{font-size:14px;color:var(--txt2);margin-bottom:24px;line-height:1.5}
.cf-splash-list{text-align:left;margin-bottom:24px}
.cf-splash-list .row{display:flex;gap:12px;padding:10px 12px;border-radius:12px;background:rgba(148,163,184,.06);margin-bottom:8px;align-items:flex-start}
.cf-splash-list .row .ico{width:36px;height:36px;border-radius:10px;background:rgba(14,165,233,.18);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.cf-splash-list .row .txt{flex:1;font-size:13px;color:var(--txt2);line-height:1.4}
.cf-splash-list .row .txt b{display:block;color:var(--txt);font-weight:700;margin-bottom:2px;font-size:14px}
.cf-splash-cta{display:block;width:100%;padding:14px 18px;border:none;border-radius:14px;font-size:15px;font-weight:800;cursor:pointer;
    background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;
    box-shadow:0 8px 24px color-mix(in srgb,var(--primary) 45%,transparent);
    transition:transform .12s}
.cf-splash-cta:active{transform:scale(.97)}

.notif-item{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--r2);padding:13px 15px;margin-bottom:9px;border-left:4px solid var(--accent);cursor:pointer;transition:transform .12s}
.notif-item:active{transform:scale(.98)}
.notif-item.k-sla_breach,.notif-item.k-alarm,.notif-item.k-incident{border-left-color:var(--red)}
.notif-item.k-sla_warning,.notif-item.k-overspeed,.notif-item.k-harsh_brake,.notif-item.k-harsh_accel,.notif-item.k-harsh_corner{border-left-color:var(--amber)}
.notif-item.k-complaint_created{border-left-color:var(--primary)}
.notif-title{font-weight:800;font-size:13px;margin-bottom:3px;display:flex;justify-content:space-between;gap:8px;align-items:center;letter-spacing:-.01em}
.notif-body{font-size:12px;color:var(--txt3);line-height:1.45;font-weight:500}
.notif-meta{font-size:11px;color:var(--txt4);margin-top:7px;display:flex;justify-content:space-between;font-weight:600}

.harsh-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.harsh-btn{background:var(--glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);color:var(--txt);border-radius:var(--r2);padding:16px 8px;font-weight:700;font-size:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .12s,background .15s}
.harsh-btn:active{transform:scale(.94)}
.harsh-btn .ic{font-size:22px}

.chk-row{display:flex;align-items:center;justify-content:space-between;padding:14px 4px;border-bottom:1px solid rgba(255,255,255,.06);gap:12px}
.chk-row:last-child{border-bottom:none}
.chk-lbl{flex:1;font-size:14px;font-weight:600}
.chk-actions{display:flex;gap:6px;flex-shrink:0}
.chk-act{width:40px;height:40px;border-radius:50%;border:1px solid var(--bg3);background:var(--glass);color:var(--txt3);font-weight:800;cursor:pointer;font-size:16px;transition:transform .12s,background .15s,color .15s}
.chk-act:active{transform:scale(.9)}
.chk-act.ok.on{background:linear-gradient(135deg,var(--green),#16a34a);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(34,197,94,.35)}
.chk-act.fail.on{background:linear-gradient(135deg,var(--red),var(--rose));color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(239,68,68,.35)}

/* ── Slide-to-deliver ───────────────────────────────────────── */
.ss-slide{position:relative;height:56px;border-radius:28px;background:var(--glass);border:1px solid var(--bg3);margin-top:14px;overflow:hidden;user-select:none;-webkit-user-select:none}
.ss-slide-fill{position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,rgba(34,197,94,.25),rgba(34,197,94,.45));transition:none;border-radius:28px}
.ss-slide-thumb{position:absolute;left:4px;top:4px;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--green),#16a34a);color:#fff;font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(34,197,94,.45);cursor:grab;touch-action:none;z-index:2}
.ss-slide-thumb:active{cursor:grabbing}
.ss-slide-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--txt2);letter-spacing:.02em;pointer-events:none;z-index:1}
.ss-slide.almost .ss-slide-label{opacity:.35}
.ss-slide.complete{border-color:var(--green)}
.ss-slide.complete .ss-slide-label{opacity:0}
.ss-slide.locked{opacity:.55}
.ss-slide.locked .ss-slide-thumb{background:var(--bg3);color:var(--txt3);box-shadow:none;cursor:not-allowed}
.ss-slide.locked .ss-slide-label{color:var(--amber)}

/* ── Failed-delivery reason sheet ───────────────────────────── */
.ss-reasons{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}
.ss-reason{padding:13px 10px;border-radius:14px;border:1px solid var(--bg3);background:var(--glass);color:var(--txt);font-size:13px;font-weight:600;text-align:left;cursor:pointer;transition:border-color .15s,background .15s,transform .12s}
.ss-reason:active{transform:scale(.97)}
.ss-reason.sel{border-color:var(--red);background:color-mix(in srgb,var(--red) 16%,transparent);box-shadow:0 0 0 1px var(--red)}
.ss-reason.ss-delivered{border-color:color-mix(in srgb,var(--green) 50%,var(--bg3))}
.ss-reason.ss-delivered.sel{border-color:var(--green);background:color-mix(in srgb,var(--green) 16%,transparent);box-shadow:0 0 0 1px var(--green)}
.ss-note{width:100%;margin-top:12px;padding:12px 14px;border-radius:12px;border:1px solid var(--bg3);background:var(--glass);color:var(--txt);font-size:14px;font-family:inherit}
.ss-note:focus{outline:none;border-color:var(--accent)}
