:root{--bg:#0f1419;--surface:#1a2332;--surface2:#243044;--border:#334155;--text:#e2e8f0;--muted:#94a3b8;--accent:#38bdf8;--accent-dim:#38bdf826;--danger:#f87171;--ok:#4ade80;--warn:#fb923c;color:var(--text);background:var(--bg);font-family:system-ui,Segoe UI,Roboto,sans-serif;line-height:1.5}*{box-sizing:border-box}body{margin:0}#root{min-height:100vh}a{color:var(--accent)}.app-shell{grid-template-columns:220px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;gap:.25rem;padding:1rem 0;display:flex}.sidebar h1{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 1rem 1rem;font-size:.85rem;font-weight:600}.sidebar button{text-align:left;width:100%;color:var(--text);font:inherit;cursor:pointer;background:0 0;border:none;border-left:3px solid #0000;padding:.65rem 1rem;display:block}.sidebar button:hover{background:var(--surface2)}.sidebar button.active{background:var(--accent-dim);border-left-color:var(--accent);color:var(--accent)}.sidebar .logout{border-top:1px solid var(--border);margin-top:auto;padding:1rem}.sidebar .logout button{border:1px solid var(--border);text-align:center;border-radius:6px}.main{padding:1.5rem 2rem;overflow:auto}.main h2{margin:0 0 1rem;font-size:1.35rem;font-weight:600}.login-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;max-width:360px;margin:4rem auto;padding:2rem}.login-panel h1{margin:0 0 1.5rem;font-size:1.25rem}.login-panel label{color:var(--muted);margin-bottom:1rem;font-size:.85rem;display:block}.login-panel input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);font:inherit;border-radius:6px;margin-top:.35rem;padding:.5rem .65rem}.login-panel button[type=submit]{background:var(--accent);color:#0f172a;cursor:pointer;border:none;border-radius:6px;width:100%;margin-top:.5rem;padding:.65rem;font-weight:600}.login-panel .hint{color:var(--muted);margin-top:1rem;font-size:.8rem}.grid-stats{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1rem 1.15rem}.stat-card .label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem}.stat-card .value{margin-top:.35rem;font-size:1.5rem;font-weight:600}.stat-card .value.ok{color:var(--ok)}.stat-card .value.bad{color:var(--danger)}.feed{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.feed h3{border-bottom:1px solid var(--border);margin:0;padding:.85rem 1rem;font-size:.95rem}.feed ul{max-height:420px;margin:0;padding:0;list-style:none;overflow:auto}.feed li{border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.9rem}.feed-row{text-align:left;width:100%;color:inherit;font:inherit;cursor:pointer;background:0 0;border:none;padding:0}.feed-row:hover{text-decoration:underline}.feed li:last-child{border-bottom:none}.feed .sev-critical{color:#f87171}.feed .sev-major{color:#fb923c}.feed .sev-minor{color:#4ade80}.table-wrap{border:1px solid var(--border);background:var(--surface);border-radius:10px;overflow:auto}table{border-collapse:collapse;width:100%;font-size:.9rem}th,td{text-align:left;border-bottom:1px solid var(--border);padding:.65rem 1rem}th{background:var(--surface2);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:500}tr:last-child td{border-bottom:none}.btn-danger{border:1px solid var(--danger);color:var(--danger);cursor:pointer;background:0 0;border-radius:6px;padding:.35rem .65rem;font-size:.8rem}.btn-danger:hover{background:#f8717126}.form-panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;max-width:480px;margin-bottom:1.5rem;padding:1rem 1.25rem}.form-panel h3{margin:0 0 1rem;font-size:1rem}.form-row{margin-bottom:.75rem}.form-row label{color:var(--muted);margin-bottom:.25rem;font-size:.8rem;display:block}.form-row input,.form-row select{border:1px solid var(--border);background:var(--bg);width:100%;max-width:320px;color:var(--text);font:inherit;border-radius:6px;padding:.45rem .6rem}.form-panel button[type=submit]{background:var(--accent);color:#0f172a;cursor:pointer;border:none;border-radius:6px;margin-top:.5rem;padding:.5rem 1rem;font-weight:600}.segmented{gap:.5rem;margin-bottom:.75rem;display:flex}.segmented button{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:999px;padding:.35rem .7rem}.segmented button.active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.inline-row{align-items:center;gap:.5rem;display:flex}.inline-row button{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:.45rem .65rem}.search-results{gap:.35rem;max-height:170px;margin-top:.6rem;display:grid;overflow:auto}.search-results button{border:1px solid var(--border);color:var(--text);text-align:left;cursor:pointer;background:0 0;border-radius:6px;padding:.4rem .55rem;font-size:.82rem}.search-results button.active{border-color:var(--accent);background:var(--accent-dim)}.leaflet-box{border:1px solid var(--border);border-radius:10px;height:320px;overflow:hidden}.leaflet-box.corridor-route-map{height:520px;min-height:500px}.grid-manual-coords{grid-template-columns:repeat(2,1fr);gap:.65rem 1rem;margin-bottom:.5rem;display:grid}@media (width<=640px){.grid-manual-coords{grid-template-columns:1fr}}.leaflet-box.preview{height:240px}.map-loading{color:var(--muted);place-items:center;font-size:.9rem;display:grid}.confirm-box{border:1px dashed var(--border);border-radius:8px;margin:.5rem 0 .4rem;padding:.7rem .8rem;font-size:.88rem}.confirm-box h4{margin:0 0 .35rem;font-size:.9rem}.map-section{margin-bottom:2rem}.map-section h3{margin:0 0 .5rem;font-size:1rem}.highway-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.15rem 1.3rem}.highway-svg{width:100%;height:260px;display:block}.live-road{background:linear-gradient(#202e42 0%,#131d2b 100%)}.map-summary{flex-wrap:wrap;gap:.8rem;margin:.4rem 0 .75rem;display:flex}.map-summary span{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:.35rem .7rem;font-size:.85rem}.map-summary .critical{color:#f87171}.map-summary .active-amb{color:#4ade80}.live-map-panel{margin-top:.75rem}.live-map-view-toggle{border:1px solid var(--border);background:var(--surface);border-radius:10px;margin-bottom:.75rem;display:inline-flex;overflow:hidden}.live-map-view-toggle button{background:var(--surface);color:var(--muted);cursor:pointer;border:none;border-radius:0;width:auto;margin:0;padding:.45rem 1rem;font-size:.88rem;font-weight:600}.live-map-view-toggle button+button{border-left:1px solid var(--border)}.live-map-view-toggle button.active{background:var(--accent);color:var(--accent-contrast,#0f172a)}.live-map-view-toggle button:hover:not(.active){background:#94a3b81f}.live-map-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.8rem}.live-map-toolbar{justify-content:flex-end;margin-bottom:.55rem;display:flex}.highway-diagram-head{align-items:baseline;gap:.65rem;margin-bottom:.5rem;font-size:.92rem;display:flex}.highway-diagram-head .muted{font-size:.82rem;font-weight:500}.highway-svg-live{width:100%;height:auto;min-height:180px;max-height:240px;display:block}@media (width>=720px){.highway-svg-live{max-height:260px}}.hw-incident-dot{cursor:default}.hw-amb-svg{cursor:default;animation:2.2s ease-in-out infinite hw-amb-pulse}@keyframes hw-amb-pulse{0%,to{opacity:1}50%{opacity:.82}}.leaflet-box.live-leaflet-map{height:600px}.ambulance-marker{background:0 0;border:none}.ambulance-marker span{background:#0f172ae0;border-radius:50%;place-items:center;width:26px;height:26px;font-size:16px;display:inline-grid;box-shadow:0 0 0 1px #94a3b873}.err{color:var(--danger);margin:.5rem 0 0;font-size:.9rem}.modal-backdrop{z-index:20;background:#020617a6;place-items:center;display:grid;position:fixed;inset:0}.incident-modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:min(680px,94vw);max-height:85vh;padding:1rem 1.1rem;overflow:auto}.incident-modal-header{justify-content:space-between;align-items:center;margin-bottom:.8rem;display:flex}.incident-modal-header h3{margin:0}.incident-modal-header button{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:.25rem .6rem}.kv{grid-template-columns:140px 1fr;gap:.35rem .8rem;margin:0 0 1rem;display:grid}.kv dt{color:var(--muted)}.kv dd{margin:0}.vehicle-list{margin:0;padding-left:1rem}
