:root{
  --bg:#0a0a0b; --surface:#141416; --surface-2:#1b1c20; --surface-3:#232429;
  --line:#2a2b30; --lime:#c8f54e; --lime-2:#b6e83a; --lime-ink:#0c0e06;
  --text:#f4f5f0; --muted:#8b8d88; --muted-2:#5f615d; --danger:#ff6b5e;
  --radius:26px; --radius-sm:18px;
  --nav-h:84px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  background:
    radial-gradient(700px 500px at 12% -5%, rgba(200,245,78,.08), transparent 55%),
    var(--bg);
  color:var(--text); overflow:hidden;
}
.app{max-width:480px;margin:0 auto;height:100dvh;display:flex;flex-direction:column;position:relative;background:var(--bg)}
.hidden{display:none!important}

/* scroll area */
main{flex:1;overflow-y:auto;scrollbar-width:none;padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom))}
main::-webkit-scrollbar{display:none}
.view{display:none;animation:fade .3s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* header */
.head{display:flex;align-items:center;justify-content:space-between;padding:calc(env(safe-area-inset-top) + 18px) 22px 14px}
.head h1{font-family:'Sora';font-size:21px;font-weight:700;letter-spacing:-.02em}
.head .sub{color:var(--muted);font-size:12.5px;margin-top:2px}
.avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#2a2b30,#15161a);display:grid;place-items:center;font-weight:700;color:var(--lime);border:1px solid var(--line);cursor:pointer}
.iconbtn{width:42px;height:42px;border-radius:14px;background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--text);cursor:pointer;font-size:18px}

/* map */
.map{margin:0 18px;border-radius:var(--radius);height:200px;overflow:hidden;border:1px solid var(--line);background:#0f1011;position:relative;z-index:0}
#adminMap,#homeMap{width:100%;height:100%}
.leaflet-control-attribution,.leaflet-control-zoom{display:none!important}
.maptag{position:absolute;left:14px;bottom:14px;z-index:500;background:rgba(10,10,11,.72);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:12px;padding:8px 12px;font-size:12px;display:flex;gap:8px;align-items:center}
.live{width:8px;height:8px;border-radius:50%;background:var(--lime);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(200,245,78,.5)}70%{box-shadow:0 0 0 10px rgba(200,245,78,0)}100%{box-shadow:0 0 0 0 rgba(200,245,78,0)}}
.carpin{background:var(--lime);width:26px;height:26px;border-radius:50% 50% 50% 2px;transform:rotate(45deg);box-shadow:0 0 0 6px rgba(200,245,78,.2)}

/* status card */
.statuscard{margin:16px 18px 0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.sc-top{display:flex;justify-content:space-between;align-items:flex-start}
.car-name{font-family:'Sora';font-weight:700;font-size:17px}
.plate{display:inline-block;margin-top:6px;font-size:11.5px;letter-spacing:.12em;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);padding:4px 9px;border-radius:8px}
.statepill{font-size:12px;font-weight:700;padding:7px 12px;border-radius:30px}
.statepill.free{background:rgba(200,245,78,.14);color:var(--lime)}
.statepill.busy{background:rgba(255,107,94,.14);color:var(--danger)}
.odo{margin-top:20px}
.odo .big{font-family:'Sora';font-weight:800;font-size:44px;letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}
.odo .unit{color:var(--muted);font-weight:600;font-size:14px}
.odo-label{color:var(--muted-2);font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.holder{margin-top:18px;display:flex;align-items:center;gap:11px;background:var(--surface-2);border:1px solid var(--line);border-radius:16px;padding:12px 14px}
.holder .dot{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--lime),var(--lime-2));display:grid;place-items:center;color:var(--lime-ink);font-weight:800;font-size:13px}
.holder small{display:block;color:var(--muted);font-size:11px}
.holder b{font-size:13.5px}

.action{margin:18px 18px 0}
.bigbtn{width:100%;border:0;border-radius:22px;padding:19px;font:800 16px 'Sora';letter-spacing:-.01em;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:transform .12s;color:var(--lime-ink)}
.bigbtn:active{transform:scale(.975)}
.bigbtn.take{background:var(--lime);box-shadow:0 14px 30px -12px rgba(200,245,78,.6)}
.bigbtn.drop{background:#fff;color:#111}
.bigbtn.ghost{background:var(--surface-2);color:var(--text);border:1px solid var(--line)}
.bigbtn[disabled]{opacity:.5;pointer-events:none}

.qrow{display:flex;gap:12px;margin:16px 18px 0}
.qstat{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:15px}
.qstat .n{font-family:'Sora';font-weight:800;font-size:22px;letter-spacing:-.02em}
.qstat .l{color:var(--muted);font-size:11px;margin-top:3px}

.sect{display:flex;justify-content:space-between;align-items:center;margin:24px 22px 12px}
.sect h2{font-family:'Sora';font-size:14px;font-weight:700}
.sect a{color:var(--lime);font-size:12px;font-weight:600;text-decoration:none;cursor:pointer}

/* trips */
.trip{margin:0 18px 12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:17px}
.trip .row1{display:flex;justify-content:space-between;align-items:center}
.trip .id{font-family:'Sora';font-weight:700;font-size:15px}
.tag{font-size:10.5px;font-weight:700;padding:5px 10px;border-radius:20px}
.tag.done{background:rgba(200,245,78,.13);color:var(--lime)}
.tag.open{background:rgba(255,107,94,.13);color:var(--danger)}
.tag.forced{background:rgba(255,170,80,.14);color:#ffaa50}
.trip .cust{color:var(--muted);font-size:12.5px;margin-top:7px}
.trip .legs{display:flex;align-items:center;gap:10px;margin-top:14px}
.leg{flex:1}.leg small{color:var(--muted-2);font-size:10.5px;text-transform:uppercase;letter-spacing:.1em}
.leg b{display:block;font-size:13px;margin-top:3px;font-variant-numeric:tabular-nums}
.leg.r{text-align:right}
.chev{color:var(--lime);letter-spacing:-2px;font-weight:700}
.trip .meta{display:flex;gap:14px;flex-wrap:wrap;margin-top:14px;padding-top:13px;border-top:1px solid var(--line);font-size:11.5px;color:var(--muted)}
.trip .meta b{color:var(--text)}
.trip .meta .park{margin-left:auto;color:var(--lime);font-weight:700;cursor:pointer}

/* fuel list */
.fuelitem{margin:0 18px 12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:15px 17px;display:flex;align-items:center;gap:14px}
.fuelitem .ic{width:42px;height:42px;border-radius:13px;background:var(--surface-2);display:grid;place-items:center;font-size:19px}
.fuelitem .amt{font-family:'Sora';font-weight:800;font-size:18px}
.fuelitem small{color:var(--muted);font-size:11.5px}
.lvlchip{margin-left:auto;font-size:11px;font-weight:700;color:var(--lime);background:rgba(200,245,78,.12);padding:5px 10px;border-radius:20px}

/* nav */
.nav{position:absolute;bottom:0;left:0;right:0;height:var(--nav-h);background:rgba(12,12,14,.9);backdrop-filter:blur(18px);border-top:1px solid var(--line);display:flex;justify-content:space-around;align-items:center;padding-bottom:env(safe-area-inset-bottom);z-index:40}
.nav button{background:0;border:0;color:var(--muted-2);display:flex;flex-direction:column;align-items:center;gap:5px;font:600 10px 'Plus Jakarta Sans';cursor:pointer}
.nav button svg{width:23px;height:23px;stroke:currentColor;fill:none;stroke-width:1.9}
.nav button.on{color:var(--lime)}
.nav .fab{width:56px;height:56px;border-radius:50%;background:var(--lime);color:var(--lime-ink);display:grid;place-items:center;margin-top:-26px;box-shadow:0 12px 26px -8px rgba(200,245,78,.7)}
.nav .fab svg{width:26px;height:26px;stroke-width:2.4}

/* sheet */
.sheet-wrap{position:absolute;inset:0;z-index:80;display:none}
.sheet-wrap.open{display:block}
.scrim{position:absolute;inset:0;background:rgba(0,0,0,.6);animation:fade .3s}
.sheet{position:absolute;left:0;right:0;bottom:0;background:var(--surface);border-radius:34px 34px 0 0;border-top:1px solid var(--line);padding:8px 22px calc(26px + env(safe-area-inset-bottom));max-height:92%;overflow-y:auto;scrollbar-width:none;animation:up .4s cubic-bezier(.2,.9,.25,1)}
.sheet::-webkit-scrollbar{display:none}
@keyframes up{from{transform:translateY(100%)}to{transform:none}}
.grab{width:42px;height:5px;border-radius:3px;background:var(--line);margin:10px auto 16px}
.sheet h3{font-family:'Sora';font-size:20px;font-weight:700;letter-spacing:-.02em}
.sheet .desc{color:var(--muted);font-size:12.5px;margin:5px 0 18px}

.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px}
.field input,.field textarea{width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:14px;padding:14px;color:var(--text);font:500 14px 'Plus Jakarta Sans';outline:none}
.field input:focus,.field textarea:focus{border-color:var(--lime)}
.field textarea{resize:none;height:74px}
.field .err{color:var(--danger);display:none;font-size:11px;margin-top:5px}
.autorow{display:flex;gap:10px}
.autotile{flex:1;background:var(--surface-2);border:1px solid var(--line);border-radius:14px;padding:12px 13px}
.autotile small{display:flex;align-items:center;gap:5px;color:var(--muted-2);font-size:10px;text-transform:uppercase;letter-spacing:.08em}
.autotile b{display:block;margin-top:5px;font-size:13.5px;font-variant-numeric:tabular-nums}
.gpsdot{width:6px;height:6px;border-radius:50%;background:var(--lime)}
.gpsdot.off{background:var(--danger)}
.locked{font-size:10px;color:var(--lime);margin-left:auto}

/* odometer scanner */
.scanner{position:relative;border-radius:18px;border:1.5px dashed var(--line);background:var(--surface-2);min-height:130px;display:grid;place-items:center;text-align:center;cursor:pointer;overflow:hidden}
.scanner .cam{font-size:26px}.scanner p{color:var(--muted);font-size:12px;margin-top:6px}
.scanner.scanning{border-color:var(--lime)}
.scanline{position:absolute;left:8%;right:8%;height:2px;background:var(--lime);box-shadow:0 0 12px var(--lime);top:0;opacity:0}
.scanner.scanning .scanline{animation:scan 1.1s ease-in-out infinite;opacity:1}
@keyframes scan{0%{top:14%}50%{top:86%}100%{top:14%}}
.scanner img.preview{width:100%;max-height:150px;object-fit:cover;border-radius:16px}
.detbadge{position:absolute;bottom:8px;left:8px;font-size:10px;color:var(--lime-ink);background:var(--lime);padding:3px 9px;border-radius:20px;font-weight:700}

.fuelbtns{display:flex;gap:8px}
.fbtn{flex:1;background:var(--surface-2);border:1px solid var(--line);border-radius:13px;padding:13px 4px;text-align:center;cursor:pointer;font:700 13px 'Sora'}
.fbtn small{display:block;font:500 9px 'Plus Jakarta Sans';color:var(--muted);margin-top:3px}
.fbtn.sel{background:var(--lime);color:var(--lime-ink);border-color:var(--lime)}
.fbtn.sel small{color:rgba(12,14,6,.7)}

/* slide to confirm */
.slide{position:relative;height:62px;border-radius:18px;background:var(--surface-2);border:1px solid var(--line);overflow:hidden;margin-top:10px;user-select:none}
.slide .fill{position:absolute;inset:0;width:62px;background:linear-gradient(90deg,var(--lime),var(--lime-2));border-radius:18px}
.slide .txt{position:absolute;inset:0;display:grid;place-items:center;font:700 14px 'Sora';color:var(--muted);pointer-events:none}
.knob{position:absolute;top:5px;left:5px;width:52px;height:52px;border-radius:14px;background:var(--lime);display:grid;place-items:center;color:var(--lime-ink);cursor:grab;touch-action:none;z-index:3;font-size:20px}

/* success */
.success{text-align:center;padding:14px 0 4px}
.tick{width:78px;height:78px;border-radius:50%;background:rgba(200,245,78,.14);display:grid;place-items:center;margin:6px auto 16px;animation:pop .45s cubic-bezier(.2,1.4,.4,1)}
@keyframes pop{from{transform:scale(0)}to{transform:none}}
.tick svg{width:38px;height:38px;stroke:var(--lime);fill:none;stroke-width:3;stroke-linecap:round}
.summ{background:var(--surface-2);border:1px solid var(--line);border-radius:16px;padding:4px 16px;margin:18px 0;text-align:left}
.summ .r{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line);font-size:13px}
.summ .r:last-child{border:0}.summ .r span{color:var(--muted)}.summ .r b{font-variant-numeric:tabular-nums}

/* toast */
.toast{position:absolute;top:calc(env(safe-area-inset-top) + 14px);left:18px;right:18px;background:rgba(20,21,24,.96);border:1px solid var(--line);border-left:3px solid var(--lime);border-radius:16px;padding:13px 15px;z-index:90;transform:translateY(-160%);transition:transform .45s cubic-bezier(.2,.9,.25,1)}
.toast.show{transform:none}
.toast b{font-size:13px;font-family:'Sora'}.toast small{display:block;color:var(--muted);font-size:11.5px;margin-top:2px}
.toast.err{border-left-color:var(--danger)}

/* admin */
.recent{margin:0 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.recent .ri{display:flex;gap:12px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line)}
.recent .ri:last-child{border:0}
.recent .ri .ic{width:34px;height:34px;border-radius:10px;background:var(--surface-2);display:grid;place-items:center;font-size:14px}
.recent .ri small{color:var(--muted);font-size:11px}.recent .ri b{font-size:13px}
.recent .ri .t{margin-left:auto;color:var(--muted-2);font-size:11px;white-space:nowrap}
.userrow{margin:0 18px 10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px 16px;display:flex;align-items:center;gap:12px}
.userrow .dot{width:38px;height:38px;border-radius:50%;background:var(--surface-2);display:grid;place-items:center;font-weight:700;color:var(--lime)}
.userrow small{color:var(--muted);font-size:11.5px;display:block}
.userrow .st{margin-left:auto;font-size:11px;font-weight:700;color:var(--lime)}
.userrow .st.off{color:var(--muted)}
.forceclose{margin:14px 18px 0;width:calc(100% - 36px);background:rgba(255,107,94,.1);border:1px solid rgba(255,107,94,.3);color:var(--danger);border-radius:16px;padding:14px;font:700 13px 'Sora';cursor:pointer}

/* login */
.login{height:100dvh;display:flex;flex-direction:column;justify-content:center;padding:32px 26px;gap:18px}
.login .brand{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.login .brand .mark{width:26px;height:16px;display:flex;gap:2px}
.login .brand .mark i{flex:1;background:var(--lime);transform:skewX(-20deg);border-radius:1px}
.login .brand .mark i:nth-child(2){opacity:.6}.login .brand .mark i:nth-child(3){opacity:.3}
.login h1{font-family:'Sora';font-size:28px;font-weight:800;letter-spacing:-.03em;line-height:1.1}
.login p{color:var(--muted);font-size:13px;margin-top:-8px}

.loader{width:20px;height:20px;border:2.5px solid rgba(12,14,6,.3);border-top-color:var(--lime-ink);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty{text-align:center;color:var(--muted-2);font-size:13px;padding:40px 30px}

/* ── fuel slider ── */
.fuel-slider-wrap{padding:4px 0 6px}
.fuel-track{position:relative;height:10px;background:var(--surface-3);border-radius:99px;margin:18px 0 6px;cursor:pointer}
.fuel-fill{position:absolute;left:0;top:0;height:100%;border-radius:99px;background:var(--lime);transition:width .12s,background .2s;pointer-events:none}
.fuel-knob{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:var(--lime);display:grid;place-items:center;font:700 13px 'Sora';color:var(--lime-ink);cursor:grab;touch-action:none;box-shadow:0 4px 14px rgba(0,0,0,.35);transition:left .08s,background .2s;left:-18px;user-select:none}
.fuel-knob:active{cursor:grabbing;transform:translateY(-50%) scale(1.1)}
.fuel-stops{display:flex;justify-content:space-between;padding:0 2px}
.fuel-stop-lbl{font:700 12px 'Sora';color:var(--muted-2);cursor:pointer;transition:color .15s;padding:2px 4px}
.fuel-stop-lbl.active{color:var(--lime)}
.fuel-readout{text-align:center;font-size:12px;color:var(--muted);margin-top:8px}
.fuel-readout b{color:var(--text)}

/* ── pills (zone + duration) ── */
.pill-row{display:flex;flex-wrap:wrap;gap:8px}
.pill{background:var(--surface-2);border:1px solid var(--line);border-radius:30px;padding:9px 16px;font:700 13px 'Sora';cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}
.pill.sel{background:var(--lime);color:var(--lime-ink);border-color:var(--lime)}
