:root{--bg-deep: #060d1a;--bg-card: #0d1b2e;--bg-elevated: #122338;--bg-hover: #1a3050;--border: rgba(100, 180, 255, .12);--border-bright: rgba(100, 180, 255, .3);--primary: #00d4ff;--primary-dim: rgba(0, 212, 255, .15);--primary-glow: 0 0 20px rgba(0, 212, 255, .35);--accent: #ff6b2b;--accent-dim: rgba(255, 107, 43, .15);--success: #00e87a;--warning: #ffd60a;--danger: #ff3d3d;--info: #4cc9f0;--text-primary: #e8f4ff;--text-secondary: #7ab3d4;--text-muted: #445d72;--text-mono: #a8d4f0;--status-open: #00e87a;--status-crowded: #ffd60a;--status-full: #ff3d3d;--status-closed: #445d72;--sev-critical: #ff2d2d;--sev-high: #ff6b35;--sev-moderate: #ffd60a;--sev-low: #00e87a;--panel-width: 420px;--control-height: 160px;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--font-display: "Syne", sans-serif;--font-mono: "Space Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden;font-family:var(--font-display);background:var(--bg-deep);color:var(--text-primary);-webkit-font-smoothing:antialiased}.splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--bg-deep);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;animation:splashFadeOut .6s ease 2.4s forwards}.splash-logo{font-family:var(--font-display);font-size:52px;font-weight:800;letter-spacing:-2px;background:linear-gradient(135deg,var(--primary),#4cc9f0,var(--primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:splashPulse 1.5s ease-in-out infinite}.splash-sub{font-family:var(--font-mono);font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--text-secondary)}.splash-ring{width:80px;height:80px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.splash-dots{display:flex;gap:8px}.splash-dot{width:6px;height:6px;border-radius:50%;background:var(--primary);animation:dotPulse 1.4s ease-in-out infinite}.splash-dot:nth-child(2){animation-delay:.2s;background:var(--info)}.splash-dot:nth-child(3){animation-delay:.4s;background:var(--accent)}@keyframes splashFadeOut{to{opacity:0;pointer-events:none}}@keyframes splashPulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes dotPulse{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.app{position:relative;width:100vw;height:100vh;overflow:hidden}.app.emergency-mode{--primary: #ff3d3d;--bg-deep: #1a0505;--bg-card: #220808}.app.storm-hurricane{--primary: #c77dff;--bg-deep: #080010;--bg-card: #0d0018}.app.storm-flood{--primary: #4cc9f0;--bg-deep: #00040d;--bg-card: #000814}.app.storm-heat{--primary: #ff9500;--bg-deep: #120800;--bg-card: #1a0d00}.map-container{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.leaflet-container{width:100%;height:100%;background:#060d1a}.leaflet-control-zoom{border:1px solid var(--border-bright)!important;border-radius:var(--radius-sm)!important;overflow:hidden}.leaflet-control-zoom a{background:var(--bg-card)!important;color:var(--text-primary)!important;border-color:var(--border)!important;font-size:16px!important}.leaflet-control-zoom a:hover{background:var(--bg-elevated)!important}.leaflet-popup-content-wrapper{background:var(--bg-card)!important;border:1px solid var(--border-bright)!important;border-radius:var(--radius)!important;color:var(--text-primary)!important;box-shadow:0 8px 32px #0006!important}.leaflet-popup-tip{background:var(--bg-card)!important}.leaflet-popup-close-button{color:var(--text-secondary)!important;font-size:18px!important}.top-bar{position:absolute;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(to bottom,rgba(6,13,26,.95),transparent);pointer-events:none}.top-bar>*{pointer-events:all}.brand{display:flex;align-items:center;gap:10px}.brand-logo{font-family:var(--font-display);font-size:22px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,var(--primary),#4cc9f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-badge{font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:3px 7px;background:var(--primary-dim);border:1px solid var(--primary);border-radius:4px;color:var(--primary)}.top-bar-right{display:flex;align-items:center;gap:8px}.status-pill{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:20px;font-family:var(--font-mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;border:1px solid;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.status-pill.online{background:#00e87a1a;border-color:var(--success);color:var(--success)}.status-pill.offline{background:#ff3d3d1a;border-color:var(--danger);color:var(--danger);animation:pillPulse 2s ease infinite}.status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.status-pill.online .status-dot{animation:dotBlink 2s ease infinite}@keyframes pillPulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes dotBlink{0%,to{opacity:1}50%{opacity:.3}}.sync-badge{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:20px;font-family:var(--font-mono);font-size:10px;background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent)}.storm-banner{position:absolute;top:60px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;padding:8px 20px;background:#ff6b2be6;border-radius:20px;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#fff;animation:bannerPulse 1.5s ease infinite;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;pointer-events:all;z-index:200}@keyframes bannerPulse{0%,to{box-shadow:0 0 #ff6b2b66}50%{box-shadow:0 0 0 8px #ff6b2b00}}.control-panel{position:absolute;bottom:0;left:0;right:0;z-index:100;background:linear-gradient(to top,rgba(6,13,26,.98) 80%,transparent);padding:16px 16px 20px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.control-row{display:flex;gap:8px;justify-content:center;margin-bottom:8px}.control-row:last-child{margin-bottom:0}.ctrl-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-family:var(--font-display);min-width:60px;flex:1;max-width:80px}.ctrl-btn:hover{background:var(--bg-elevated);border-color:var(--border-bright);color:var(--text-primary);transform:translateY(-1px)}.ctrl-btn.active{background:var(--primary-dim);border-color:var(--primary);color:var(--primary);box-shadow:var(--primary-glow)}.ctrl-btn.danger-btn{background:#ff3d3d1a;border-color:var(--danger);color:var(--danger)}.ctrl-btn.danger-btn.active{background:#ff3d3d40;box-shadow:0 0 20px #ff3d3d4d}.ctrl-btn.accent-btn{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.ctrl-icon{font-size:18px;line-height:1}.ctrl-label{font-size:9px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.side-panel{position:absolute;top:0;right:0;bottom:0;width:min(var(--panel-width),100vw);z-index:200;background:var(--bg-card);border-left:1px solid var(--border);display:flex;flex-direction:column;transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:-12px 0 40px #00000080}.side-panel.open{transform:translate(0)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0}.panel-title{font-size:16px;font-weight:700;letter-spacing:-.3px;display:flex;align-items:center;gap:10px}.panel-title .icon{font-size:20px}.panel-close{width:32px;height:32px;border-radius:8px;background:transparent;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s}.panel-close:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-bright)}.panel-body{flex:1;overflow-y:auto;padding:16px;scrollbar-width:thin;scrollbar-color:var(--border-bright) transparent}.panel-body::-webkit-scrollbar{width:4px}.panel-body::-webkit-scrollbar-track{background:transparent}.panel-body::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:2px}.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;transition:all .2s}.card:hover{border-color:var(--border-bright);box-shadow:0 4px 20px #0000004d}.card.clickable{cursor:pointer}.card.clickable:hover{transform:translateY(-1px)}.card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.card-name{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.2px}.card-sub{font-size:12px;color:var(--text-secondary);margin-top:2px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.badge.open{background:#00e87a26;color:var(--status-open);border:1px solid rgba(0,232,122,.3)}.badge.crowded{background:#ffd60a26;color:var(--status-crowded);border:1px solid rgba(255,214,10,.3)}.badge.full{background:#ff3d3d26;color:var(--status-full);border:1px solid rgba(255,61,61,.3)}.badge.closed{background:#445d7233;color:var(--status-closed);border:1px solid rgba(68,93,114,.3)}.badge.critical{background:#ff2d2d26;color:var(--sev-critical);border:1px solid rgba(255,45,45,.3)}.badge.high{background:#ff6b3526;color:var(--sev-high);border:1px solid rgba(255,107,53,.3)}.badge.moderate{background:#ffd60a26;color:var(--sev-moderate);border:1px solid rgba(255,214,10,.3)}.badge.low{background:#00e87a26;color:var(--sev-low);border:1px solid rgba(0,232,122,.3)}.badge.verified{background:#00e87a26;color:var(--success);border:1px solid rgba(0,232,122,.3)}.badge.community{background:#4cc9f026;color:var(--info);border:1px solid rgba(76,201,240,.3)}.badge.unverified{background:#445d7233;color:var(--text-muted);border:1px solid rgba(68,93,114,.3)}.progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin:10px 0 6px}.progress-fill{height:100%;border-radius:3px;transition:width .5s ease}.progress-fill.low{background:var(--success)}.progress-fill.medium{background:var(--warning)}.progress-fill.high{background:var(--danger)}.progress-label{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:11px;color:var(--text-secondary)}.tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}.tag{padding:3px 8px;background:var(--primary-dim);border:1px solid rgba(0,212,255,.2);border-radius:4px;font-family:var(--font-mono);font-size:10px;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}.trend{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.5px}.trend.increasing{color:var(--danger)}.trend.stable{color:var(--info)}.trend.decreasing{color:var(--success)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid transparent;white-space:nowrap}.btn-primary{background:var(--primary);color:var(--bg-deep);border-color:var(--primary)}.btn-primary:hover{background:#1ae0ff;box-shadow:var(--primary-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-bright)}.btn-secondary:hover{background:var(--bg-hover)}.btn-danger{background:#ff3d3d1a;color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:#ff3d3d33}.btn-success{background:#00e87a1a;color:var(--success);border-color:var(--success)}.btn-success:hover{background:#00e87a33}.btn-full{width:100%}.btn-sm{padding:7px 12px;font-size:12px}.btn-lg{padding:14px 24px;font-size:15px;font-weight:700}.input,.select,.textarea{width:100%;padding:10px 14px;background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-display);font-size:14px;outline:none;transition:border-color .2s}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}.input::placeholder{color:var(--text-muted)}.select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%237ab3d4' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.select option{background:var(--bg-card);color:var(--text-primary)}.textarea{resize:vertical;min-height:80px;line-height:1.5}.form-group{margin-bottom:14px}.form-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:6px}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%) translateY(-80px);z-index:9000;padding:12px 20px;border-radius:50px;font-family:var(--font-mono);font-size:12px;letter-spacing:.5px;display:flex;align-items:center;gap:10px;max-width:400px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid;animation:toastIn .4s cubic-bezier(.34,1.56,.64,1) forwards;box-shadow:0 8px 32px #0006}.toast.leaving{animation:toastOut .3s ease forwards}.toast.success{background:#00e87a26;border-color:var(--success);color:var(--success)}.toast.warning{background:#ffd60a26;border-color:var(--warning);color:var(--warning)}.toast.error{background:#ff3d3d26;border-color:var(--danger);color:var(--danger)}.toast.info{background:#4cc9f026;border-color:var(--info);color:var(--info)}@keyframes toastIn{0%{transform:translate(-50%) translateY(-80px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes toastOut{to{transform:translate(-50%) translateY(-80px);opacity:0}}.offline-banner{position:absolute;top:60px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:7px 16px;background:#ff3d3d26;border:1px solid var(--danger);border-radius:20px;font-family:var(--font-mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--danger);z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:bannerPulse 2s ease infinite}.filter-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.filter-chip{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;gap:5px}.filter-chip:hover{border-color:var(--primary);color:var(--primary)}.filter-chip.active{background:var(--primary-dim);border-color:var(--primary);color:var(--primary)}.section-title{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin:16px 0 10px;display:flex;align-items:center;gap:8px}.section-title:after{content:"";flex:1;height:1px;background:var(--border)}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-icon{font-size:40px;margin-bottom:12px}.empty-title{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.empty-sub{font-size:12px}.emergency-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:#0a0000f7;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:32px}.emergency-title{font-size:32px;font-weight:800;color:var(--danger);letter-spacing:-1px;text-align:center;animation:emergencyPulse 1.5s ease infinite}@keyframes emergencyPulse{0%,to{text-shadow:0 0 20px rgba(255,61,61,.5)}50%{text-shadow:0 0 40px rgba(255,61,61,.9)}}.emergency-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%;max-width:500px}.emergency-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:28px 20px;border-radius:16px;border:2px solid;cursor:pointer;transition:all .2s;font-family:var(--font-display);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.emergency-btn .e-icon{font-size:36px}.emergency-btn.red{background:#ff3d3d26;border-color:var(--danger);color:var(--danger)}.emergency-btn.red:hover{background:#ff3d3d40}.emergency-btn.blue{background:#00d4ff1a;border-color:var(--primary);color:var(--primary)}.emergency-btn.blue:hover{background:#00d4ff33}.emergency-btn.green{background:#00e87a1a;border-color:var(--success);color:var(--success)}.emergency-btn.green:hover{background:#00e87a33}.emergency-btn.orange{background:#ff6b2b1a;border-color:var(--accent);color:var(--accent)}.emergency-btn.orange:hover{background:#ff6b2b33}.emergency-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center}.mono-output{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;font-family:var(--font-mono);font-size:11px;line-height:1.7;color:var(--text-mono);white-space:pre-wrap;overflow-x:auto;max-height:300px;overflow-y:auto}.map-legend{position:absolute;bottom:200px;left:16px;z-index:100;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;min-width:150px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.legend-title{font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px}.legend-item{display:flex;align-items:center;gap:8px;margin-bottom:7px;font-size:11px;color:var(--text-secondary)}.legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.search-bar{position:absolute;top:70px;left:50%;transform:translate(-50%);z-index:100;width:min(480px,calc(100vw - 32px));display:flex;gap:8px}.search-input-wrap{flex:1;position:relative}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:16px;color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:12px 14px 12px 40px;background:#0d1b2ef2;border:1px solid var(--border-bright);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-display);font-size:14px;outline:none;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:border-color .2s,box-shadow .2s}.search-input:focus{border-color:var(--primary);box-shadow:var(--primary-glow)}.search-input::placeholder{color:var(--text-muted)}.mesh-device{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;gap:10px}.mesh-device.synced{border-color:var(--success)}.device-signal{display:flex;gap:3px;align-items:flex-end}.signal-bar{width:4px;background:var(--success);border-radius:2px;opacity:.3}.signal-bar.active{opacity:1}.signal-bar:nth-child(1){height:6px}.signal-bar:nth-child(2){height:10px}.signal-bar:nth-child(3){height:14px}.signal-bar:nth-child(4){height:18px}@media (max-width: 640px){.side-panel{width:100vw}.ctrl-btn{padding:8px;min-width:48px}.ctrl-label{font-size:8px}.ctrl-icon{font-size:16px}.control-panel{padding:12px 8px 16px}.control-row{gap:5px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.fade-in{animation:fadeIn .3s ease}.slide-up{animation:slideUp .3s ease}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--danger);animation:livePulse 1.5s ease infinite;display:inline-block}@keyframes livePulse{0%,to{box-shadow:0 0 #ff3d3d66}50%{box-shadow:0 0 0 6px #ff3d3d00}}.panel-body{scrollbar-width:thin;scrollbar-color:var(--border-bright) transparent}
