
/* ═══ TOKENS ═══════════════════════════════════════════════════ */
:root {
  --bg:   #0b0d0c; --bg2: #111413; --bg3: #181c1a;
  --bg4:  #1f2421; --bg5: #252b27; --bg6: #2c332e;
  --ln:   rgba(255,255,255,0.06);
  --ln2:  rgba(255,255,255,0.11);
  --ln3:  rgba(255,255,255,0.19);
  --tx:   #dfe8e0; --tx2: #96a699; --mu: #5c6b5f;
  --acc:  #8fd44a; --acc2: #4ac8d4; --acc3: #d4944a;
  --dan:  #d45a5a; --ok: #4ad47a; --warn: #d4c44a;
  --r0:#8fd44a;--r1:#4ac8d4;--r2:#d4944a;--r3:#b44ad4;
  --r4:#d44a7a;--r5:#4ad494;--r6:#d4d44a;--r7:#4a78d4;--r8:#d4504a;
  --fui:'Syne',sans-serif; --fmono:'DM Mono',monospace;
  --rad:6px; --radl:12px; --radx:18px;
  --sbw:268px; --stw:282px; --tbh:50px; --chh:146px;
}
[data-theme="light"] {
  --bg:   #f4f5f2; --bg2: #ffffff; --bg3: #eeeee9;
  --bg4:  #e5e5df; --bg5: #d8d8d2; --bg6: #ccccc6;
  --ln:   rgba(0,0,0,0.07);
  --ln2:  rgba(0,0,0,0.13);
  --ln3:  rgba(0,0,0,0.22);
  --tx:   #1a1f1b; --tx2: #4a5a4d; --mu: #8a9a8d;
  --acc:  #5ba820; --acc2: #1a8a96; --acc3: #a06020;
  --dan:  #b03030; --ok: #1a8a4a; --warn: #907000;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg);color:var(--tx);font-family:var(--fmono);font-size:13px;overflow:hidden;-webkit-font-smoothing:antialiased}
button{font-family:var(--fmono);cursor:pointer}
input,select,textarea{font-family:var(--fmono)}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:2px}

/* ═══ LAYOUT ════════════════════════════════════════════════════ */
#app{display:grid;grid-template-rows:var(--tbh) 1fr;height:100vh}
#main{display:grid;grid-template-columns:var(--sbw) 1fr var(--stw);overflow:hidden;height:calc(100vh - var(--tbh))}

/* ═══ TOPBAR ════════════════════════════════════════════════════ */
#topbar{display:flex;align-items:center;gap:12px;padding:0 16px;background:var(--bg2);border-bottom:1px solid var(--ln);z-index:500;flex-shrink:0}
.logo{font-family:var(--fui);font-size:17px;font-weight:800;letter-spacing:-.04em;color:var(--acc);flex-shrink:0}
.logo em{color:var(--tx);font-style:normal}
.vsep{width:1px;height:20px;background:var(--ln2);flex-shrink:0}
.tagline{font-size:10px;color:var(--mu);letter-spacing:.08em;text-transform:uppercase}
.tbr{margin-left:auto;display:flex;align-items:center;gap:7px}
.chip{font-size:10px;padding:3px 9px;border-radius:99px;background:var(--bg3);border:1px solid var(--ln2);color:var(--tx2);white-space:nowrap;flex-shrink:0}
.chip.on{border-color:var(--acc);color:var(--acc)}
.chip.warn{border-color:var(--warn);color:var(--warn)}
.chip.danger{border-color:var(--dan);color:var(--dan)}
.btn{font-size:11px;font-weight:500;padding:5px 12px;border-radius:var(--rad);border:1px solid var(--ln2);background:var(--bg3);color:var(--tx);transition:all .15s}
.btn:hover{background:var(--bg4);border-color:var(--ln3)}
.btn.primary{background:var(--acc);color:#0b0d0c;border-color:var(--acc);font-weight:700}
.btn.primary:hover{background:#a8e862}
.btn.ghost{background:transparent;border-color:transparent;color:var(--tx2)}
.btn.ghost:hover{color:var(--tx);background:var(--bg3)}
.btn.dbtn{border-color:var(--dan);color:var(--dan)}
.btn.dbtn:hover{background:rgba(212,90,90,.1)}

/* ═══ SIDEBAR ═══════════════════════════════════════════════════ */
#sidebar{background:var(--bg2);border-right:1px solid var(--ln);display:flex;flex-direction:column;overflow:hidden}
.ph{padding:11px 13px 9px;border-bottom:1px solid var(--ln);display:flex;align-items:center;gap:8px;flex-shrink:0}
.pt{font-family:var(--fui);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--mu);flex:1}
#rides-list{flex:1;overflow-y:auto;padding:7px;display:flex;flex-direction:column;gap:5px}

/* Ride card */
.rc{border:1px solid var(--ln);border-radius:var(--radl);padding:8px 10px 7px;transition:border-color .15s,background .15s;position:relative;overflow:hidden;cursor:pointer}
.rc::after{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--rc,var(--acc));border-radius:3px 0 0 3px}
.rc:hover{border-color:var(--ln2);background:var(--bg3)}
.rc.sel{border-color:var(--rc,var(--acc)) !important;background:var(--bg4) !important;box-shadow:inset 0 0 0 1px var(--rc,var(--acc))}
.rc.fad{opacity:.32}
.rc-hd{display:flex;align-items:center;gap:7px;margin-bottom:6px}
.rc-dot{width:7px;height:7px;border-radius:50%;background:var(--rc);flex-shrink:0}
.rc-nm{font-family:var(--fui);font-size:12px;font-weight:700;color:var(--tx);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rc-acts{display:flex;gap:3px}
.ibb{width:20px;height:20px;border-radius:4px;border:1px solid var(--ln);background:transparent;color:var(--mu);display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .12s;flex-shrink:0}
.ibb:hover{border-color:var(--ln3);color:var(--tx);background:var(--bg5)}
.ibb.rm:hover{border-color:var(--dan);color:var(--dan)}
.rc-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px 8px}
.rc-kv{font-size:10px;color:var(--mu)}
.rc-kv b{color:var(--tx2);font-weight:400}

/* Drop zone */
#dz{margin:7px;border:1px dashed var(--ln2);border-radius:var(--radl);padding:16px 12px;text-align:center;cursor:pointer;transition:all .2s;flex-shrink:0}
#dz:hover,#dz.ov{border-color:var(--acc);background:rgba(143,212,74,.04)}
.dz1{font-family:var(--fui);font-size:12px;font-weight:700;color:var(--tx);margin-bottom:2px}
.dz2{font-size:10px;color:var(--mu)}
#fi{display:none}

/* DB badge */
#db-badge{margin:0 7px 7px;padding:6px 10px;border-radius:var(--rad);border:1px solid var(--ln);background:var(--bg3);font-size:10px;color:var(--mu);display:flex;align-items:center;gap:6px;flex-shrink:0;cursor:pointer;transition:border-color .15s}
#db-badge:hover{border-color:var(--ln2)}
#dbdot{width:6px;height:6px;border-radius:50%;background:var(--mu);flex-shrink:0}
#dbdot.ok{background:var(--ok)}
#dbdot.warn{background:var(--warn)}

/* ═══ MAP ════════════════════════════════════════════════════════ */
#map-panel{display:flex;flex-direction:column;position:relative;overflow:hidden}
#map{flex:1;min-height:0;background:var(--bg)}
#mc{position:absolute;top:10px;right:10px;z-index:400;display:flex;gap:4px}
.mb{font-size:10px;padding:4px 9px;border-radius:var(--rad);border:1px solid rgba(255,255,255,.12);background:rgba(11,13,12,.82);color:var(--tx2);cursor:pointer;transition:all .12s;backdrop-filter:blur(6px)}
.mb:hover{color:var(--tx);border-color:rgba(255,255,255,.22)}
.mb.on{border-color:var(--acc);color:var(--acc)}
#mhl{position:absolute;z-index:401;background:var(--bg2);border:1px solid var(--ln3);border-radius:var(--rad);padding:4px 8px;font-size:10px;color:var(--tx);pointer-events:none;display:none;white-space:nowrap}

/* ═══ CHART STRIP ════════════════════════════════════════════════ */
#cs{height:var(--chh);background:var(--bg2);border-top:1px solid var(--ln);padding:7px 12px 5px;display:flex;flex-direction:column;gap:5px;flex-shrink:0}
.csh{display:flex;align-items:center;gap:8px}
.cst{font-size:10px;color:var(--mu);text-transform:uppercase;letter-spacing:.08em}
.cts{display:flex;gap:3px;margin-left:auto}
.ct{font-size:10px;padding:2px 8px;border-radius:4px;border:1px solid var(--ln);background:transparent;color:var(--mu);cursor:pointer;transition:all .12s}
.ct.on{border-color:var(--acc2);color:var(--acc2);background:rgba(74,200,212,.07)}
#cw{flex:1;position:relative;min-height:0}

/* ═══ STATS PANEL ════════════════════════════════════════════════ */
#sp{background:var(--bg2);border-left:1px solid var(--ln);display:flex;flex-direction:column;overflow:hidden}
.stabs{display:flex;border-bottom:1px solid var(--ln);flex-shrink:0}
.stab{flex:1;padding:9px 4px;text-align:center;font-size:10px;color:var(--mu);cursor:pointer;border-bottom:2px solid transparent;transition:all .12s;text-transform:uppercase;letter-spacing:.07em;font-weight:600}
.stab:hover{color:var(--tx2)}
.stab.on{color:var(--acc);border-bottom-color:var(--acc)}
#sb{flex:1;overflow-y:auto;padding:9px;display:flex;flex-direction:column;gap:7px}

/* Stat blocks */
.sblk{background:var(--bg3);border:1px solid var(--ln);border-radius:var(--radl);padding:8px 10px}
.slbl{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--mu);margin-bottom:6px;font-weight:600}
.sbr{display:flex;align-items:center;gap:5px;margin-bottom:4px}
.sbd{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.sbn{width:65px;font-size:9px;color:var(--mu);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}
.sbb{flex:1;height:3px;background:var(--bg5);border-radius:2px;overflow:hidden}
.sbf{height:100%;border-radius:2px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.sbv{width:54px;font-size:10px;color:var(--tx2);text-align:right;flex-shrink:0}
.sbv.best{font-weight:500}

/* Vitals */
.vsec{margin-bottom:4px}
.vsect{font-size:9px;text-transform:uppercase;letter-spacing:.1em;padding:4px 0 6px;border-bottom:1px solid var(--ln);margin-bottom:6px;font-weight:600}
.vg{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-bottom:7px}
.vc{background:var(--bg4);border:1px solid var(--ln);border-radius:var(--rad);padding:7px 8px}
.vcl{font-size:9px;color:var(--mu);margin-bottom:3px}
.vcv{font-size:13px;font-weight:500;color:var(--tx)}
.vcv.a{color:var(--acc)}.vcv.b{color:var(--acc2)}.vcv.c{color:var(--acc3)}.vcv.d{color:var(--dan)}
.zr{display:flex;align-items:center;gap:5px;margin-bottom:3px}
.zl{font-size:9px;color:var(--mu);width:44px;flex-shrink:0}
.zbg{flex:1;height:4px;background:var(--bg5);border-radius:2px}
.zf{height:100%;border-radius:2px}
.zp{font-size:9px;color:var(--tx2);width:28px;text-align:right;flex-shrink:0}

/* Plan */
.ins{background:var(--bg4);border:1px solid var(--ln);border-radius:var(--rad);padding:8px 10px;font-size:10px;line-height:1.65;color:var(--tx2)}
.ins b{color:var(--tx);font-weight:500}
.insl{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--mu);margin-bottom:4px;font-weight:600}

/* Empty */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:20px}
.ei{font-size:26px;opacity:.18;margin-bottom:8px}
.et{font-family:var(--fui);font-size:13px;font-weight:700;color:var(--mu);margin-bottom:4px}
.es{font-size:10px;color:var(--mu);opacity:.6;line-height:1.7;max-width:180px}

/* ═══ MODAL ══════════════════════════════════════════════════════ */
#mb{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:800;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
#mb.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--ln3);border-radius:var(--radx);padding:22px;width:430px;max-width:96vw;max-height:92vh;overflow-y:auto;animation:mIn .2s ease}
@keyframes mIn{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}
.mt{font-family:var(--fui);font-size:16px;font-weight:800;color:var(--tx);margin-bottom:3px}
.ms{font-size:11px;color:var(--mu);margin-bottom:18px;line-height:1.6}
.fr{margin-bottom:11px}
.fl{font-size:10px;color:var(--mu);text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px;display:block}
.fi2{width:100%;padding:8px 10px;background:var(--bg3);border:1px solid var(--ln2);border-radius:var(--rad);color:var(--tx);font-size:12px;outline:none;transition:border-color .15s}
.fi2:focus{border-color:var(--acc)}
.fh{font-size:10px;color:var(--mu);margin-top:4px;line-height:1.5}
.ma{display:flex;gap:8px;justify-content:flex-end;margin-top:18px}
.msec{border-top:1px solid var(--ln);padding-top:14px;margin-top:14px}
.mst{font-size:10px;color:var(--mu);text-transform:uppercase;letter-spacing:.08em;margin-bottom:9px;font-weight:600}
pre.sql{font-size:9px;color:var(--mu);background:var(--bg3);padding:8px;border-radius:var(--rad);overflow:auto;line-height:1.5;border:1px solid var(--ln)}

/* Auth sections inside modal */
.auth-provider-btns{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.auth-btn{display:flex;align-items:center;gap:10px;padding:9px 14px;border-radius:var(--rad);border:1px solid var(--ln2);background:var(--bg3);color:var(--tx);font-size:12px;width:100%;transition:all .15s;cursor:pointer}
.auth-btn:hover{background:var(--bg4);border-color:var(--ln3)}
.auth-btn svg{width:18px;height:18px;flex-shrink:0}
.auth-divider{display:flex;align-items:center;gap:8px;margin:10px 0;font-size:10px;color:var(--mu)}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--ln2)}

/* Admin panel */
.admin-row{display:flex;align-items:center;gap:8px;padding:7px 9px;background:var(--bg3);border-radius:var(--rad);border:1px solid var(--ln);margin-bottom:5px;font-size:11px}
.admin-name{flex:1;color:var(--tx)}
.admin-email{font-size:10px;color:var(--mu);width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-time{font-size:9px;color:var(--mu);width:70px;text-align:right;flex-shrink:0}
.status-badge{font-size:9px;padding:2px 7px;border-radius:99px;flex-shrink:0}
.sb-pending{background:rgba(212,196,74,.12);border:1px solid var(--warn);color:var(--warn)}
.sb-approved{background:rgba(74,212,122,.12);border:1px solid var(--ok);color:var(--ok)}
.sb-denied{background:rgba(212,90,90,.12);border:1px solid var(--dan);color:var(--dan)}

/* ═══ TOAST ══════════════════════════════════════════════════════ */
#toast{position:fixed;bottom:16px;left:50%;transform:translateX(-50%) translateY(52px);background:var(--bg3);border:1px solid var(--ln3);color:var(--tx);font-size:11px;padding:7px 16px;border-radius:99px;z-index:900;transition:transform .22s;pointer-events:none;white-space:nowrap}
#toast.show{transform:translateX(-50%) translateY(0)}
#toast.err{border-color:var(--dan);color:var(--dan)}
#toast.ok{border-color:var(--ok);color:var(--ok)}

/* ═══ LOADER ═════════════════════════════════════════════════════ */
#ldr{position:fixed;inset:0;background:rgba(11,13,12,.85);z-index:700;display:none;align-items:center;justify-content:center;flex-direction:column;gap:12px}
#ldr.open{display:flex}
.ls{width:26px;height:26px;border:2px solid var(--ln2);border-top-color:var(--acc);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.lm{font-size:11px;color:var(--mu)}

/* ═══ LEAFLET OVERRIDES ══════════════════════════════════════════ */
.leaflet-container{background:var(--bg) !important}
.leaflet-control-zoom a{background:var(--bg3) !important;color:var(--tx2) !important;border-color:var(--ln2) !important}
.leaflet-control-zoom a:hover{color:var(--tx) !important;background:var(--bg4) !important}
.leaflet-control-attribution{background:rgba(11,13,12,.75) !important;color:var(--mu) !important;font-size:9px !important}
.leaflet-control-attribution a{color:var(--mu) !important}

@keyframes fadeUp{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.rc{animation:fadeUp .18s ease}

/* ═══ MOBILE ═════════════════════════════════════════════════ */
@media (max-width: 768px) {
  :root { --sbw:0px; --stw:0px }
  #main { grid-template-columns:1fr }
  #sidebar { display:none; position:fixed; left:0; top:var(--tbh); bottom:0;
    width:82vw; max-width:300px; z-index:600 }
  #sidebar.mob-open { display:flex !important }
  #sp { display:none; position:fixed; right:0; top:var(--tbh); bottom:0;
    width:82vw; max-width:290px; z-index:600 }
  #sp.mob-open { display:flex !important }
  .tagline,.vsep { display:none }
  #btn-mob-sb, #btn-mob-st { display:flex !important }
}
#btn-mob-sb, #btn-mob-st { display:none }

