*{margin:0;padding:0;box-sizing:border-box}:root{--panel-bg: rgba(15, 15, 30, .82);--panel-border: rgba(255, 255, 255, .08);--accent: #f0d9b5;--accent-dim: rgba(240, 217, 181, .3);--text-primary: #f0f0f5;--text-secondary: #9a9ab0;--text-dim: #666680;--radius: 16px;--radius-sm: 10px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden;background:#0a0a1e;color:var(--text-primary);-webkit-font-smoothing:antialiased;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}#canvas-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0}canvas{display:block;touch-action:none}#canvas-container:after{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(ellipse 80% 70% at 50% 45%,transparent 50%,rgba(0,0,0,.12) 100%);z-index:1}.street-label{background:#0f0f1ea6;color:#e8e8f0;padding:2px 8px;border-radius:10px;font-family:Inter,sans-serif;font-size:10px;letter-spacing:.06em;font-weight:500;white-space:nowrap;pointer-events:none;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);-webkit-user-select:none;user-select:none;text-shadow:0 1px 2px rgba(0,0,0,.3)}#loading{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0a0a1e,#141428,#1a1a35);display:flex;align-items:center;justify-content:center;z-index:100;transition:opacity .8s ease,transform .8s ease}#loading.hidden{opacity:0;transform:scale(1.02);pointer-events:none}.loading-content{text-align:center}.loading-icon{color:var(--accent);margin-bottom:1.5rem;opacity:.8;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}#loading h1{font-family:JetBrains Mono,Courier New,monospace;font-size:1.6rem;font-weight:600;letter-spacing:.25em;color:var(--accent);margin-bottom:2rem}.loading-bar-track{width:200px;height:3px;background:#ffffff0f;border-radius:3px;margin:0 auto 1.2rem;overflow:hidden}.loading-bar{width:0%;height:100%;background:var(--accent);border-radius:3px;transition:width .4s ease}#loading .status{font-size:.78rem;color:var(--text-dim);letter-spacing:.05em}#ui{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}#weather-panel{position:absolute;top:20px;left:20px;background:var(--panel-bg);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border:1px solid var(--panel-border);border-radius:var(--radius);padding:20px 24px 18px;pointer-events:auto;min-width:200px;max-height:calc(100vh - 120px);overflow-y:auto;box-shadow:0 8px 32px #0000004d}#weather-panel::-webkit-scrollbar{width:0}#location-name{font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:600;color:var(--text-secondary);letter-spacing:.18em;text-transform:uppercase;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.temp-row{display:flex;align-items:center;gap:8px}#temperature{font-size:3.2rem;font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-.02em}#weather-icon{font-size:1.8rem;line-height:1}#condition{font-size:.85rem;font-weight:400;color:var(--text-secondary);margin-bottom:12px;margin-top:2px}.divider{height:1px;background:var(--panel-border);margin-bottom:12px}#details{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px}.detail-item{display:flex;flex-direction:column;gap:1px}.detail-label{font-size:.62rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.detail-value{font-family:JetBrains Mono,monospace;font-size:.78rem;color:var(--text-secondary);font-weight:400}#daily-forecast{display:flex;flex-direction:column;gap:4px}.daily-row{display:flex;align-items:center;justify-content:space-between;padding:6px 4px;border-radius:6px;cursor:pointer;transition:background .15s;gap:8px}.daily-row:hover{background:#ffffff0d}.daily-row.active{background:#f0d9b51a}.daily-day{font-size:.72rem;font-weight:500;color:var(--text-secondary);min-width:36px}.daily-icon{font-size:1rem;line-height:1;min-width:24px;text-align:center}.daily-temps{font-family:JetBrains Mono,monospace;font-size:.7rem;color:var(--text-secondary);display:flex;gap:4px;align-items:baseline}.daily-high{color:var(--text-primary);font-weight:600}.daily-low{color:var(--text-dim);font-weight:400}#forecast-bar{position:absolute;bottom:64px;left:50%;transform:translate(-50%);max-width:90vw;width:540px;pointer-events:auto;background:var(--panel-bg);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border:1px solid var(--panel-border);border-radius:var(--radius);padding:8px 4px;box-shadow:0 8px 32px #0000004d;display:none}#forecast-scroll{display:flex;overflow-x:auto;scroll-snap-type:x proximity;gap:2px;padding:0 4px}#forecast-scroll::-webkit-scrollbar{display:none}#forecast-scroll{-ms-overflow-style:none;scrollbar-width:none}.forecast-cell{flex:0 0 54px;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;border-radius:8px;cursor:pointer;scroll-snap-align:center;transition:background .15s}.forecast-cell:hover{background:#ffffff0d}.forecast-cell.active{background:#f0d9b526;box-shadow:inset 0 0 0 1px var(--accent-dim)}.forecast-hour{font-size:.58rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.forecast-icon{font-size:1rem;line-height:1}.forecast-temp{font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:500;color:var(--text-secondary)}#controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:6px;pointer-events:auto}#search-box{background:var(--panel-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--panel-border);border-radius:var(--radius-sm);padding:10px 16px;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.82rem;width:240px;outline:none;transition:border-color .2s,box-shadow .2s;box-shadow:0 4px 16px #0003}#search-box::placeholder{color:var(--text-dim)}#search-box:focus{border-color:var(--accent-dim);box-shadow:0 4px 16px #0003,0 0 0 2px #f0d9b51a}.btn{background:var(--panel-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--panel-border);border-radius:var(--radius-sm);padding:10px 12px;color:var(--accent);cursor:pointer;transition:background .2s,border-color .2s,transform .1s;white-space:nowrap;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0003}.btn:hover{background:#1e1e37e6;border-color:var(--accent-dim)}.btn:active{transform:scale(.96)}#poi-toggle-btn{font-size:.72rem;padding:8px 12px;letter-spacing:.02em}#theme-selector{position:absolute;top:20px;right:20px;display:flex;gap:6px;pointer-events:auto;z-index:11}.theme-swatch{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.15);cursor:pointer;transition:transform .15s,border-color .2s,box-shadow .2s;box-shadow:0 2px 8px #0000004d;outline:none;padding:0}.theme-swatch:hover{transform:scale(1.15);border-color:#fff6}.theme-swatch.active{border-color:#ffffffe6;box-shadow:0 0 0 2px #fff3,0 2px 8px #0000004d;transform:scale(1.1)}#credits{position:absolute;bottom:20px;right:20px;font-size:.6rem;color:var(--text-dim);pointer-events:auto;letter-spacing:.03em}#credits a{color:var(--text-secondary);text-decoration:none;transition:color .2s}#credits a:hover{color:var(--accent)}#error-toast{position:fixed;top:20px;right:20px;background:#a03232eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,100,100,.2);border-radius:var(--radius-sm);padding:12px 16px;font-size:.78rem;color:#fdd;z-index:200;opacity:0;transform:translateY(-8px);transition:opacity .3s,transform .3s;pointer-events:none;max-width:320px;box-shadow:0 8px 24px #0006}#error-toast.visible{opacity:1;transform:translateY(0)}.poi-icon{font-size:14px;background:#0f0f1e80;padding:1px 4px;border-radius:8px;pointer-events:none;white-space:nowrap;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);-webkit-user-select:none;user-select:none;color:#e8e8f0;max-width:120px;overflow:hidden;text-overflow:ellipsis}#canvas-container canvas.night-glow{filter:contrast(1.1) brightness(1.05)}#time-slider-container{padding:8px 16px 4px}#time-display{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:6px}#time-label{font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:600;color:var(--text-primary)}#time-icon{font-size:1.1rem;line-height:1}#time-temp{font-family:JetBrains Mono,monospace;font-size:.82rem;color:var(--text-secondary)}#time-slider-row{display:flex;align-items:center;gap:8px}#time-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:#ffffff1a;border-radius:3px;outline:none;cursor:pointer}#time-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:grab;box-shadow:0 2px 6px #0000004d;transition:transform .1s}#time-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.2)}#time-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);border:none;cursor:grab;box-shadow:0 2px 6px #0000004d}#time-marks{display:flex;justify-content:space-between;padding:2px 0;font-size:.55rem;color:var(--text-dim);font-family:JetBrains Mono,monospace;letter-spacing:.02em}#time-play-btn{background:none;border:none;color:var(--accent);cursor:pointer;padding:4px;opacity:.6;transition:opacity .2s;flex-shrink:0}#time-play-btn:hover{opacity:1}#time-play-btn.playing svg{display:none}#time-play-btn.playing:after{content:"u23F8";font-size:14px}#minutecast-bar{position:absolute;bottom:100px;left:50%;transform:translate(-50%);width:min(90vw,460px);z-index:10;pointer-events:auto}.minutecast-text{font-size:11px;color:#ffffffe6;text-align:center;margin-bottom:4px;text-shadow:0 1px 3px rgba(0,0,0,.5)}.minutecast-scroll{display:flex;gap:0;height:16px;border-radius:4px;overflow:hidden;background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.minutecast-segment{flex:1;min-width:3px;position:relative;transition:background-color .3s}.minutecast-segment.active{border:1px solid rgba(255,255,255,.8);border-radius:2px;z-index:1}#mobile-sheet,#sheet-backdrop{display:none}@media(max-width:767px){#weather-panel,#forecast-bar,#minutecast-bar,#controls,#theme-selector,#credits{display:none!important}#mobile-sheet{display:block;position:fixed;left:0;right:0;bottom:0;height:85vh;transform:translateY(calc(85vh - 56px));padding-bottom:env(safe-area-inset-bottom);background:var(--panel-bg);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border:1px solid var(--panel-border);border-bottom:none;border-radius:16px 16px 0 0;z-index:20;pointer-events:auto;touch-action:none;will-change:transform;overflow:hidden;box-shadow:0 -4px 32px #0000004d}#mobile-sheet.animating{transition:transform .3s cubic-bezier(.25,.46,.45,.94)}#sheet-handle{display:flex;justify-content:center;padding:8px 0 4px;cursor:grab}#sheet-handle:active{cursor:grabbing}.handle-bar{width:40px;height:4px;border-radius:2px;background:#ffffff4d}#sheet-peek{display:flex;align-items:center;padding:0 16px 8px;gap:10px;min-height:36px;cursor:pointer}#peek-location{font-family:JetBrains Mono,monospace;font-size:.65rem;font-weight:600;color:var(--text-secondary);letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:40%;flex-shrink:1}#peek-temp{font-size:1.6rem;font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-.02em;flex-shrink:0}#peek-icon{font-size:1.2rem;line-height:1;flex-shrink:0}#peek-time-bar{flex:1;height:3px;background:#ffffff1a;border-radius:2px;overflow:hidden;min-width:40px;cursor:pointer}#peek-time-progress{height:100%;background:var(--accent);border-radius:2px;width:50%;transition:width .3s ease}#sheet-content{overflow-y:auto;-webkit-overflow-scrolling:touch;height:calc(85vh - 56px);padding:0 16px 24px;overscroll-behavior:contain}#sheet-content::-webkit-scrollbar{width:0}.sheet-section-label{font-size:.6rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin:16px 0 8px}.sheet-divider{height:1px;background:var(--panel-border);margin:12px 0}#mobile-sheet #time-slider-container{padding:4px 0}#mobile-sheet #forecast-scroll{padding:0}#mobile-sheet #forecast-bar{display:block!important;position:static;background:none;backdrop-filter:none;-webkit-backdrop-filter:none;border:none;border-radius:0;padding:0;box-shadow:none;max-width:none;width:auto;transform:none}#mobile-sheet #details{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px}#mobile-sheet #minutecast-bar{position:static;width:auto;transform:none}#mobile-sheet #controls{display:flex!important;position:static;transform:none;gap:6px}#mobile-sheet #search-box{flex:1;width:auto}#mobile-sheet #theme-selector{display:flex!important;position:static;flex-direction:row;gap:8px}#mobile-sheet #daily-forecast{display:flex;flex-direction:column;gap:4px}#mobile-sheet #daily-divider{display:block!important}#mobile-sheet .daily-row{padding:6px 4px}#sheet-backdrop{display:none;position:fixed;inset:0;background:#0000;z-index:19;pointer-events:none;transition:background .3s ease}#sheet-backdrop.visible{display:block;pointer-events:auto;background:#00000026}.street-label{font-size:8px;padding:1px 5px;background:#0f0f1e73;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.poi-icon{font-size:11px;padding:1px 3px;max-width:90px}#mobile-sheet #time-slider{height:4px}#mobile-sheet #time-slider::-webkit-slider-thumb{width:14px;height:14px}#mobile-sheet #time-slider::-moz-range-thumb{width:14px;height:14px}#mobile-sheet #time-marks{font-size:.5rem;padding:1px 0}#mobile-sheet #time-display{margin-bottom:4px}}@media(min-width:768px){#mobile-sheet,#sheet-backdrop{display:none!important}}@media(max-width:380px){#peek-temp{font-size:1.4rem}#peek-location{max-width:30%;font-size:.58rem}}#layer-panel{position:absolute;top:20px;right:20px;margin-top:48px;background:var(--panel-bg);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border:1px solid var(--panel-border);border-radius:var(--radius);padding:12px 14px;pointer-events:auto;min-width:140px;box-shadow:0 8px 32px #0000004d;z-index:10}.layer-panel-title{font-family:JetBrains Mono,monospace;font-size:.58rem;font-weight:600;color:var(--text-dim);letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}.layer-toggle{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:6px;cursor:pointer;transition:background .15s,opacity .15s;-webkit-user-select:none;user-select:none}.layer-toggle:hover{background:#ffffff0d}.layer-toggle .layer-dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--text-dim);flex-shrink:0;transition:background .15s,border-color .15s}.layer-toggle.active .layer-dot{background:var(--accent);border-color:var(--accent)}.layer-toggle .layer-icon{font-size:.82rem;line-height:1}.layer-toggle .layer-name{font-size:.7rem;font-weight:500;color:var(--text-secondary);letter-spacing:.02em}.layer-toggle:not(.active) .layer-name{color:var(--text-dim);opacity:.6}#mode-panel{position:absolute;top:20px;right:20px;display:flex;flex-direction:column;gap:4px;pointer-events:auto;margin-top:380px;z-index:10}.mode-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--panel-bg);backdrop-filter:blur(16px) saturate(1.1);-webkit-backdrop-filter:blur(16px) saturate(1.1);border:1px solid var(--panel-border);border-radius:8px;cursor:pointer;transition:background .15s,border-color .2s,transform .1s;color:var(--text-secondary);box-shadow:0 2px 8px #0003}.mode-btn:hover{background:#1e1e37e6;border-color:var(--accent-dim)}.mode-btn:active{transform:scale(.96)}.mode-btn.active{border-color:var(--accent);background:#f0d9b514}.mode-icon{font-size:1rem;line-height:1}.mode-label{font-size:.65rem;font-weight:600;letter-spacing:.04em;color:inherit}.mode-btn.active .mode-label{color:var(--accent)}.mobile-layer-row{display:flex;gap:6px;overflow-x:auto;padding:4px 0 8px;-ms-overflow-style:none;scrollbar-width:none}.mobile-layer-row::-webkit-scrollbar{display:none}.mobile-layer-btn{flex-shrink:0;width:44px;height:44px;border-radius:50%;border:2px solid var(--panel-border);background:#ffffff0d;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .2s;color:var(--text-secondary)}.mobile-layer-btn.active{border-color:var(--accent);background:#f0d9b51f}.mobile-layer-btn:not(.active){opacity:.45}.mobile-mode-row{display:flex;gap:6px;overflow-x:auto;padding:4px 0 8px;-ms-overflow-style:none;scrollbar-width:none}.mobile-mode-row::-webkit-scrollbar{display:none}.mobile-mode-row .mode-btn{flex-shrink:0;padding:6px 12px;font-size:.7rem}@media(max-width:767px){#layer-panel,#mode-panel{display:none!important}}@media(min-width:768px){.mobile-layer-row,.mobile-mode-row{display:none!important}}
