@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;600&display=swap");:root{--bg-base:#080c14;--bg-surface:#0d1420;--bg-elevated:#111827;--bg-panel:#161f2e;--bg-overlay:rgba(8,12,20,.92);--border-subtle:hsla(0,0%,100%,.06);--border-default:hsla(0,0%,100%,.1);--border-strong:hsla(0,0%,100%,.18);--accent-primary:#3b82f6;--accent-primary-glow:rgba(59,130,246,.3);--accent-secondary:#8b5cf6;--accent-cyan:#06b6d4;--accent-cyan-glow:rgba(6,182,212,.25);--status-green:#10b981;--status-green-bg:rgba(16,185,129,.12);--status-amber:#f59e0b;--status-amber-bg:rgba(245,158,11,.12);--status-red:#ef4444;--status-red-bg:rgba(239,68,68,.12);--status-blue:#3b82f6;--status-blue-bg:rgba(59,130,246,.12);--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-accent:#38bdf8;--gradient-brand:linear-gradient(135deg,#3b82f6,#8b5cf6);--gradient-danger:linear-gradient(135deg,#ef4444,#dc2626);--gradient-success:linear-gradient(135deg,#10b981,#059669);--gradient-surface:linear-gradient(180deg,#0d1420,#080c14);--shadow-sm:0 1px 3px rgba(0,0,0,.5);--shadow-md:0 4px 16px rgba(0,0,0,.4);--shadow-lg:0 8px 32px rgba(0,0,0,.6);--shadow-glow-blue:0 0 20px rgba(59,130,246,.25);--shadow-glow-cyan:0 0 20px rgba(6,182,212,.2);--sidebar-width:280px;--header-height:64px;--panel-radius:12px;--card-radius:8px;--btn-radius:8px;--transition-fast:150ms ease;--transition-base:250ms ease;--transition-slow:400ms ease;--font-sans:"Inter",system-ui,-apple-system,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace}[data-theme=light]{--bg-base:#f8fafc;--bg-surface:#fff;--bg-elevated:#fff;--bg-panel:#f1f5f9;--bg-overlay:hsla(0,0%,100%,.92);--border-subtle:rgba(0,0,0,.06);--border-default:rgba(0,0,0,.1);--border-strong:rgba(0,0,0,.18);--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-accent:#0284c7;--gradient-surface:linear-gradient(180deg,#fff,#f8fafc);--shadow-sm:0 1px 3px rgba(0,0,0,.1);--shadow-md:0 4px 16px rgba(0,0,0,.08);--shadow-lg:0 8px 32px rgba(0,0,0,.12)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-base);color:var(--text-primary);min-height:100vh;overflow-x:hidden;background-image:radial-gradient(ellipse at 20% 0,rgba(59,130,246,.06) 0,transparent 60%),radial-gradient(ellipse at 80% 100%,rgba(139,92,246,.06) 0,transparent 60%)}.app-shell{display:grid;grid-template-rows:var(--header-height) 1fr;grid-template-columns:var(--sidebar-width) 1fr;grid-template-areas:"header header" "sidebar main";height:100vh;overflow:hidden;transition:grid-template-columns var(--transition-base)}.app-shell.sidebar-collapsed{--sidebar-width:72px}.header{grid-area:header;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);z-index:100;position:relative}.header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-primary),var(--accent-secondary),transparent);opacity:.4}.header-brand{gap:12px}.header-brand,.header-logo{display:flex;align-items:center}.header-logo{width:36px;height:36px;background:var(--gradient-brand);border-radius:10px;justify-content:center;font-size:18px;box-shadow:var(--shadow-glow-blue);flex-shrink:0}.header-title{font-size:16px;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);line-height:1.1}.header-subtitle{font-size:11px;font-weight:400;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}.header-center{gap:8px}.header-center,.header-right{display:flex;align-items:center}.header-right{gap:16px}.live-badge{display:flex;align-items:center;gap:6px;padding:4px 12px;background:var(--status-green-bg);border:1px solid rgba(16,185,129,.3);border-radius:20px;font-size:11px;font-weight:600;color:var(--status-green);letter-spacing:.08em;text-transform:uppercase}.live-dot{width:6px;height:6px;background:var(--status-green);border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.header-time{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text-secondary)}.sidebar{grid-area:sidebar;background:var(--bg-surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border-default) transparent;transition:all var(--transition-base)}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:4px}.sidebar-section{padding:16px;border-bottom:1px solid var(--border-subtle)}.sidebar-section-label{font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;padding-left:4px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--card-radius);cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary);font-size:13px;font-weight:500;border:1px solid transparent;background:transparent;text-decoration:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.nav-item:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-subtle)}.nav-item.active{background:var(--accent-primary-glow);color:var(--accent-primary);border-color:rgba(59,130,246,.2)}.nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}.main-content{grid-area:main;overflow-y:auto;overflow-x:hidden;padding:20px;display:flex;flex-direction:column;gap:20px;scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}.main-content::-webkit-scrollbar{width:6px}.main-content::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:4px}.dashboard-grid{display:grid;grid-template-columns:1fr 340px;grid-gap:20px;gap:20px;flex:1 1}.dashboard-left{gap:20px}.dashboard-left,.dashboard-right{display:flex;flex-direction:column;min-height:0}.dashboard-right{gap:16px}.panel{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--panel-radius);overflow:hidden;position:relative}.panel-header{justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-subtle);background:var(--bg-elevated)}.panel-header,.panel-title{display:flex;align-items:center}.panel-title{font-size:13px;font-weight:600;color:var(--text-primary);gap:8px}.panel-title-icon{font-size:15px}.panel-badge{font-family:var(--font-mono);font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;letter-spacing:.05em}.panel-badge.green{background:var(--status-green-bg);color:var(--status-green);border:1px solid rgba(16,185,129,.2)}.panel-badge.amber{background:var(--status-amber-bg);color:var(--status-amber);border:1px solid rgba(245,158,11,.2)}.panel-badge.red{background:var(--status-red-bg);color:var(--status-red);border:1px solid rgba(239,68,68,.2)}.panel-badge.blue{background:var(--status-blue-bg);color:var(--status-blue);border:1px solid rgba(59,130,246,.2)}.panel-body{padding:16px 18px}.map-container{height:480px;background:var(--bg-base);position:relative;overflow:hidden}.map-container .map-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);font-size:14px}.map-container .map-placeholder .map-icon{font-size:48px;opacity:.3}.gate-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:10px;gap:10px;padding:16px}.gate-card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--card-radius);padding:12px;position:relative;overflow:hidden}.gate-card,.gate-card:before{transition:all var(--transition-base)}.gate-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:8px 8px 0 0}.gate-card.green:before{background:var(--status-green)}.gate-card.amber:before{background:var(--status-amber)}.gate-card.red:before{background:var(--status-red);box-shadow:0 0 12px rgba(239,68,68,.4)}.gate-card.locked:before{background:var(--accent-secondary)}.gate-card:hover{border-color:var(--border-default);transform:translateY(-1px);box-shadow:var(--shadow-md)}.gate-name{font-size:11px;font-weight:700;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px}.gate-congestion{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:4px}.gate-label{font-size:10px;color:var(--text-muted);margin-bottom:8px}.congestion-bar{width:100%;height:3px;background:var(--border-subtle);border-radius:2px;overflow:hidden;margin-bottom:8px}.congestion-fill{height:100%;border-radius:2px;transition:width var(--transition-slow)}.gate-card.green .congestion-fill{background:var(--status-green)}.gate-card.amber .congestion-fill{background:var(--status-amber)}.gate-card.red .congestion-fill{background:var(--status-red)}.gate-stats{display:flex;justify-content:space-between;font-size:10px;color:var(--text-muted)}.gate-status-pill{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:2px 6px;border-radius:4px}.gate-status-pill.green{background:var(--status-green-bg);color:var(--status-green)}.gate-status-pill.amber{background:var(--status-amber-bg);color:var(--status-amber)}.gate-status-pill.red{background:var(--status-red-bg);color:var(--status-red)}.gate-status-pill.locked{background:rgba(139,92,246,.15);color:var(--accent-secondary)}.metrics-bar{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px;padding:0}.metric-card{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--card-radius);padding:16px 20px;display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden;transition:all var(--transition-base)}.metric-card:hover{border-color:var(--border-default);transform:translateY(-2px);box-shadow:var(--shadow-md)}.metric-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--gradient-brand);opacity:0;transition:opacity var(--transition-base)}.metric-card:hover:after{opacity:.4}.metric-label{font-size:10px;font-weight:600;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.metric-value{font-family:var(--font-mono);font-size:28px;font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-.02em}.metric-sub{font-size:11px;color:var(--text-secondary);margin-top:2px}.metric-icon{position:absolute;top:16px;right:16px;font-size:24px;opacity:.15}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--btn-radius);font-size:13px;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;white-space:nowrap;outline:none}.btn-primary{background:var(--accent-primary);color:#fff;box-shadow:0 2px 8px rgba(59,130,246,.4)}.btn-primary:hover{background:#2563eb;box-shadow:0 4px 16px rgba(59,130,246,.5);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-danger{background:var(--gradient-danger);color:#fff;box-shadow:0 2px 8px rgba(239,68,68,.4)}.btn-danger:hover{box-shadow:0 4px 16px rgba(239,68,68,.5);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:var(--border-default)}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-strong)}.btn-sm{padding:5px 10px;font-size:11px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--card-radius);color:var(--text-primary);font-family:var(--font-sans);font-size:13px;padding:9px 12px;transition:all var(--transition-fast);outline:none;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}.form-select option{background:var(--bg-elevated);color:var(--text-primary)}.form-textarea{resize:vertical;min-height:80px}.severity-group{display:flex;gap:6px}.severity-btn{flex:1 1;padding:6px 4px;border-radius:6px;border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-muted);font-size:11px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);text-align:center}.severity-btn:hover{border-color:var(--border-strong);color:var(--text-primary)}.severity-btn.low.active{background:var(--status-green-bg);border-color:var(--status-green);color:var(--status-green)}.severity-btn.medium.active{background:var(--status-amber-bg);border-color:var(--status-amber);color:var(--status-amber)}.severity-btn.high.active{background:var(--status-red-bg);border-color:var(--status-red);color:var(--status-red)}.severity-btn.critical.active{background:rgba(139,92,246,.15);border-color:var(--accent-secondary);color:var(--accent-secondary)}.incident-feed{gap:8px;max-height:280px;overflow-y:auto;padding:4px 0;scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}.incident-feed,.incident-item{display:flex;flex-direction:column}.incident-item{gap:4px;padding:10px 12px;background:var(--bg-elevated);border-radius:var(--card-radius);border:1px solid var(--border-subtle);border-left:3px solid transparent;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}.incident-item.low{border-left-color:var(--status-green)}.incident-item.medium{border-left-color:var(--status-amber)}.incident-item.high{border-left-color:var(--status-red)}.incident-item.critical{border-left-color:var(--accent-secondary)}.incident-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.incident-type{font-size:12px;font-weight:600;color:var(--text-primary)}.incident-time{font-family:var(--font-mono);font-size:10px;color:var(--text-muted)}.incident-location{font-size:11px;color:var(--text-secondary)}.incident-desc{font-size:11px;color:var(--text-muted);line-height:1.5}.ai-insight{background:linear-gradient(135deg,rgba(139,92,246,.06),rgba(59,130,246,.06));border:1px solid rgba(139,92,246,.2);border-radius:var(--card-radius);padding:14px}.ai-insight-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.ai-label{letter-spacing:.1em;color:var(--accent-secondary)}.ai-label,.ai-risk-badge{font-size:10px;font-weight:700;text-transform:uppercase}.ai-risk-badge{margin-left:auto;padding:2px 8px;border-radius:20px;letter-spacing:.05em}.ai-risk-badge.low{background:var(--status-green-bg);color:var(--status-green)}.ai-risk-badge.medium{background:var(--status-amber-bg);color:var(--status-amber)}.ai-risk-badge.high{background:var(--status-red-bg);color:var(--status-red)}.ai-risk-badge.critical{background:rgba(139,92,246,.15);color:var(--accent-secondary)}.ai-summary{font-size:13px;color:var(--text-primary);line-height:1.6;margin-bottom:10px}.ai-actions-label{font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}.ai-action-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text-secondary);margin-bottom:4px;line-height:1.4}.ai-action-item:before{content:"→";color:var(--accent-primary);flex-shrink:0;margin-top:1px}.ai-thinking{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);font-style:italic}.ai-spinner{width:14px;height:14px;border:2px solid var(--border-default);border-top-color:var(--accent-secondary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.alert-feed{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-default) transparent}.alert-item{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:6px;font-size:12px;animation:slideIn .3s ease}.alert-icon{font-size:14px;flex-shrink:0;margin-top:1px}.alert-text{color:var(--text-secondary);flex:1 1;line-height:1.4}.alert-time{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);flex-shrink:0}.evacuation-banner{background:linear-gradient(135deg,rgba(239,68,68,.15),rgba(220,38,38,.1));border:2px solid var(--status-red);border-radius:var(--card-radius);padding:14px 16px;display:flex;align-items:center;gap:12px;animation:pulse-danger 2s ease-in-out infinite}@keyframes pulse-danger{0%,to{box-shadow:0 0 0 0 rgba(239,68,68,0)}50%{box-shadow:0 0 20px rgba(239,68,68,.3)}}.evacuation-banner .evac-icon{font-size:24px}.evacuation-banner .evac-text{flex:1 1}.evacuation-banner .evac-title{font-size:14px;font-weight:700;color:var(--status-red);letter-spacing:.04em}.evacuation-banner .evac-sub{font-size:11px;color:var(--text-secondary)}.vip-zone-list{display:flex;flex-direction:column;gap:8px}.vip-zone-card{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--card-radius);transition:all var(--transition-fast)}.vip-zone-card.active{border-color:rgba(251,191,36,.3);background:rgba(251,191,36,.05)}.vip-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#d97706);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.vip-info{flex:1 1;min-width:0}.vip-name{font-size:12px;font-weight:600;color:var(--text-primary)}.vip-location{font-size:10px;color:var(--text-muted)}.vip-toggle{width:36px;height:20px;background:var(--border-default);border-radius:10px;position:relative;cursor:pointer;border:none;transition:background var(--transition-fast);flex-shrink:0}.vip-toggle.on{background:#f59e0b}.vip-toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.vip-toggle.on:after{transform:translateX(16px)}.weather-widget{display:flex;align-items:center;gap:16px;padding:14px 18px}.weather-icon{font-size:36px}.weather-temp{font-family:var(--font-mono);font-size:28px;font-weight:700;color:var(--text-primary);line-height:1}.weather-desc{font-size:12px;color:var(--text-secondary);margin-top:2px}.weather-stats{display:flex;flex-direction:column;gap:4px;margin-left:auto}.weather-stat{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary)}.weather-stat-icon{font-size:12px}.toggle-switch{position:relative;width:44px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;inset:0;background:var(--border-default);border-radius:12px;cursor:pointer;transition:background var(--transition-fast)}.toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.toggle-switch input:checked+.toggle-slider{background:var(--accent-primary)}.toggle-switch input:checked+.toggle-slider:after{transform:translateX(20px)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.auth-overlay{position:fixed;inset:0;background:var(--bg-base);display:flex;align-items:center;justify-content:center;z-index:9999;padding:24px}.auth-card{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:16px;padding:40px;width:100%;max-width:420px;gap:24px;box-shadow:var(--shadow-lg)}.auth-card,.auth-logo{display:flex;flex-direction:column}.auth-logo{align-items:center;gap:12px;text-align:center}.auth-logo-icon{width:56px;height:56px;background:var(--gradient-brand);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:var(--shadow-glow-blue)}.auth-title{font-size:22px;font-weight:800;letter-spacing:-.03em;color:var(--text-primary)}.auth-subtitle{font-size:13px;color:var(--text-muted);margin-top:-8px}.auth-error{background:var(--status-red-bg);border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--status-red)}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-panel) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width:1280px){.dashboard-grid{grid-template-columns:1fr}.gate-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){:root{--sidebar-width:0px}.app-shell{grid-template-columns:1fr;grid-template-areas:"header" "main"}.sidebar{display:none}.gate-grid,.metrics-bar{grid-template-columns:repeat(2,1fr)}}