@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg-base: #080b10;--bg-surface: #0e1117;--bg-elevated: #141920;--bg-panel: #0e1117;--bg-hover: #1a2030;--bg-active: #1e2840;--bg-glass: rgba(14,17,23,.92);--border-subtle: rgba(255,255,255,.05);--border-default: rgba(255,255,255,.09);--border-strong: rgba(255,255,255,.16);--border-focus: rgba(74,158,255,.5);--text-primary: #f0f2f5;--text-secondary: #8a9ab8;--text-tertiary: #4e5f7a;--text-inverse: #080b10;--line-red: #BF0D3E;--line-blue: #009CDE;--line-orange: #ED8B00;--line-silver: #9EA2A2;--line-green: #00B140;--line-yellow: #FFD100;--line-bus: #F26B21;--status-critical: #f23d4f;--status-high: #f5823a;--status-moderate: #f5c842;--status-low: #4fc3f7;--status-info: #78909c;--status-ok: #26d98a;--status-degraded: #f5c842;--accent-primary: #4a9eff;--accent-secondary: #26d98a;--accent-rail: #818cf8;--accent-bus: #fb923c;--topbar-h: 52px;--leftpanel-w: 272px;--rightpanel-w: 330px;--aipanel-w: 370px;--bottompanel-h: 68px;--radius-xs: 3px;--radius-sm: 5px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--font-ui: "Inter", -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 12px rgba(0,0,0,.5);--shadow-lg: 0 8px 24px rgba(0,0,0,.6);--shadow-xl: 0 16px 40px rgba(0,0,0,.7)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden;background:var(--bg-base);color:var(--text-primary);font-family:var(--font-ui);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.app-shell{display:grid;grid-template-rows:var(--topbar-h) 1fr var(--bottompanel-h);grid-template-columns:var(--leftpanel-w) 1fr;grid-template-areas:"topbar topbar" "left   main" "left   bottom";height:100vh;width:100vw}.app-shell.ai-open{grid-template-columns:var(--leftpanel-w) 1fr var(--aipanel-w);grid-template-areas:"topbar topbar topbar" "left   main   ai" "left   bottom ai"}.topbar{grid-area:topbar;background:var(--bg-surface);border-bottom:1px solid var(--border-default);display:flex;align-items:center;padding:0 16px;gap:12px;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.left-panel{grid-area:left;background:var(--bg-panel);border-right:1px solid var(--border-default);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.map-area{grid-area:main;position:relative;overflow:hidden}.ai-panel{grid-area:ai;background:var(--bg-panel);border-left:1px solid var(--border-default);display:flex;flex-direction:column;overflow:hidden}.bottom-bar{grid-area:bottom;background:var(--bg-surface);border-top:1px solid var(--border-default);display:flex;align-items:center;padding:0 16px;gap:12px}.right-overlay{position:absolute;top:16px;right:16px;width:var(--rightpanel-w);max-height:calc(100% - 32px);z-index:50;pointer-events:none;display:flex;flex-direction:column;gap:10px}.right-overlay>*{pointer-events:all}.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}.brand-icon{width:30px;height:30px;background:linear-gradient(135deg,#4a9eff,#818cf8);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:15px;box-shadow:0 0 12px #4a9eff4d}.brand-name{font-size:13px;font-weight:700;color:var(--text-primary);letter-spacing:.06em;text-transform:uppercase}.brand-sub{font-size:10px;color:var(--text-tertiary);font-family:var(--font-mono);letter-spacing:.04em}.topbar-sep{width:1px;height:22px;background:var(--border-default);flex-shrink:0}.topbar-nav{display:flex;gap:2px}.nav-btn{background:none;border:1px solid transparent;color:var(--text-tertiary);font-family:var(--font-ui);font-size:11px;font-weight:500;padding:5px 11px;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.05em;text-transform:uppercase;transition:all .15s;white-space:nowrap}.nav-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-default)}.nav-btn.active{background:#4a9eff1f;color:var(--accent-primary);border-color:#4a9eff59}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.feed-indicator{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary)}.feed-dot{width:6px;height:6px;border-radius:50%;background:var(--status-ok);box-shadow:0 0 6px var(--status-ok);animation:pulse-dot 2s infinite}.feed-dot.stale{background:var(--status-degraded);box-shadow:none;animation:none}.feed-dot.error{background:var(--status-critical);box-shadow:none;animation:none}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 6px var(--status-ok)}50%{opacity:.5;box-shadow:0 0 2px var(--status-ok)}}.health-badge{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.08em;padding:3px 9px;border-radius:var(--radius-xs);text-transform:uppercase}.health-badge.normal{background:#26d98a1a;color:var(--status-ok);border:1px solid rgba(38,217,138,.25)}.health-badge.degraded{background:#f5c8421a;color:var(--status-degraded);border:1px solid rgba(245,200,66,.25)}.health-badge.critical{background:#f23d4f1a;color:var(--status-critical);border:1px solid rgba(242,61,79,.25);animation:blink-badge 1s infinite}@keyframes blink-badge{0%,to{opacity:1}50%{opacity:.6}}.ai-toggle-btn{display:flex;align-items:center;gap:6px;background:none;border:1px solid var(--border-default);color:var(--text-secondary);font-family:var(--font-ui);font-size:11px;font-weight:600;padding:5px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.05em}.ai-toggle-btn:hover,.ai-toggle-btn.active{background:#4a9eff1a;color:var(--accent-primary);border-color:#4a9eff66;box-shadow:0 0 12px #4a9eff26}.panel-section{padding:12px 14px;border-bottom:1px solid var(--border-subtle)}.panel-section:last-child{border-bottom:none}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.section-title{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary)}.section-count{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);background:var(--bg-hover);padding:1px 7px;border-radius:10px;border:1px solid var(--border-subtle)}.map-legend{display:flex;flex-direction:column;gap:6px}.legend-item{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-secondary)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-line{width:18px;height:3px;border-radius:2px;flex-shrink:0}.legend-square{width:10px;height:10px;border-radius:2px;flex-shrink:0}.filter-chips{display:flex;gap:5px;flex-wrap:wrap}.chip{font-size:11px;font-weight:500;letter-spacing:.02em;padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all .15s;font-family:var(--font-ui);white-space:nowrap}.chip:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.chip.active{background:#4a9eff26;color:var(--accent-primary);border-color:#4a9eff66}.chip.chip-rail.active{background:#818cf826;color:var(--accent-rail);border-color:#818cf866}.chip.chip-bus.active{background:#fb923c26;color:var(--accent-bus);border-color:#fb923c66}.chip.chip-critical.active{background:#f23d4f26;color:var(--status-critical);border-color:#f23d4f59}.chip.chip-high.active{background:#f5823a26;color:var(--status-high);border-color:#f5823a59}.chip.chip-moderate.active{background:#f5c84226;color:var(--status-moderate);border-color:#f5c84259}.chip.chip-danger{background:#f23d4f14;color:var(--status-critical);border-color:#f23d4f40}.chip.chip-danger:hover{background:#f23d4f26}.route-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;border:1px solid transparent;margin-bottom:2px}.route-item:hover{background:var(--bg-hover);border-color:var(--border-subtle)}.route-item.selected{background:var(--bg-active);border-color:#4a9eff4d}.route-badge{font-family:var(--font-mono);font-size:10px;font-weight:700;padding:3px 6px;border-radius:var(--radius-xs);flex-shrink:0;text-align:center;min-width:32px;letter-spacing:.02em}.route-name{font-size:11px;color:var(--text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.route-meta{display:flex;align-items:center;gap:4px;margin-top:2px}.route-instability{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);flex-shrink:0;min-width:24px;text-align:right}.route-instability.high{color:var(--status-high)}.route-instability.critical{color:var(--status-critical);font-weight:600}.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-default)}.kpi-card{background:var(--bg-elevated);padding:10px 12px}.kpi-label{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:3px}.kpi-value{font-family:var(--font-mono);font-size:20px;font-weight:700;color:var(--text-primary);line-height:1}.kpi-value.critical{color:var(--status-critical)}.kpi-value.warning{color:var(--status-moderate)}.kpi-value.ok{color:var(--status-ok)}.kpi-sub{font-size:9px;color:var(--text-tertiary);margin-top:2px;font-family:var(--font-mono)}.alert-item{padding:9px 10px;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border-subtle);cursor:pointer;transition:all .15s;margin-bottom:6px}.alert-item:hover{border-color:var(--border-default);background:var(--bg-hover)}.alert-item.selected{border-color:var(--accent-primary);background:var(--bg-active)}.alert-item.sev-critical{border-left:3px solid var(--status-critical)}.alert-item.sev-high{border-left:3px solid var(--status-high)}.alert-item.sev-moderate{border-left:3px solid var(--status-moderate)}.alert-item.sev-low{border-left:3px solid var(--status-low)}.alert-header{display:flex;align-items:flex-start;gap:7px;margin-bottom:5px}.severity-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:4px}.severity-dot.critical{background:var(--status-critical);box-shadow:0 0 6px var(--status-critical)}.severity-dot.high{background:var(--status-high)}.severity-dot.moderate{background:var(--status-moderate)}.severity-dot.low{background:var(--status-low)}.severity-dot.info{background:var(--status-info)}.alert-title{font-size:11px;font-weight:500;color:var(--text-primary);line-height:1.4}.alert-meta{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.alert-tag{font-size:9px;font-family:var(--font-mono);padding:1px 5px;border-radius:2px;background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border-subtle)}.alert-tag.route-tag{background:#4a9eff14;color:var(--accent-primary);border-color:#4a9eff33}.score-bar-wrap{display:flex;flex-direction:column;gap:3px}.score-bar-label{display:flex;justify-content:space-between;font-size:10px}.score-bar-label span:first-child{color:var(--text-secondary)}.score-bar-label span:last-child{font-family:var(--font-mono);color:var(--text-primary);font-weight:500}.score-bar-track{height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden}.score-bar-fill{height:100%;border-radius:2px;transition:width .5s ease}.score-bar-fill.ok{background:linear-gradient(90deg,#1aad6e,#26d98a)}.score-bar-fill.warning{background:linear-gradient(90deg,#c9a200,#f5c842)}.score-bar-fill.danger{background:linear-gradient(90deg,#c0293b,#f23d4f)}.search-input{width:100%;background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-primary);font-family:var(--font-ui);font-size:12px;padding:7px 10px;border-radius:var(--radius-sm);outline:none;transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px #4a9eff1a}.search-input::placeholder{color:var(--text-tertiary)}.overlay-card{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.overlay-card-header{padding:10px 14px;background:#ffffff08;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.overlay-card-title{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary)}.overlay-card-body{padding:10px 14px}.mapboxgl-popup-content{background:var(--bg-elevated)!important;border:1px solid var(--border-strong)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-xl)!important;padding:0!important}.mapboxgl-popup-tip{border-top-color:var(--bg-elevated)!important;border-bottom-color:var(--bg-elevated)!important}.mapboxgl-popup-close-button{color:var(--text-tertiary)!important;font-size:16px!important;top:6px!important;right:8px!important}.vehicle-popup{padding:12px 14px;min-width:210px}.popup-mode-badge{display:inline-flex;align-items:center;gap:5px;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:2px 7px;border-radius:2px;margin-bottom:6px}.popup-mode-badge.rail{background:#818cf833;color:var(--accent-rail);border:1px solid rgba(129,140,248,.3)}.popup-mode-badge.bus{background:#fb923c33;color:var(--accent-bus);border:1px solid rgba(251,146,60,.3)}.popup-heading{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:8px;line-height:1.3}.popup-row{display:flex;justify-content:space-between;align-items:center;padding:2px 0;border-bottom:1px solid var(--border-subtle)}.popup-row:last-child{border-bottom:none}.popup-key{font-size:10px;color:var(--text-tertiary)}.popup-val{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary)}.popup-val.delayed{color:var(--status-high);font-weight:600}.popup-val.critical{color:var(--status-critical);font-weight:600}.popup-val.ok{color:var(--status-ok)}.playback-strip{display:flex;align-items:center;gap:12px;width:100%;height:100%}.play-btn{width:34px;height:34px;background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;transition:all .15s}.play-btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.play-btn.playing{background:#4a9eff26;border-color:var(--accent-primary);color:var(--accent-primary)}.timeline-wrap{flex:1;display:flex;flex-direction:column;gap:5px}.timeline-labels{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:9px;color:var(--text-tertiary)}.timeline-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:#ffffff14;border-radius:2px;outline:none;cursor:pointer}.timeline-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-primary);cursor:pointer;border:2px solid var(--bg-surface);box-shadow:0 0 6px #4a9eff66}.speed-btn{font-family:var(--font-mono);font-size:10px;padding:4px 8px;background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-tertiary);border-radius:var(--radius-xs);cursor:pointer;white-space:nowrap;transition:all .15s}.speed-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.speed-btn.active{border-color:var(--accent-primary);color:var(--accent-primary);background:#4a9eff1a}.playback-ts{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary);white-space:nowrap}.ai-header{padding:12px 14px;border-bottom:1px solid var(--border-default);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:linear-gradient(135deg,#4a9eff0d,#818cf80d)}.ai-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-primary)}.ai-close-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:var(--radius-sm)}.ai-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.ai-actions{padding:10px 14px;border-bottom:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:4px;flex-shrink:0}.ai-actions-title{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:4px}.ai-action-btn{text-align:left;background:var(--bg-elevated);border:1px solid var(--border-subtle);color:var(--text-secondary);font-family:var(--font-ui);font-size:11px;padding:7px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.ai-action-btn:hover{background:var(--bg-hover);border-color:var(--border-default);color:var(--text-primary)}.ai-messages{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.ai-msg{display:flex;flex-direction:column;gap:3px}.ai-msg-role{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary)}.ai-msg.user .ai-msg-role{color:var(--accent-primary)}.ai-msg.assistant .ai-msg-role{color:var(--accent-secondary)}.ai-msg-content{font-size:11px;line-height:1.65;color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:9px 10px;white-space:pre-wrap}.ai-msg.user .ai-msg-content{background:#4a9eff12;border-color:#4a9eff2e}.ai-loading-dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent-secondary);animation:blink-dot .8s infinite;margin:0 2px}@keyframes blink-dot{0%,to{opacity:.15}50%{opacity:1}}.ai-input-wrap{padding:10px 14px;border-top:1px solid var(--border-default);display:flex;gap:6px;flex-shrink:0}.ai-input{flex:1;background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-primary);font-family:var(--font-ui);font-size:12px;padding:8px 10px;border-radius:var(--radius-sm);outline:none;resize:none;transition:border-color .15s,box-shadow .15s;height:58px}.ai-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px #4a9eff1a}.ai-input::placeholder{color:var(--text-tertiary)}.ai-send-btn{background:var(--accent-primary);border:none;color:#fff;font-family:var(--font-ui);font-size:11px;font-weight:600;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;align-self:flex-end}.ai-send-btn:disabled{opacity:.3;cursor:default}.ai-send-btn:hover:not(:disabled){background:#6ab0ff}.recharts-cartesian-axis-tick-value{fill:var(--text-tertiary)!important;font-size:9px!important;font-family:var(--font-mono)!important}.custom-tooltip{background:var(--bg-elevated)!important;border:1px solid var(--border-default)!important;border-radius:var(--radius-sm)!important;padding:6px 10px!important;font-size:11px!important}.mono{font-family:var(--font-mono)}.text-dim{color:var(--text-tertiary)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.mt-2{margin-top:6px}.mt-3{margin-top:10px}.mb-2{margin-bottom:6px}.badge{font-family:var(--font-mono);font-size:9px;font-weight:700;padding:2px 6px;border-radius:2px;text-transform:uppercase;letter-spacing:.05em}.badge-critical{background:#f23d4f1f;color:var(--status-critical);border:1px solid rgba(242,61,79,.25)}.badge-high{background:#f5823a1f;color:var(--status-high);border:1px solid rgba(245,130,58,.25)}.badge-moderate{background:#f5c8421f;color:var(--status-moderate);border:1px solid rgba(245,200,66,.25)}.badge-low{background:#4fc3f71f;color:var(--status-low);border:1px solid rgba(79,195,247,.25)}.badge-info{background:#78909c1f;color:var(--status-info);border:1px solid rgba(120,144,156,.25)}.icon-btn{background:none;border:1px solid var(--border-subtle);color:var(--text-tertiary);border-radius:var(--radius-sm);padding:3px 8px;cursor:pointer;font-size:11px;transition:all .15s}.icon-btn:hover{background:var(--bg-hover);border-color:var(--border-default);color:var(--text-primary)}.empty-state{padding:24px 16px;text-align:center;color:var(--text-tertiary);font-size:11px;line-height:1.6}.loading-bar{height:2px;background:linear-gradient(90deg,transparent,var(--accent-primary),transparent);animation:loading-sweep 1.5s infinite}@keyframes loading-sweep{0%{transform:translate(-100%)}to{transform:translate(100%)}}.mapboxgl-ctrl-group{background:var(--bg-elevated)!important;border:1px solid var(--border-default)!important;border-radius:var(--radius-sm)!important;box-shadow:var(--shadow-md)!important}.mapboxgl-ctrl-group button{background:var(--bg-elevated)!important;color:var(--text-secondary)!important;border-bottom:1px solid var(--border-subtle)!important}.mapboxgl-ctrl-group button:hover{background:var(--bg-hover)!important}.mapboxgl-ctrl-group button span{filter:invert(1) brightness(.6)}.map-controls-overlay{position:absolute;top:14px;left:14px;z-index:10;display:flex;flex-direction:column;gap:8px}.map-mode-toggle{display:flex;background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-sm);overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-md)}.map-mode-btn{background:none;border:none;color:var(--text-tertiary);font-family:var(--font-ui);font-size:10px;font-weight:600;padding:6px 12px;cursor:pointer;transition:all .15s;letter-spacing:.05em;text-transform:uppercase;border-right:1px solid var(--border-subtle);white-space:nowrap}.map-mode-btn:last-child{border-right:none}.map-mode-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.map-mode-btn.active{background:#4a9eff26;color:var(--accent-primary)}.map-legend-overlay{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:10px 12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-md)}.legend-title{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:8px}.legend-row{display:flex;align-items:center;gap:7px;font-size:10px;color:var(--text-secondary);margin-bottom:5px}.legend-row:last-child{margin-bottom:0}.legend-symbol{flex-shrink:0;display:flex;align-items:center;justify-content:center}.legend-swatch-line{width:20px;height:3px;border-radius:2px}.legend-swatch-circle{width:10px;height:10px;border-radius:50%}.legend-swatch-ring{width:10px;height:10px;border-radius:50%;border:2px solid;background:transparent}.legend-swatch-alert{width:10px;height:10px;border-radius:50%;border:2px solid}@keyframes pulse-banner{0%,to{opacity:1}50%{opacity:.85}}.app-shell{grid-template-rows:auto 1fr var(--bottompanel-h)!important}.app-shell{grid-template-rows:var(--topbar-h) 1fr var(--bottompanel-h)!important}.overlay-card{background:#0c0f14eb!important;border-color:#ffffff12!important;box-shadow:0 4px 20px #00000080!important}.overlay-card-header{background:#ffffff05!important;border-bottom-color:#ffffff0d!important}.panel-section{border-bottom-color:#ffffff0a!important}.route-item{border-color:transparent!important}.route-item:hover{background:#ffffff0a!important;border-color:transparent!important}.route-item.selected{background:#4a9eff14!important;border-color:#4a9eff33!important}.alert-item{background:transparent!important;border-color:transparent!important;border-left:2px solid transparent!important;border-radius:0!important;padding:8px 10px!important}.alert-item:hover{background:#ffffff08!important}.alert-item.sev-critical{border-left-color:var(--status-critical)!important}.alert-item.sev-high{border-left-color:var(--status-high)!important}.alert-item.sev-moderate{border-left-color:var(--status-moderate)!important}.alert-item.selected{background:#4a9eff0f!important}.bottom-bar{background:#0a0c10f2!important;border-top-color:#ffffff0f!important}.kpi-value{font-size:18px!important}.kpi-card{padding:8px 10px!important}.mapboxgl-ctrl-bottom-right{bottom:40px!important}@media (max-width: 768px){:root{--leftpanel-w: 0px;--rightpanel-w: 100vw;--aipanel-w: 100vw;--topbar-h: 48px;--bottompanel-h: 52px}.app-shell,.app-shell.ai-open{grid-template-columns:1fr!important;grid-template-areas:"topbar" "main" "bottom"!important}.left-panel{position:fixed;top:var(--topbar-h);left:0;bottom:var(--bottompanel-h);width:280px;z-index:200;transform:translate(-100%);transition:transform .25s ease;box-shadow:4px 0 20px #00000080}.left-panel.open{transform:translate(0)}.ai-panel{position:fixed;inset:var(--topbar-h) 0 var(--bottompanel-h) 0;z-index:200;width:100%!important}.right-overlay{left:8px;right:8px;width:auto;top:8px}.topbar-nav,.nav-btn,.brand-sub{display:none}.bottom-bar{padding:0 10px;gap:8px}.kpi-sub{display:none}}@media (max-width: 480px){.topbar-right>.topbar-sep{display:none}.feed-indicator{display:none}}.mobile-menu-btn{display:none}@media (max-width: 768px){.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;color:var(--text-secondary);flex-shrink:0}}
