*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-void: #060a12;--bg-deep: #0c1220;--bg-surface: #111827;--bg-elevated: #1a2335;--bg-card: #1e2d45;--bg-hover: #243452;--border-dim: rgba(96, 165, 250, .12);--border-glow: rgba(96, 165, 250, .35);--text-primary: #f0f4ff;--text-secondary: #94a3b8;--text-dim: #4b5e7a;--accent-blue: #3b82f6;--accent-cyan: #22d3ee;--accent-teal: #14b8a6;--accent-glow: rgba(59, 130, 246, .25);--alert-red: #ef4444;--alert-orange: #f97316;--alert-yellow: #eab308;--alert-green: #22c55e;--satellite-bg: #070d1a;--font-base: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--sidebar-w: 400px;--header-h: 52px;--alert-h: 40px;--ease-snappy: cubic-bezier(.25, .46, .45, .94);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1)}html,body{height:100%;font-family:var(--font-base);background:var(--bg-void);color:var(--text-primary);-webkit-font-smoothing:antialiased;overflow:hidden}#root{height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg-surface)}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-blue)}.app-shell{display:flex;flex-direction:column;height:100%}.alert-banner{height:var(--alert-h);flex-shrink:0;display:flex;align-items:center;overflow:hidden;padding:0 16px;gap:12px;border-bottom:1px solid var(--border-dim)}.alert-banner.severity-extreme,.alert-banner.severity-Extreme{background:#ef444433;border-color:#ef444466}.alert-banner.severity-Severe{background:#f973162e;border-color:#f9731666}.alert-banner.severity-Moderate{background:#eab3081f;border-color:#eab3084d}.alert-banner.severity-Minor{background:#22c55e14;border-color:#22c55e33}.alert-banner.no-alerts{background:transparent}.alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;animation:pulse-dot 1.5s ease-in-out infinite}.severity-Extreme .alert-dot,.severity-extreme .alert-dot{background:var(--alert-red)}.severity-Severe .alert-dot{background:var(--alert-orange)}.severity-Moderate .alert-dot{background:var(--alert-yellow)}.severity-Minor .alert-dot{background:var(--alert-green)}.no-alerts .alert-dot{background:var(--alert-green);animation:none}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.alert-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.7;flex-shrink:0}.alert-ticker{flex:1;overflow:hidden;white-space:nowrap}.alert-ticker-inner{display:inline-flex;gap:60px;animation:ticker 25s linear infinite;font-size:12px;color:var(--text-primary);font-weight:500}.alert-ticker-inner:hover{animation-play-state:paused}@keyframes ticker{0%{transform:translate(0)}to{transform:translate(-50%)}}.alert-count{font-size:11px;font-family:var(--font-mono);background:#3b82f626;border:1px solid var(--border-dim);border-radius:4px;padding:2px 8px;color:var(--accent-cyan);flex-shrink:0}.no-alerts-text{font-size:12px;color:var(--text-dim)}.app-header{height:var(--header-h);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:var(--bg-deep);border-bottom:1px solid var(--border-dim);z-index:100}.header-brand{display:flex;align-items:center;gap:10px}.header-logo{width:28px;height:28px;background:linear-gradient(135deg,var(--accent-blue),var(--accent-cyan));border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px}.header-logo-img{width:36px;height:36px;border-radius:8px;object-fit:contain;filter:drop-shadow(0 0 6px rgba(59,130,246,.5));flex-shrink:0}.header-title{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.header-subtitle{font-size:11px;font-family:var(--font-mono);color:var(--accent-cyan);opacity:.7}.header-status{display:flex;align-items:center;gap:16px}.status-pill{display:flex;align-items:center;gap:6px;font-size:11px;font-family:var(--font-mono);color:var(--text-secondary)}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--alert-green);animation:pulse-dot 2s ease-in-out infinite}.status-dot.stale{background:var(--alert-yellow)}.status-dot.error{background:var(--alert-red);animation:none}.app-content{flex:1;display:flex;overflow:hidden}.satellite-panel{flex:1;display:flex;flex-direction:column;background:var(--satellite-bg);position:relative;overflow:hidden}.satellite-map-container{flex:1;position:relative}.satellite-map-container .leaflet-container{background:var(--satellite-bg)!important;height:100%}.layer-sidebar{width:130px;flex-shrink:0;display:flex;flex-direction:column;gap:2px;padding:10px 8px;background:var(--bg-deep);border-right:1px solid var(--border-dim);overflow-y:auto;overflow-x:hidden;z-index:10}.sidebar-section-label{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-cyan);padding:6px 2px 3px;opacity:.8}.sidebar-group{display:flex;flex-direction:column;gap:2px;margin-bottom:2px}.sidebar-group-label{font-size:8px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);padding:2px 2px 1px;display:flex;align-items:center;gap:4px}.sidebar-group-buttons{display:flex;flex-direction:column;gap:2px}.sidebar-divider{height:1px;background:var(--border-dim);margin:6px 0}.layer-sidebar .band-btn{display:flex;align-items:center;gap:5px;width:100%;text-align:left;padding:5px 8px;font-size:10px}.band-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;transition:background .3s}.dot-ok{background:var(--alert-green)}.dot-stale{background:var(--alert-yellow)}.dot-sparse{background:var(--alert-orange)}.dot-empty{background:var(--alert-red)}.dot-loading{background:var(--text-dim)}.band-btn-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.band-frame-count{font-size:9px;font-family:var(--font-mono);color:var(--text-dim);flex-shrink:0;opacity:.7}.band-btn.active .band-frame-count{color:#fff9;opacity:1}.no-data-banner{position:absolute;bottom:20px;left:50%;transform:translate(-50%);z-index:600;display:flex;align-items:flex-start;gap:10px;padding:10px 16px;border-radius:10px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid;max-width:480px;width:calc(100% - 60px);box-shadow:0 4px 24px #00000080;animation:slide-up .25s var(--ease-bounce)}.no-data-banner-radar{bottom:88px}@keyframes slide-up{0%{transform:translate(-50%) translateY(12px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.no-data-banner.severity-error{background:#7f1d1dbf;border-color:#ef444480}.no-data-banner.severity-warn{background:#4e3409cc;border-color:#eab30873}.no-data-banner.severity-info{background:#0e2848d1;border-color:#60a5fa59}.no-data-icon{font-size:18px;line-height:1;flex-shrink:0;margin-top:1px}.no-data-text{display:flex;flex-direction:column;gap:3px}.no-data-title{font-size:12px;font-weight:700;color:var(--text-primary);letter-spacing:.01em}.no-data-detail{font-size:11px;color:var(--text-secondary);line-height:1.4}.backfill-btn{display:flex;align-items:center;gap:6px;padding:5px 12px;font-size:11px;font-weight:600;border-radius:6px;border:1px solid rgba(96,165,250,.35);background:#1e3a8a73;color:var(--accent-blue);cursor:pointer;transition:background .2s,border-color .2s;white-space:nowrap}.backfill-btn:hover{background:#2563eb8c;border-color:#60a5faa6}.backfill-btn.running{color:var(--alert-yellow);border-color:#eab30866;background:#4e340980}.backfill-spinner{display:inline-block;width:10px;height:10px;border:2px solid rgba(234,179,8,.3);border-top-color:var(--alert-yellow);border-radius:50%;animation:spin .8s linear infinite}.modal-box{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:14px;width:min(520px,96vw);max-height:88vh;display:flex;flex-direction:column;box-shadow:0 24px 80px #000000bf;overflow:hidden;animation:slide-up .2s var(--ease-bounce)}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px 12px;border-bottom:1px solid var(--border-dim)}.modal-title{font-size:15px;font-weight:700;color:var(--text-primary)}.modal-close{font-size:14px;background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px 8px;border-radius:4px;transition:color .2s}.modal-close:hover{color:var(--text-primary)}.modal-body{flex:1;overflow-y:auto;padding:20px}.back-to-live-btn{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:700;border-radius:20px;border:1px solid rgba(239,68,68,.5);background:#7f1d1d8c;color:#fca5a5;cursor:pointer;transition:background .2s,border-color .2s;white-space:nowrap;animation:pulse-live 2s ease-in-out infinite}.back-to-live-btn:hover{background:#b91c1ca6;border-color:#ef4444cc;animation:none}@keyframes pulse-live{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 0 4px #ef44442e}}.skyview-gen-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;font-size:12px;font-weight:700;border-radius:7px;border:1px solid rgba(34,211,238,.45);background:#06556480;color:var(--accent-cyan);cursor:pointer;transition:background .18s,border-color .18s,transform .12s;white-space:nowrap}.skyview-gen-btn:hover:not(:disabled){background:#08788ca6;border-color:var(--accent-cyan);transform:translateY(-1px)}.skyview-gen-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.backfill-modal{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:14px;width:min(680px,96vw);max-height:80vh;display:flex;flex-direction:column;box-shadow:0 24px 80px #000000b3;overflow:hidden;animation:slide-up .2s var(--ease-bounce)}.backfill-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 20px 14px;border-bottom:1px solid var(--border-dim)}.backfill-modal-title{font-size:15px;font-weight:700;color:var(--text-primary);display:block}.backfill-modal-subtitle{font-size:11px;color:var(--text-dim);display:block;margin-top:3px}.modal-close-btn{font-size:14px;background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px 6px;border-radius:4px;transition:color .2s;flex-shrink:0}.modal-close-btn:hover{color:var(--text-primary)}.backfill-log{flex:1;overflow-y:auto;padding:10px 16px;font-family:var(--font-mono);font-size:11px;line-height:1.6;background:#00000040;min-height:180px;max-height:340px}.log-line{white-space:pre}.log-header{color:var(--accent-blue);font-weight:700}.log-info{color:var(--text-secondary)}.log-active{color:var(--accent-cyan)}.log-new{color:var(--alert-green)}.log-cached{color:var(--text-dim);opacity:.55}.log-error{color:var(--alert-red)}.log-done{color:var(--alert-green);font-weight:700}.log-dim{color:var(--text-dim)}.log-pulse{color:var(--accent-cyan);animation:pulse-text 1.2s ease-in-out infinite}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.35}}.backfill-summary{padding:12px 20px;border-top:1px solid var(--border-dim)}.bf-table{width:100%;border-collapse:collapse;font-size:12px}.bf-table th{text-align:left;padding:4px 8px;color:var(--text-dim);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.05em}.bf-table td{padding:5px 8px;color:var(--text-secondary);border-top:1px solid var(--border-dim)}.bf-new{color:var(--alert-green)!important;font-weight:700}.bf-skip{color:var(--text-dim)!important}.bf-err{color:var(--alert-red)!important}.bf-elapsed{display:block;font-size:10px;color:var(--text-dim);margin-top:6px;text-align:right}.backfill-modal-footer{padding:12px 20px;border-top:1px solid var(--border-dim);display:flex;align-items:center;justify-content:flex-end}.bf-run-btn{padding:6px 16px;font-size:12px;font-weight:600;border-radius:6px;border:1px solid rgba(96,165,250,.4);background:#2563eb66;color:var(--accent-blue);cursor:pointer;transition:background .2s}.bf-run-btn:hover{background:#2563eba6}.map-ctx-menu{position:absolute;z-index:700;min-width:160px;background:#060a18eb;border:1px solid var(--border-glow);border-radius:10px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 8px 32px #0009,0 0 0 1px #22d3ee14;overflow:hidden;animation:ctx-pop .12s var(--ease-bounce);pointer-events:auto}@keyframes ctx-pop{0%{opacity:0;transform:scale(.93) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.map-ctx-coords{padding:7px 12px 5px;font-size:10px;font-family:var(--font-mono);color:var(--text-dim);border-bottom:1px solid var(--border-dim);letter-spacing:.03em}.map-ctx-item{display:flex;align-items:center;gap:7px;width:100%;padding:9px 12px;background:transparent;border:none;color:var(--accent-cyan);font-size:12px;font-weight:600;cursor:pointer;transition:background .15s;text-align:left}.map-ctx-item:hover{background:#22d3ee1a}.skyview-modal{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:14px;width:min(1300px,96vw);max-height:92vh;display:flex;flex-direction:column;box-shadow:0 24px 80px #000000bf;overflow:hidden;animation:slide-up .2s var(--ease-bounce)}.skyview-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 20px 14px;border-bottom:1px solid var(--border-dim)}.skyview-inputs{display:flex;align-items:flex-end;gap:12px;padding:16px 20px 12px;background:#00000026;border-bottom:1px solid var(--border-dim);flex-wrap:wrap}.skyview-divider-v{width:1px;align-self:stretch;background:var(--border-dim);flex-shrink:0;margin:0 4px}.skyview-field-sm{flex:0 0 72px;min-width:64px}.skyview-field{display:flex;flex-direction:column;gap:5px;flex:1;min-width:120px}.skyview-field-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim)}.skyview-input{padding:7px 10px;border-radius:6px;border:1px solid var(--border-dim);background:#060a12b3;color:var(--text-primary);font-size:13px;font-family:var(--font-mono);transition:border-color .18s;width:100%}.skyview-input:focus{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 0 2px #22d3ee26}.skyview-input::-webkit-inner-spin-button,.skyview-input::-webkit-outer-spin-button{opacity:.4}.skyview-input:disabled{opacity:.55;cursor:not-allowed}.skyview-auto-alt-btn{flex-shrink:0;padding:0 9px;height:34px;border-radius:6px;border:1px solid rgba(34,211,238,.3);background:#06556459;color:var(--accent-cyan);font-size:15px;line-height:1;cursor:pointer;transition:background .18s,border-color .18s,transform .12s;white-space:nowrap}.skyview-auto-alt-btn:hover:not(:disabled){background:#08788c8c;border-color:var(--accent-cyan);transform:translateY(-1px)}.skyview-auto-alt-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.skyview-generate-btn{display:flex;align-items:center;gap:6px;padding:8px 18px;font-size:12px;font-weight:700;border-radius:7px;border:1px solid rgba(34,211,238,.45);background:#06556480;color:var(--accent-cyan);cursor:pointer;transition:background .18s,border-color .18s,transform .12s;white-space:nowrap;flex-shrink:0;align-self:flex-end;height:36px}.skyview-generate-btn:hover{background:#08788ca6;border-color:var(--accent-cyan);transform:translateY(-1px)}.skyview-generate-btn:active{transform:scale(.97)}.skyview-generate-btn.loading{color:var(--accent-cyan);opacity:.75;cursor:not-allowed}.skyview-generate-btn:disabled{cursor:not-allowed}.skyview-animate-btn{border-color:#a78bfa73!important;background:#4c1d9559!important;color:#c4b5fd!important}.skyview-animate-btn:hover:not(:disabled){background:#6d28d98c!important;border-color:#a78bfa!important;transform:translateY(-1px)}.skyview-animate-btn.loading{color:#a78bfa!important;opacity:.75}.skyview-gif-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;margin-bottom:8px;border-radius:20px;background:#4c1d9566;border:1px solid rgba(167,139,250,.35);color:#c4b5fd;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.skyview-anim-progress{width:100%;max-width:380px;height:4px;background:var(--bg-elevated);border-radius:4px;overflow:hidden;margin-top:8px}.skyview-anim-bar{height:100%;width:40%;background:linear-gradient(90deg,transparent 0%,#a78bfa 50%,transparent 100%);border-radius:4px;animation:anim-shimmer 1.6s ease-in-out infinite}@keyframes anim-shimmer{0%{transform:translate(-150%)}to{transform:translate(350%)}}.skyview-error{margin:12px 20px 0;padding:8px 14px;border-radius:6px;background:#7f1d1d80;border:1px solid rgba(239,68,68,.4);color:#fca5a5;font-size:12px}.skyview-result{padding:12px 16px 16px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;overflow-y:auto}.skyview-chart-img{width:100%;border-radius:8px;border:1px solid var(--border-dim);display:block}.skyview-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:48px 24px;color:var(--text-dim);font-size:13px;text-align:center;line-height:1.5}.skyview-placeholder-icon{font-size:40px;opacity:.35;line-height:1}.skyview-placeholder-hint{font-size:11px;color:var(--text-dim);opacity:.7;max-width:480px}.skyview-btn{color:var(--accent-cyan)!important;border-color:#22d3ee33!important;margin-top:3px}.skyview-btn:hover{background:#22d3ee14!important;border-color:#22d3ee73!important}.skyview-pin{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;animation:skypin-drop .35s cubic-bezier(.34,1.56,.64,1);cursor:grab}.skyview-pin:active{cursor:grabbing}@keyframes skypin-drop{0%{transform:translateY(-20px) scale(.7);opacity:0}60%{transform:translateY(3px) scale(1.05);opacity:1}to{transform:translateY(0) scale(1);opacity:1}}.skyview-pin-crosshair{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.skyview-pin-h,.skyview-pin-v{position:absolute;background:#facc15;opacity:.85}.skyview-pin-h{top:50%;left:0;right:0;height:1.5px;transform:translateY(-50%)}.skyview-pin-v{left:50%;top:0;bottom:0;width:1.5px;transform:translate(-50%)}.skyview-pin-dot{width:10px;height:10px;border-radius:50%;background:#facc15;border:2px solid #1a1a1a;box-shadow:0 0 8px #facc15b3,0 0 16px #facc154d;z-index:1;flex-shrink:0}.skyview-pin-label{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);white-space:nowrap;background:#060a18e0;border:1px solid rgba(250,204,21,.45);color:#fde68a;font-size:10px;font-weight:600;padding:3px 8px;border-radius:6px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;opacity:0;transition:opacity .15s}.skyview-pin:hover .skyview-pin-label{opacity:1}.skyview-ring-handle{width:16px;height:16px;border-radius:50%;background:#060a18d9;border:2px solid #facc15;box-shadow:0 0 6px #facc1580;cursor:ew-resize;transition:box-shadow .15s,transform .15s}.skyview-ring-handle:hover{box-shadow:0 0 12px #facc15d9;transform:scale(1.25)}.map-zoom-controls{position:absolute;right:14px;top:50%;transform:translateY(-50%);z-index:500;display:flex;flex-direction:column;gap:4px}.zoom-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border-glow);background:#060a12d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-primary);font-size:20px;font-weight:300;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s var(--ease-snappy);-webkit-user-select:none;user-select:none}.zoom-btn:hover{background:var(--bg-hover);border-color:var(--accent-cyan);color:var(--accent-cyan);box-shadow:0 0 10px var(--accent-glow);transform:scale(1.08)}.zoom-btn:active{transform:scale(.94)}.band-group{display:flex;flex-direction:column;gap:4px}.band-group-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);padding:0 2px;display:flex;align-items:center;gap:4px}.band-group-note{font-size:8px;font-weight:500;letter-spacing:.05em;opacity:.7}.band-group-buttons{display:flex;flex-wrap:wrap;gap:3px}.band-btn{padding:4px 8px;border-radius:5px;border:1px solid transparent;background:transparent;color:var(--text-secondary);font-size:10px;font-family:var(--font-mono);font-weight:600;cursor:pointer;transition:all .18s var(--ease-snappy);letter-spacing:.02em;white-space:nowrap}.band-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-dim)}.band-btn.active{background:var(--accent-blue);color:#fff;border-color:#ffffff26;box-shadow:0 0 8px var(--accent-glow)}.band-divider{width:1px;background:#ffffff1f;margin:0 4px;align-self:stretch}.timeline-controls{flex-shrink:0;padding:10px 16px;background:linear-gradient(to top,#060a12fa,#060a12d9);border-top:1px solid var(--border-dim);display:flex;flex-direction:column;gap:8px}.timeline-header{display:flex;align-items:center;justify-content:space-between}.timeline-label{font-size:11px;font-family:var(--font-mono);color:var(--accent-cyan);font-weight:500}.timeline-time-block{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.timeline-time{font-size:12px;font-family:var(--font-mono);color:var(--text-primary);font-weight:600}.timeline-time-local{font-size:10px;font-family:var(--font-mono);color:var(--text-dim);font-weight:400}.timeline-row{display:flex;align-items:center;gap:12px}.play-btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--border-glow);background:var(--accent-blue);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;transition:all .2s var(--ease-bounce);flex-shrink:0}.play-btn:hover{transform:scale(1.1);background:#2563eb}.play-btn:active{transform:scale(.95)}.timeline-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;border-radius:4px;background:var(--bg-elevated);outline:none;cursor:pointer}.timeline-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-blue);border:2px solid white;box-shadow:0 0 8px #3b82f699;cursor:pointer;transition:transform .15s var(--ease-bounce)}.timeline-slider::-webkit-slider-thumb:hover{transform:scale(1.3)}.frame-count{font-size:10px;font-family:var(--font-mono);color:var(--text-dim);flex-shrink:0;white-space:nowrap}.timeline-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.utc-input-wrap{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.utc-input-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);flex-shrink:0}.utc-input{flex:1;min-width:140px;max-width:190px;padding:4px 8px;background:var(--bg-surface);border:1px solid var(--border-dim);border-radius:5px;color:var(--text-primary);font-size:11px;font-family:var(--font-mono);outline:none;transition:border-color .15s,box-shadow .15s;caret-color:var(--accent-cyan)}.utc-input:focus{border-color:var(--border-glow);box-shadow:0 0 0 2px var(--accent-glow)}.utc-input.error{border-color:var(--alert-red);box-shadow:0 0 0 2px #ef444433}.utc-input::placeholder{color:var(--text-dim);opacity:.6}.utc-range-hint{font-size:9px;font-family:var(--font-mono);color:var(--text-dim);white-space:nowrap;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;max-width:200px}.speed-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}.speed-label{font-size:10px;color:var(--text-dim);font-family:var(--font-mono);margin-right:2px}.speed-btn{padding:3px 8px;border-radius:4px;border:1px solid var(--border-dim);background:var(--bg-elevated);color:var(--text-secondary);font-size:10px;font-family:var(--font-mono);cursor:pointer;transition:all .15s}.speed-btn:hover,.speed-btn.active{background:var(--bg-hover);color:var(--accent-cyan);border-color:var(--border-glow)}.satellite-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--satellite-bg);z-index:10}.satellite-spinner{width:48px;height:48px;border:3px solid var(--border-dim);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.satellite-loading p{font-size:13px;color:var(--text-secondary);font-family:var(--font-mono)}.sidebar{width:var(--sidebar-w);flex-shrink:0;display:flex;flex-direction:column;background:var(--bg-deep);border-left:1px solid var(--border-dim);overflow:hidden}.city-strip{padding:12px;border-bottom:1px solid var(--border-dim);display:flex;flex-direction:column;gap:8px}.city-strip-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim)}.city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.city-chip{padding:8px 6px;border-radius:8px;border:1px solid var(--border-dim);background:var(--bg-surface);cursor:pointer;transition:all .2s var(--ease-snappy);text-align:center}.city-chip:hover{background:var(--bg-hover);border-color:var(--border-glow)}.city-chip.active{background:var(--bg-card);border-color:var(--accent-blue);box-shadow:0 0 12px var(--accent-glow)}.city-chip-emoji{font-size:16px;line-height:1;display:block}.city-chip-name{font-size:10px;font-weight:600;color:var(--text-secondary);margin-top:3px}.city-chip-temp{font-size:13px;font-weight:700;color:var(--text-primary)}.conditions-card{margin:12px;padding:16px;background:var(--bg-surface);border:1px solid var(--border-dim);border-radius:12px;display:flex;gap:16px;align-items:center}.conditions-main{flex:1}.conditions-city{font-size:13px;font-weight:600;color:var(--text-secondary)}.conditions-temp{font-size:48px;font-weight:700;line-height:1;background:linear-gradient(135deg,var(--text-primary),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.conditions-desc{font-size:12px;color:var(--text-secondary);margin-top:2px}.conditions-meta{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.conditions-emoji{font-size:40px}.meta-row{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-secondary)}.meta-row .icon{font-size:11px}.forecast-section{flex:1;display:flex;flex-direction:column;overflow:hidden}.section-header{padding:10px 14px;border-bottom:1px solid var(--border-dim);display:flex;align-items:center;justify-content:space-between}.section-title{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim)}.section-badge{font-size:10px;font-family:var(--font-mono);color:var(--accent-cyan);background:#22d3ee1a;border:1px solid rgba(34,211,238,.2);border-radius:4px;padding:2px 7px}.forecast-scroll{flex:1;overflow-y:auto;padding:10px}.hourly-list{display:flex;flex-direction:column;gap:4px}.hourly-item{display:grid;grid-template-columns:52px 28px 1fr 50px 60px;align-items:center;gap:8px;padding:7px 10px;border-radius:8px;transition:background .15s;cursor:default}.hourly-item:hover{background:var(--bg-elevated)}.hour-time{font-size:11px;font-family:var(--font-mono);color:var(--text-dim);font-weight:500}.hour-icon{font-size:16px;text-align:center}.hour-desc{font-size:11px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hour-temp{font-size:13px;font-weight:700;color:var(--text-primary);text-align:right;font-family:var(--font-mono)}.hour-precip{font-size:10px;font-family:var(--font-mono);color:var(--accent-cyan);text-align:right;display:flex;align-items:center;justify-content:flex-end;gap:2px}.hour-precip.dry{color:var(--text-dim)}.chart-container{padding:8px 10px;height:140px}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.leaflet-control-attribution{background:#060a12b3!important;color:var(--text-dim)!important;font-size:9px!important;border-radius:4px 0 0!important}.leaflet-control-attribution a{color:var(--text-dim)!important}.leaflet-control-zoom{border:1px solid var(--border-dim)!important;border-radius:8px!important;overflow:hidden}.leaflet-control-zoom a{background:#060a12d9!important;color:var(--text-secondary)!important;border:none!important;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.leaflet-control-zoom a:hover{background:var(--bg-hover)!important;color:#fff!important}.city-marker{background:transparent;border:none}.city-marker-inner{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer}.city-marker-dot{width:10px;height:10px;border-radius:50%;background:var(--accent-cyan);border:2px solid var(--bg-void);box-shadow:0 0 8px var(--accent-cyan)}.city-marker-label{background:#060a12d9;border:1px solid var(--border-dim);border-radius:4px;padding:1px 5px;font-size:10px;font-weight:600;white-space:nowrap;color:var(--text-primary);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.leaflet-image-layer{transition:opacity .3s ease}@media (max-width: 768px){.app-content{flex-direction:column}.sidebar{width:100%;height:320px;border-left:none;border-top:1px solid var(--border-dim)}:root{--sidebar-w: 100%}}.ac-marker{display:flex;align-items:center;justify-content:center;will-change:transform;filter:drop-shadow(0 0 4px rgba(0,0,0,.8));transition:filter .2s}.ac-marker:hover{filter:drop-shadow(0 0 6px rgba(255,255,255,.4));cursor:pointer}.ac-tooltip{background:#060a12eb!important;border:1px solid rgba(255,255,255,.15)!important;border-radius:6px!important;color:#e2e8f0!important;font-size:11px!important;font-family:var(--font-mono)!important;padding:4px 8px!important;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;box-shadow:0 4px 12px #0006!important}.ac-tooltip:before{display:none!important}.leaflet-tooltip.ac-tooltip{pointer-events:none}.adsb-toggle{min-width:52px;font-weight:700;letter-spacing:.02em}.adsb-toggle.active{color:#60a5fa;border-color:#60a5fa;background:#60a5fa1f;box-shadow:0 0 8px #60a5fa40}.geocolor-toggle{min-width:88px;font-weight:600}.geocolor-toggle.active{color:#a78bfa;border-color:#a78bfa;background:#a78bfa1f;box-shadow:0 0 8px #a78bfa40}.overlay-toggles{display:flex;flex-direction:column;gap:3px;align-self:center}.radar-toggle{min-width:68px;font-weight:700;letter-spacing:.02em}.radar-toggle.active{color:#4ade80;border-color:#4ade80;background:#4ade801f;box-shadow:0 0 8px #4ade804d}.radar-overlay{transition:opacity .25s ease}.site-product-row{display:flex;align-items:center;gap:4px;margin-top:6px;padding:5px 6px;background:#ffffff0a;border:1px solid var(--border-dim);border-radius:6px}.site-product-label{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);flex-shrink:0;margin-right:2px}.site-product-btn{flex:1;padding:3px 0;border-radius:4px;border:1px solid var(--border-dim);background:transparent;color:var(--text-dim);font-size:9px;font-family:var(--font-mono);font-weight:700;letter-spacing:.06em;cursor:pointer;transition:all .15s var(--ease-snappy);text-align:center}.site-product-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.site-product-btn.site-product-ref.active{background:#008e0040;border-color:#4ade80;color:#4ade80;box-shadow:0 0 6px #4ade804d}.site-product-btn.site-product-vel.active{background:#00a0ff2e;border-color:#38bdf8;color:#38bdf8;box-shadow:0 0 6px #38bdf84d}.site-product-btn.site-product-cc.active{background:#ff8c0033;border-color:#fb923c;color:#fb923c;box-shadow:0 0 6px #fb923c4d}.nexrad-site-marker{display:flex;flex-direction:column;align-items:center;gap:0;cursor:default;position:relative}.nexrad-site-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-70%);width:32px;height:32px;border-radius:50%;border:2px solid rgba(34,211,238,.8);box-shadow:0 0 10px #22d3ee80;animation:nexrad-pulse 2s ease-out infinite;pointer-events:none}@keyframes nexrad-pulse{0%{transform:translate(-50%,-70%) scale(.8);opacity:1}to{transform:translate(-50%,-70%) scale(2.2);opacity:0}}.nexrad-site-icon{font-size:20px;line-height:1;filter:drop-shadow(0 0 6px rgba(34,211,238,.8));position:relative;z-index:1}.nexrad-site-label{background:#060a12e0;border:1px solid rgba(34,211,238,.5);border-radius:4px;padding:1px 5px;font-size:9px;font-weight:700;font-family:var(--font-mono);letter-spacing:.06em;color:var(--accent-cyan);white-space:nowrap;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 0 8px #22d3ee33;position:relative;z-index:1;margin-top:2px}.nexrad-site-tooltip{background:#060a12eb!important;border:1px solid rgba(34,211,238,.35)!important;border-radius:7px!important;color:#e2e8f0!important;font-size:11px!important;font-family:var(--font-mono)!important;padding:6px 10px!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap;box-shadow:0 4px 16px #00000080,0 0 10px #22d3ee1a!important;line-height:1.6}.nexrad-site-tooltip strong{color:var(--accent-cyan)!important;font-weight:700}.nexrad-site-tooltip:before{display:none!important}.leaflet-tooltip.nexrad-site-tooltip{pointer-events:none}.subscribe-btn{display:flex;align-items:center;gap:6px;padding:5px 14px;font-size:11px;font-weight:700;border-radius:6px;border:1px solid rgba(34,211,238,.5);background:linear-gradient(135deg,#065564b3,#1e3a8ab3);color:var(--accent-cyan);cursor:pointer;transition:background .2s,border-color .2s,transform .12s;white-space:nowrap;letter-spacing:.02em}.subscribe-btn:hover{background:linear-gradient(135deg,#08788ccc,#2563ebcc);border-color:var(--accent-cyan);transform:translateY(-1px)}.subscribe-btn.is-pro{border-color:#22c55e80;background:#052e1699;color:var(--alert-green)}.modal-panel{position:relative;border-radius:16px;box-shadow:0 32px 96px #000c;animation:slide-up .22s var(--ease-bounce);overflow:hidden}.subscribe-modal{background:linear-gradient(160deg,#0d1627,#111f3a 60%,#0a1f2f);border:1px solid rgba(34,211,238,.25);width:min(440px,96vw);padding:32px 28px 24px;text-align:center}.subscribe-modal .modal-close{position:absolute;top:14px;right:16px;font-size:16px;background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s}.subscribe-modal .modal-close:hover{color:var(--text-primary)}.subscribe-header{margin-bottom:20px}.subscribe-icon{font-size:36px;margin-bottom:10px;filter:drop-shadow(0 0 12px rgba(34,211,238,.4))}.subscribe-header h2{font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:8px}.subscribe-tagline{font-size:13px;color:var(--text-secondary);line-height:1.5}.subscribe-features{list-style:none;text-align:left;background:#00000040;border:1px solid var(--border-dim);border-radius:10px;padding:14px 18px;margin:0 0 20px;display:flex;flex-direction:column;gap:8px}.subscribe-features li{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.feat-check{color:var(--alert-green);font-weight:700;font-size:14px;flex-shrink:0}.subscribe-price{margin-bottom:20px}.price-amount{font-size:42px;font-weight:800;color:var(--text-primary);letter-spacing:-.04em}.price-period{font-size:16px;color:var(--text-secondary);font-weight:400}.subscribe-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.subscribe-divider{font-size:11px;color:var(--text-dim);text-align:center;position:relative}.subscribe-note{font-size:12px;color:var(--text-dim)}.subscribe-note strong{color:var(--text-secondary)}.subscribe-active-badge{font-size:14px;font-weight:700;color:var(--alert-green);background:#052e1699;border:1px solid rgba(34,197,94,.35);border-radius:8px;padding:8px 16px}.subscribe-error{font-size:12px;color:var(--alert-red);background:#7f1d1d4d;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:8px 12px;margin-top:8px}.subscribe-fine-print{font-size:11px;color:var(--text-dim);line-height:1.5;margin-top:4px}.btn-primary{display:flex;align-items:center;justify-content:center;gap:6px;padding:11px 20px;font-size:13px;font-weight:700;border-radius:8px;border:1px solid rgba(34,211,238,.5);background:linear-gradient(135deg,#065564cc,#1e3a8acc);color:var(--accent-cyan);cursor:pointer;transition:background .18s,transform .12s;width:100%;letter-spacing:.01em}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#08788ce6,#2563ebe6);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{display:flex;align-items:center;justify-content:center;padding:9px 20px;font-size:12px;font-weight:600;border-radius:8px;border:1px solid var(--border-dim);background:#ffffff0d;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s;width:100%}.btn-secondary:hover:not(:disabled){background:#ffffff1a;color:var(--text-primary)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{display:flex;align-items:center;justify-content:center;padding:7px 20px;font-size:11px;font-weight:500;border-radius:8px;border:none;background:none;color:var(--text-dim);cursor:pointer;transition:color .15s;width:100%}.btn-ghost:hover:not(:disabled){color:var(--text-secondary)}.btn-ghost:disabled{opacity:.4;cursor:not-allowed}.dsm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px}.dsm-modal{background:linear-gradient(160deg,#0d1e35,#081525);border:1px solid rgba(34,211,238,.2);border-radius:14px;box-shadow:0 24px 64px #000000b3,0 0 0 1px #22d3ee14;width:min(880px,100%);max-height:85vh;display:flex;flex-direction:column;overflow:hidden;font-family:var(--font-base, "Outfit", sans-serif)}.dsm-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 14px;border-bottom:1px solid rgba(34,211,238,.12);flex-shrink:0}.dsm-title{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:700;color:#e2f4ff;letter-spacing:.02em}.dsm-title-icon{font-size:18px}.dsm-title-sub{font-size:10px;font-weight:400;color:#4b6080;margin-left:4px}.dsm-header-actions{display:flex;align-items:center;gap:10px}.dsm-updated{font-size:10px;color:#3a5070}.dsm-refresh{background:none;border:1px solid rgba(34,211,238,.25);border-radius:6px;color:#22d3ee;font-size:16px;width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s;line-height:1}.dsm-refresh:hover{background:#22d3ee1f;transform:rotate(30deg)}.dsm-refresh:disabled{opacity:.4;cursor:not-allowed}.dsm-close{background:none;border:none;color:#4b6080;font-size:16px;cursor:pointer;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.dsm-close:hover{color:#e2f4ff;background:#ffffff0f}.dsm-body{overflow-y:auto;padding:18px 20px 0;flex:1}.dsm-loading,.dsm-error{display:flex;align-items:center;gap:12px;color:#4b6080;font-size:13px;padding:40px 0;justify-content:center}.dsm-error{color:#f87171}.dsm-spinner{width:18px;height:18px;border:2px solid rgba(34,211,238,.2);border-top-color:#22d3ee;border-radius:50%;animation:dsm-spin .8s linear infinite}@keyframes dsm-spin{to{transform:rotate(360deg)}}.dsm-heatmap-wrap{width:100%}.dsm-group{margin-bottom:18px}.dsm-group-header{display:flex;align-items:center;gap:7px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#3a5070;margin-bottom:6px;padding-left:2px}.dsm-group-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.dsm-axis-row{display:flex;align-items:flex-end;margin-bottom:4px}.dsm-cells-wrap{position:relative;flex:1;min-width:0;overflow:hidden}.dsm-x-label{position:absolute;bottom:0;font-size:8px;color:#2e4560;transform:translate(-50%);white-space:nowrap;pointer-events:none}.dsm-layer-row{display:flex;align-items:center;gap:10px;margin-bottom:3px}.dsm-layer-name{width:120px;flex-shrink:0;font-size:10px;color:#5a7a9a;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:6px}.dsm-cells{display:flex;gap:1px;height:18px;width:100%}.dsm-cell{flex:1;min-width:0;border-radius:2px;cursor:default;transition:filter .1s}.dsm-cell:hover{filter:brightness(1.5)}.dsm-layer-count{width:32px;flex-shrink:0;font-size:9px;color:#2e4560;text-align:left}.dsm-x-ends{display:flex;align-items:center;gap:10px;margin-top:4px;margin-bottom:16px}.dsm-x-end-label{position:absolute;font-size:8px;color:#2e4560}.dsm-x-end-label.left{left:0}.dsm-x-end-label.right{right:0}.dsm-legend{display:flex;align-items:center;gap:16px;padding:12px 0 18px;border-top:1px solid rgba(34,211,238,.08);margin-top:4px;flex-wrap:wrap}.dsm-legend-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#2e4560}.dsm-legend-item{display:flex;align-items:center;gap:5px;font-size:9px;color:#4b6080}.dsm-legend-swatch{width:12px;height:12px;border-radius:2px;border:1px solid rgba(255,255,255,.05)}.dsm-heal-badge{font-size:9px;font-weight:700;letter-spacing:.05em;color:#f59e0b;background:#f59e0b1f;border:1px solid rgba(245,158,11,.3);border-radius:4px;padding:2px 7px;animation:dsm-pulse 1.4s ease-in-out infinite}.dsm-heal-badge.is-done{color:#4ade80;background:#4ade801a;border-color:#4ade804d;animation:none}@keyframes dsm-pulse{0%,to{opacity:1}50%{opacity:.55}}
