:root{--bg: #0b1020;--bg-2: #0e1530;--panel: #131c3a;--panel-2: #1a2548;--line: #2a3556;--text: #e8edff;--muted: #7c89ad;--good: #22c55e;--warn: #f5b301;--bad: #ef4444;--accent: #38bdf8;--radius: 14px;--mono: ui-monospace, "SF Mono", "Roboto Mono", Menlo, Consolas, monospace}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:radial-gradient(120% 80% at 50% 0%,#101a3a 0%,var(--bg) 60%);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior:none}.app{max-width:560px;margin:0 auto;padding:max(12px,env(safe-area-inset-top)) 14px max(16px,env(safe-area-inset-bottom)) 14px;display:flex;flex-direction:column;gap:14px}.app-head h1{margin:0;font-size:1.5rem;letter-spacing:.5px}.app-head .tag{font-size:.7rem;font-weight:600;color:var(--bg);background:var(--accent);padding:2px 8px;border-radius:999px;vertical-align:middle}.subtitle{margin:2px 0 0;color:var(--muted);font-size:.85rem}.hud{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;transition:border-color .25s,box-shadow .25s}.hud.running{border-color:var(--good);box-shadow:0 0 0 1px var(--good),0 0 28px -8px var(--good)}.hud.armed{border-color:var(--warn)}.hud-state{display:flex;align-items:center;gap:8px;font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}.hud-state .dot{width:10px;height:10px;border-radius:50%;background:var(--muted)}.hud-state.running{color:var(--good)}.hud-state.running .dot{background:var(--good);box-shadow:0 0 10px var(--good);animation:pulse 1.4s infinite}.hud-state.armed{color:var(--warn)}.hud-state.armed .dot{background:var(--warn);animation:pulse 1.4s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.hud-primary{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0 14px}.metric{text-align:center}.metric-value{font-size:clamp(2.6rem,13vw,4rem);font-weight:700;line-height:1;font-variant-numeric:tabular-nums}.metric-label{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:1.5px;margin-top:4px}.hud-secondary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}@media (max-width: 420px){.hud-secondary{grid-template-columns:repeat(2,1fr)}}.stat{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:8px;min-width:0}.stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}.stat-value{font-size:.95rem;font-weight:600;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-sub{font-size:.68rem;color:var(--muted);margin-top:1px}.hud-error{margin-top:10px;padding:8px 10px;border-radius:8px;background:#ef44441f;border:1px solid var(--bad);color:#ffd9d9;font-size:.82rem}.good{color:var(--good)}.warn{color:var(--warn)}.bad{color:var(--bad)}.mono{font-family:var(--mono)}.muted{color:var(--muted)}.controls{display:flex;flex-direction:column;gap:8px}.controls-row{display:flex;gap:8px}.controls-row .btn{flex:1}.controls-hint{margin:0;color:var(--muted);font-size:.8rem;text-align:center}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line);background:var(--panel-2);color:var(--text);font-size:1.05rem;font-weight:600;padding:16px 18px;border-radius:12px;cursor:pointer;transition:transform .05s,filter .15s,background .15s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--good);border-color:var(--good);color:#052012}.btn--danger{background:var(--bad);border-color:var(--bad);color:#2a0606}.btn--ghost{background:transparent}.btn--sm{font-size:.82rem;font-weight:600;padding:8px 12px;border-radius:9px}.capabilities{background:#f5b3011a;border:1px solid var(--warn);border-radius:10px;padding:8px 12px;font-size:.82rem;color:#ffe8b0}.settings{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:4px 14px}.settings>summary{cursor:pointer;padding:12px 0;font-weight:600;color:var(--muted);list-style:none}.settings>summary::-webkit-details-marker{display:none}.settings>summary:before{content:"⚙ "}.settings-body{display:flex;flex-direction:column;gap:4px;padding-bottom:12px}.settings-note{margin:0 0 6px;font-size:.8rem;color:var(--warn)}.field{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--line);font-size:.88rem}.field span em{color:var(--muted);font-style:normal;font-size:.78rem}.field input[type=number]{width:96px;background:var(--bg-2);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:8px;font-family:var(--mono);text-align:right}.field input[type=checkbox]{width:22px;height:22px;accent-color:var(--good)}.runs h2,.modal h2{font-size:1.1rem;margin:0 0 8px}.runlist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.runlist-item{display:flex;align-items:stretch;gap:6px;background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}.runlist-main{flex:1;text-align:left;background:transparent;border:none;color:var(--text);padding:12px;cursor:pointer}.runlist-when{font-weight:600;display:flex;align-items:center;gap:8px}.runlist-stats{display:flex;flex-wrap:wrap;gap:6px;color:var(--muted);font-size:.82rem;margin-top:3px}.runlist-del{border:none;border-left:1px solid var(--line);border-radius:0;color:var(--muted)}.badge{font-size:.65rem;padding:1px 7px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px}.badge--live{background:#f5b3012e;color:var(--warn);border:1px solid var(--warn)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#020612b3;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;z-index:50}@media (min-width: 560px){.modal-backdrop{align-items:center}}.modal{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:560px;max-height:92vh;overflow:auto;padding:14px}@media (min-width: 560px){.modal{border-radius:var(--radius)}}.modal-head{display:flex;align-items:center;justify-content:space-between;position:sticky;top:-14px;background:var(--bg-2);padding-top:4px;margin:-4px 0 8px}.charts{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media (max-width: 460px){.charts{grid-template-columns:1fr}}.charts figure{margin:0}.charts figcaption{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.trackview{width:100%;height:auto;display:block;border-radius:10px}.trackview--empty{height:120px;display:flex;align-items:center;justify-content:center;background:var(--bg-2);border:1px dashed var(--line);color:var(--muted);font-size:.85rem}.kv{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden;margin:14px 0}.kv-item{background:var(--panel);padding:8px 10px}.kv-item dt{color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.5px}.kv-item dd{margin:2px 0 0;font-weight:600;font-size:.95rem}.export-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.export-label{color:var(--muted);font-size:.85rem}.timeline{margin-top:14px}.timeline summary{cursor:pointer;color:var(--muted);font-weight:600}.timeline ul{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}.timeline li{display:flex;align-items:baseline;gap:8px;font-size:.82rem}.ev-time{color:var(--muted);flex:0 0 auto}.ev-type{font-weight:600}.ev-gps-acquired,.ev-started,.ev-motion-start,.ev-wakelock-acquired{color:var(--good)}.ev-gps-lost,.ev-gps-error,.ev-wakelock-failed,.ev-visibility-hidden{color:var(--warn)}.ev-finished{color:var(--accent)}.ev-detail{color:var(--muted)}.app-foot{display:flex;gap:8px;justify-content:center;color:var(--muted);font-size:.76rem;padding:6px 0 2px}.ahead{color:var(--good)}.behind{color:var(--bad)}.even{color:var(--muted)}.gold{color:#ffd34d}.tabs{display:flex;gap:6px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:4px}.tab{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;color:var(--muted);font-size:.9rem;font-weight:600;padding:10px;border-radius:9px;cursor:pointer}.tab--active{background:var(--panel-2);color:var(--text)}.tab:disabled{opacity:.4;cursor:not-allowed}.screen h2{font-size:1.1rem;margin:0 0 10px}.route-picker{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:10px}.field--route{border-bottom:none;padding:0}.route-picker select,.save-route select,.editable input,.field-inline input{background:var(--bg-2);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:9px 10px;font-size:.95rem;max-width:60%}.route-picker select{max-width:62%}.route-records{display:grid;grid-template-columns:1fr 1fr;gap:8px}.route-records--row{grid-template-columns:repeat(3,1fr);margin:8px 0}.route-empty{font-size:.84rem}.hud-route{margin-left:auto;color:var(--text);text-transform:none;letter-spacing:0;font-weight:600}.metric--delta .delta{font-size:clamp(2.8rem,14vw,4.4rem)}.hud-next{display:flex;align-items:baseline;gap:8px;font-size:.9rem;margin-bottom:8px}.next-label b{color:var(--text)}.next-dist{color:var(--muted);margin-left:6px}.next-count{margin-left:auto;color:var(--muted)}.next-elapsed{color:var(--muted)}.progress{height:6px;background:var(--bg-2);border-radius:999px;overflow:hidden;border:1px solid var(--line)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--good));transition:width .4s linear}.last-split{display:flex;justify-content:space-between;margin-top:8px;padding:6px 10px;border-radius:9px;background:var(--bg-2);border:1px solid var(--line);font-weight:600;font-size:.92rem}.last-split.gold{border-color:#ffd34d;box-shadow:0 0 18px -6px #ffd34d}.splittable{margin:6px 0 14px}.splittable-head{display:flex;align-items:center;gap:10px}.splittable-head h3{margin:0;font-size:1rem}.badge--pb{background:#22c55e2e;color:var(--good);border:1px solid var(--good)}.badge--base{background:#38bdf829;color:var(--accent);border:1px solid var(--accent);margin-left:8px;vertical-align:middle}table.splits{width:100%;border-collapse:collapse;font-size:.88rem}table.splits th{text-align:right;color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;padding:6px 8px;border-bottom:1px solid var(--line)}table.splits th:first-child{text-align:left}table.splits td{text-align:right;padding:7px 8px;border-bottom:1px solid var(--line)}table.splits td:first-child{text-align:left}table.splits tr.is-gold{background:#ffd34d14}table.splits tfoot td{font-weight:700;border-top:2px solid var(--line);border-bottom:none}.seg-flag{margin-left:5px;font-size:.8rem}.save-route-open{width:100%}.save-route{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.save-route h3{margin:0 0 2px;font-size:1rem}.save-route .field input,.save-route .field select{background:var(--bg-2);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:8px 10px;width:58%}.save-route-preview{margin:0;font-size:.84rem}.routes-screen{display:flex;flex-direction:column;gap:12px}.corridor-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:8px}.corridor-name input{font-size:1.05rem;font-weight:700;width:100%;background:transparent;border:none;color:var(--text);padding:2px 0}.corridor-name input:focus{outline:1px solid var(--line);border-radius:6px;padding:2px 6px}.route-card{background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:4px 12px}.route-card>summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px;padding:10px 0;font-weight:600}.route-card>summary::-webkit-details-marker{display:none}.route-card-pb{margin-left:auto;color:var(--good)}.route-card-body{padding-bottom:10px;display:flex;flex-direction:column;gap:8px}.route-card-body h4{margin:6px 0 0;font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.cp-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.cp-row{display:flex;align-items:center;gap:8px}.cp-row .editable{flex:1}.cp-row .editable input{width:100%;max-width:none;padding:6px 8px}.cp-gold{color:#ffd34d;font-size:.82rem;white-space:nowrap}.cp-seglen{color:var(--muted);margin-right:8px}.editable{display:flex;align-items:center;gap:8px}.field-inline{justify-content:space-between}.field-inline>span{color:var(--muted);font-size:.84rem}.route-actions{margin-top:4px}.tag--sim{background:#a855f7;color:#140524;margin-left:6px}.app--sim{max-width:1160px;display:grid;grid-template-columns:minmax(0,520px) minmax(0,1fr);gap:18px;align-items:start}.app-main{display:flex;flex-direction:column;gap:14px;min-width:0}.sim-pane{position:sticky;top:max(12px,env(safe-area-inset-top));min-width:0}@media (max-width: 720px){.app--sim{display:block;max-width:560px}.sim-pane{position:static;margin-top:14px}.sim-pane:before{content:"↥ Simulator is built for a desktop browser + keyboard.";display:block;color:var(--muted);font-size:.78rem;margin-bottom:6px}}.sim{background:var(--panel);border:1px solid #6d3bd1;border-radius:var(--radius);padding:10px;display:flex;flex-direction:column;gap:8px}.sim-bar{display:flex;align-items:center;gap:10px}.sim-tag{font-size:.7rem;font-weight:700;letter-spacing:.5px;color:#c4a3ff;text-transform:uppercase}.sim-readout{color:var(--text);font-size:.9rem}.sim-bar .btn{margin-left:auto}.sim-map{width:100%;height:auto;display:block;border-radius:10px;touch-action:none}.sim-bg{fill:#0a0f24}.sim-grid{stroke:#1b264a;stroke-width:1}.sim-route{fill:none;stroke:var(--accent);stroke-width:3;stroke-linecap:round;stroke-linejoin:round;opacity:.85}.sim-trail{fill:none;stroke:#ffd34d;stroke-width:2;stroke-linecap:round;opacity:.5}.sim-cp{fill:#1a2548;stroke:var(--accent);stroke-width:2}.sim-cp--start{stroke:var(--good)}.sim-cp--finish{stroke:var(--bad)}.sim-cp.is-done{fill:var(--good);stroke:var(--good)}.sim-cp.is-next{stroke:#ffd34d;stroke-width:3}.sim-cp-label{fill:var(--muted);font-size:10px;font-weight:600}.sim-car{fill:var(--text);stroke:#0a0f24;stroke-width:1.5}.sim-car.is-live{fill:var(--good)}.sim-north{fill:var(--muted);font-size:12px;font-weight:700}.sim-hint{margin:0;font-size:.78rem;color:var(--muted);line-height:1.4}.sim-hint b{color:var(--text)}
