
/* ═══ TOKENS ═══════════════════════════════════════════════════ */
:root {
  --bg:   #121212; --bg2: #1a1a1a; --bg3: #242424;
  --bg4:  #2d2d2d; --bg5: #363636; --bg6: #404040;
  --ln:   rgba(255,255,255,0.08);
  --ln2:  rgba(255,255,255,0.12);
  --ln3:  rgba(255,255,255,0.2);
  --tx:   #f0f0f0; --tx2: #b0b0b0; --mu: #b0b0b0;
  --card-border: #333333;
  --acc:  #a4e263; --acc2: #66d4e2; --acc3: #e2b466;
  --dan:  #e26666; --ok: #66e28a; --warn: #e2d466;
  --r0:#a4e263;--r1:#66d4e2;--r2:#e2b466;--r3:#b466e2;
  --r4:#e266b4;--r5:#66e2a4;--r6:#e2e266;--r7:#66a2e2;--r8:#e26666;
  --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:   #f8f9f7; --bg2: #ffffff; --bg3: #f0f0eb;
  --bg4:  #e5e5df; --bg5: #d8d8d2; --bg6: #cccccc;
  --ln:   rgba(0,0,0,0.07);
  --ln2:  rgba(0,0,0,0.13);
  --ln3:  rgba(0,0,0,0.22);
  --tx:   #1a1a1a; --tx2: #595959; --mu: #595959;
  --card-border: #e5e5df;
  --acc:  #5ba820; --acc2: #1a8a96; --acc3: #a06020;
  --dan:  #b03030; --ok: #1a8a4a; --warn: #907000;
  --r0:#78b030;--r1:#1a8a96;--r2:#a06020;--r3:#8040b0;
  --r4:#b04080;--r5:#30a060;--r6:#a0a030;--r7:#4060b0;--r8:#b03030;
}
*,*::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:14px;line-height:1.5;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:flex;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:12px;font-weight:600;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:#121212;border-color:var(--acc);font-weight:800}
.btn.primary:hover{background:var(--acc2)}
.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;width:var(--sbw);flex-shrink:0;transition:width 300ms, margin 300ms, padding 300ms}
.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:13px;font-weight:600;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(--card-border);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:13px;color:var(--mu);font-weight:400}
.rc-kv b{color:var(--tx2);font-weight:700;font-size:16px}

/* 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;flex-grow:1}
#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;box-shadow:0 2px 8px rgba(0,0,0,.3);font-weight:600}

/* ═══ 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;width:var(--stw);flex-shrink:0;transition:width 300ms, margin 300ms, padding 300ms}
.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:13px;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:13px;color:var(--mu);margin-bottom:3px;font-weight:600}
.vcv{font-size:16px;font-weight:700;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;animation:fadeUp .3s ease}
.ei{font-size:32px;opacity:.25;margin-bottom:12px;filter:grayscale(.3)}
.et{font-family:var(--fui);font-size:14px;font-weight:700;color:var(--mu);margin-bottom:6px}
.es{font-size:11px;color:var(--mu);opacity:.7;line-height:1.7;max-width:200px}

/* ═══ 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; transition:transform .2s ease;
    transform:translateX(-100%); box-shadow:4px 0 12px rgba(0,0,0,.3) }
  #sidebar.mob-open { display:flex !important; transform:translateX(0) !important }
  #sp { display:none; position:fixed; right:0; top:var(--tbh); bottom:0;
    width:82vw; max-width:290px; z-index:600; transition:transform .2s ease;
    transform:translateX(100%); box-shadow:-4px 0 12px rgba(0,0,0,.3) }
  #sp.mob-open { display:flex !important; transform:translateX(0) !important }
  .tagline,.vsep { display:none }
  #btn-mob-sb, #btn-mob-st { display:flex !important }
  /* Close button for mobile panels */
  .mob-close { display:block !important; position:absolute; top:8px; right:8px; z-index:10 }
  /* Overlay when panel is open */
  .mob-overlay { display:block !important; position:fixed; inset:0; background:rgba(0,0,0,.5);
    z-index:599; opacity:0; animation:fadeIn .2s forwards }
}
@keyframes fadeIn { from{opacity:0} to{opacity:1} }

#btn-mob-sb, #btn-mob-st { display:none }
.mob-close { display:none }
.mob-overlay { display:none }

/* ═══ UTILS ══════════════════════════════════════════════════════ */
.hidden{width:0 !important;margin:0 !important;padding:0 !important;overflow:hidden !important;border:none !important}
.toggle-btn{position:absolute;top:8px;right:8px;z-index:10;font-size:10px;padding:2px 6px;background:var(--bg4);color:var(--tx);border:1px solid var(--ln2);border-radius:4px;cursor:pointer;transition:all .15s}
#sidebar .toggle-btn{right:auto;left:8px}
.toggle-btn:hover{background:var(--bg5);color:var(--acc)}

.collapse-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;font-size:14px;padding:6px 2px;background:var(--bg4);color:var(--tx);border:1px solid var(--ln2);border-radius:4px;cursor:pointer;transition:all .15s}
#sidebar .collapse-btn{right:-20px;width:20px;text-align:center}
#sp .collapse-btn{left:-20px;width:20px;text-align:center}
.collapse-btn:hover{background:var(--bg5);color:var(--acc)}

.sidebar-collapsed{transform:translateX(-100%);transition:transform 300ms ease}
#sp.sidebar-collapsed{transform:translateX(100%)}

/* Segment rows */
.seg-row{display:flex;align-items:center;gap:6px;padding:6px 8px;background:var(--bg3);border-radius:var(--rad);border:1px solid var(--ln);margin-bottom:4px;cursor:pointer;transition:all .12s}
.seg-row:hover{background:var(--bg4);border-color:var(--ln2)}
.seg-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.3)}

