@charset "UTF-8";:root{--color-primary-start: #2f6bd8;--color-primary-end: #48c7ff;--weather-primary: #2f65e0;--weather-secondary: #3fa0f8;--weather-accent: #2bb8f2;--weather-text-primary: #233552;--weather-text-secondary: #3c4c68;--weather-text-muted: #5b6b88;--weather-surface: rgba(255, 255, 255, .94);--weather-surface-blur: rgba(255, 255, 255, .86);--weather-surface-card: rgba(253, 254, 255, .97);--weather-border: rgba(47, 101, 224, .18);--weather-border-light: rgba(47, 101, 224, .12);--weather-shadow: rgba(15, 23, 42, .1);--weather-shadow-md: rgba(15, 23, 42, .16);--weather-shadow-lg: rgba(15, 23, 42, .22);--header-bg: rgba(146, 180, 230, .86);--header-bg-scrolled: rgba(72, 126, 204, .9);--header-border: rgba(84, 123, 212, .2);--header-text: #f7fbff;--header-control-bg: rgba(255, 255, 255, .16);--header-control-hover-bg: rgba(255, 255, 255, .22);--header-control-border: rgba(255, 255, 255, .28);--header-control-hover-border: rgba(255, 255, 255, .4);--header-control-color: #f7fbff;--bg-gradient-start: rgba(227, 237, 255, .6);--bg-gradient-mid: rgba(214, 240, 255, .48);--bg-gradient-end: rgba(255, 255, 255, .98);--bg-base: #f7f9fd;--home-shell-bg: radial-gradient(circle at 20% 18%, rgba(47, 107, 216, .18), transparent 26%), radial-gradient(circle at 78% 10%, rgba(42, 179, 255, .22), transparent 24%), linear-gradient(135deg, #f5f8ff 0%, #e9f0ff 55%, #fdfbff 100%);--home-ambient-1: #f3f7ff;--home-ambient-2: #e6edff;--home-surface: rgba(255, 255, 255, .94);--home-surface-strong: rgba(255, 255, 255, .98);--home-surface-soft: rgba(255, 255, 255, .88);--home-surface-ghost: rgba(255, 255, 255, .75);--home-border-soft: rgba(53, 86, 163, .2);--home-border-strong: rgba(53, 86, 163, .35);--home-border-glow: rgba(66, 134, 255, .32);--home-accent: #2563eb;--home-accent-2: #0ea5e9;--home-glow: rgba(37, 99, 235, .18);--home-gridline: rgba(47, 107, 216, .12);--home-text-strong: #516481;--home-text-muted: #64748b;--home-control-bg: rgba(255, 255, 255, .92);--home-control-strong: rgba(248, 250, 252, .98);--home-control-hover: rgba(59, 130, 246, .12);--home-control-border: rgba(71, 100, 163, .28);--home-shadow-soft: 0 2px 8px rgba(71, 100, 163, .12), 0 1px 3px rgba(71, 100, 163, .08);--home-shadow-strong: 0 4px 16px rgba(53, 86, 163, .18), 0 2px 6px rgba(53, 86, 163, .12);--bg-primary: #f7f9fd;--bg-secondary: #eef3ff;--bg-tertiary: #e2e8f5;--bg-header: var(--header-bg);--bg-card: rgba(255, 255, 255, .96);--bg-card-hover: rgba(255, 255, 255, .98);--text-primary: #233552;--text-secondary: #3c4c68;--text-muted: #5b6b88;--text-dark: #233552;--border-light: rgba(53, 86, 163, .16);--border-medium: rgba(53, 86, 163, .24);--border-dark: rgba(53, 86, 163, .32);--overlay-light: rgba(255, 255, 255, .15);--overlay-medium: rgba(47, 107, 216, .08);--overlay-dark: rgba(0, 0, 0, .25);--floating-btn-start: #6aa1fa;--floating-btn-end: #3b75f1;--floating-btn-hover-start: #5f9afa;--floating-btn-hover-end: #2c6af1;--floating-btn-shadow: 0 6px 24px rgba(59, 130, 246, .45), 0 2px 8px rgba(37, 99, 235, .3);--floating-btn-shadow-strong: 0 10px 32px rgba(59, 130, 246, .55), 0 4px 12px rgba(68, 123, 243, .4);--weather-temp-cold: #3b82f6;--weather-temp-cool: #06b6d4;--weather-temp-pleasant: #22c55e;--weather-temp-warm: #eab308;--weather-temp-hot: #f97316;--weather-temp-extreme: #ef4444;--weather-rain-none: #e2e8f0;--weather-rain-light: #bae6fd;--weather-rain-moderate: #7dd3fc;--weather-rain-heavy: #38bdf8;--weather-rain-intense: #0284c7;--weather-uv-low: #22c55e;--weather-uv-moderate: #eab308;--weather-uv-high: #f97316;--weather-uv-very-high: #ef4444;--weather-uv-extreme: #a855f7;--alpha-10: .1;--alpha-15: .15;--alpha-20: .2;--alpha-30: .3;--alpha-50: .5;--alpha-70: .7;--alpha-90: .9;--alpha-95: .95;--info-panel-surface: linear-gradient(180deg, #fdfefe 0%, #e7f0ff 100%);--info-panel-soft: rgba(245, 249, 255, .94);--info-panel-border: rgba(59, 130, 246, .18);--info-panel-shadow: 0 22px 72px rgba(53, 86, 163, .14);--info-panel-highlight: rgba(59, 130, 246, .14);--panel-header-gradient: linear-gradient(135deg, #f9fbff 0%, #e4edff 45%, #c9ddff 100%);--panel-header-text: #0f3f8c}[data-theme=dark]{--color-primary-start: #58b1ff;--color-primary-end: #8bd3ff;--weather-primary: #58b1ff;--weather-secondary: #7fc0ff;--weather-accent: #8bd3ff;--weather-text-primary: #e8f2ff;--weather-text-secondary: #c8dbf5;--weather-text-muted: #9fb5d6;--weather-surface: rgba(12, 22, 38, .95);--weather-surface-blur: rgba(12, 22, 38, .88);--weather-surface-card: rgba(12, 22, 38, .92);--weather-border: rgba(88, 177, 255, .3);--weather-border-light: rgba(88, 177, 255, .16);--weather-shadow: rgba(0, 0, 0, .45);--weather-shadow-md: rgba(0, 0, 0, .5);--weather-shadow-lg: rgba(0, 0, 0, .6);--header-bg: rgba(12, 22, 38, .88);--header-bg-scrolled: rgba(14, 30, 52, .94);--header-border: rgba(88, 177, 255, .26);--header-text: #e8f2ff;--header-control-bg: rgba(255, 255, 255, .08);--header-control-hover-bg: rgba(255, 255, 255, .12);--header-control-border: rgba(88, 177, 255, .24);--header-control-hover-border: rgba(139, 211, 255, .32);--header-control-color: #e8f2ff;--bg-gradient-start: rgba(6, 17, 33, .4);--bg-gradient-mid: rgba(8, 22, 40, .35);--bg-gradient-end: rgba(4, 10, 20, .6);--bg-base: #050d1a;--home-shell-bg: radial-gradient(circle at 18% 18%, rgba(88, 177, 255, .12), transparent 25%), radial-gradient(circle at 80% 12%, rgba(84, 152, 255, .18), transparent 28%), linear-gradient(135deg, #050d1a 0%, #0a1627 52%, #040a15 100%);--home-ambient-1: #050d1a;--home-ambient-2: #0a1627;--home-surface: rgba(10, 18, 32, .88);--home-surface-strong: rgba(12, 22, 40, .94);--home-surface-soft: rgba(12, 24, 41, .78);--home-surface-ghost: rgba(255, 255, 255, .05);--home-border-soft: rgba(88, 177, 255, .18);--home-border-strong: rgba(88, 177, 255, .32);--home-border-glow: rgba(88, 177, 255, .3);--home-accent: #7fd1ff;--home-accent-2: #58b1ff;--home-glow: rgba(88, 177, 255, .2);--home-gridline: rgba(88, 177, 255, .06);--home-text-strong: #e8f2ff;--home-text-muted: #9db4d6;--home-control-bg: rgba(255, 255, 255, .06);--home-control-strong: rgba(255, 255, 255, .1);--home-control-hover: rgba(88, 177, 255, .12);--home-control-border: rgba(88, 177, 255, .26);--home-shadow-soft: 0 18px 46px rgba(0, 0, 0, .45);--home-shadow-strong: 0 24px 66px rgba(0, 0, 0, .65);--floating-btn-start: #22d3ee;--floating-btn-end: #0ea5e9;--floating-btn-hover-start: #22d3ee;--floating-btn-hover-end: #0ea5e9;--floating-btn-shadow: 0 6px 24px rgba(56, 189, 248, .45), 0 2px 8px rgba(14, 165, 233, .3);--floating-btn-shadow-strong: 0 10px 32px rgba(56, 189, 248, .55), 0 4px 12px rgba(14, 165, 233, .4);--text-primary: #e8f2ff;--text-secondary: #c8dbf5;--text-muted: #9db4d6;--text-dark: #e5e7eb;--bg-primary: #050d1a;--bg-secondary: #0a1627;--bg-tertiary: #0d1b30;--bg-header: var(--header-bg);--bg-card: rgba(12, 22, 38, .94);--bg-card-hover: rgba(12, 22, 38, .98);--info-panel-surface: linear-gradient(180deg, rgba(10, 18, 32, .98) 0%, rgba(8, 24, 46, .94) 100%);--info-panel-soft: rgba(12, 24, 41, .86);--info-panel-border: rgba(88, 177, 255, .28);--info-panel-shadow: 0 28px 90px rgba(0, 0, 0, .68);--info-panel-highlight: rgba(88, 177, 255, .14);--panel-header-gradient: linear-gradient(135deg, #0b1f3a 0%, #0f305a 55%, #164a78 100%);--panel-header-text: #e8f2ff}*{transition:background-color .3s ease,border-color .3s ease,color .3s ease,box-shadow .3s ease}*:where(.leaflet-container,.leaflet-pane,img,svg,path,circle,rect){transition:none!important}:root{font-size:16px}@media(max-width:1024px){:root{font-size:15px}}@media(max-width:768px){:root{font-size:14px}}@media(max-width:480px){:root{font-size:13px}}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}*{margin:0;padding:0;box-sizing:border-box}html{min-height:100%;overflow-x:hidden;overflow-y:auto}body{margin:0;padding:0;width:100%;min-height:100vh;min-height:100dvh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow-x:hidden;overflow-y:auto;position:relative;background:var(--bg-base, #f8f9fc)}#app{width:100%;min-height:100vh;overflow-x:hidden;overflow-y:visible;position:relative}.weather-shell{min-height:100vh;min-height:100dvh;padding:1.25rem 1.5rem 2rem;display:flex;flex-direction:column;gap:1rem;position:relative;background:var(--home-shell-bg);background-color:var(--bg-base);color:var(--home-text-strong)}@media(max-width:768px){.weather-shell{padding:.75rem .75rem 1.5rem;gap:.75rem}}.weather-topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1.2rem;border-radius:16px;background:linear-gradient(135deg,#2f6bd81f,#2ab3ff14),var(--home-surface-strong);border:1px solid var(--home-border-strong);box-shadow:var(--home-shadow-strong);position:sticky;top:0;z-index:1000;backdrop-filter:blur(14px);color:var(--home-text-strong);transition:all .3s ease}@media(max-width:768px){.weather-topbar{padding:.7rem .9rem;gap:.5rem;border-radius:12px;flex-direction:column;align-items:stretch}}.topbar-left{display:flex;align-items:center;gap:1.25rem;min-width:0;flex:1}@media(max-width:768px){.topbar-left{gap:.75rem;width:100%;justify-content:space-between}}.brand{display:flex;align-items:center;gap:.75rem}@media(max-width:768px){.brand{gap:.5rem}}.brand-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0;background:transparent;border:none;box-shadow:none;padding:0}.brand-icon svg,.brand-icon img{width:3rem;height:3rem}@media(max-width:768px){.brand-icon svg,.brand-icon img{width:2.5rem;height:2.5rem}}.brand-text{display:flex;flex-direction:column;gap:.15rem;color:var(--home-text-strong)}@media(max-width:768px){.brand-text{gap:.1rem}}.brand-title{font-weight:700;letter-spacing:-.3px;color:var(--home-text-muted)}@media(max-width:768px){.brand-title{font-size:.85rem}}.brand-subtitle{color:var(--home-text-muted);font-size:.75rem;opacity:.85}@media(max-width:768px){.brand-subtitle{font-size:.7rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.topbar-right{display:flex;align-items:center;gap:.75rem;flex-wrap:nowrap;justify-content:flex-end;transition:all .3s ease}@media(max-width:768px){.topbar-right{gap:.4rem;width:100%;justify-content:flex-start;flex-direction:column;align-items:stretch;order:2;padding-top:.1rem;margin-top:.1rem;max-height:320px;opacity:1;transition:max-height .32s ease,opacity .22s ease,padding .24s ease,margin-top .24s ease}.topbar-right .layer-select,.topbar-right .pill-btn.ghost{transition:opacity .22s ease,transform .24s ease}.topbar-right:not(.is-collapsed) .layer-select,.topbar-right:not(.is-collapsed) .pill-btn.ghost{opacity:1;transform:translateY(0);pointer-events:auto}}@media(max-width:768px){.topbar-right.is-collapsed{overflow:hidden;max-height:0;opacity:0;padding-top:0;margin-top:0;pointer-events:none}.topbar-right.is-collapsed .layer-select,.topbar-right.is-collapsed .pill-btn.ghost{opacity:0;transform:translateY(-10px);pointer-events:none}}.resolution-switch{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .4rem;background:var(--home-surface-strong);border:1px solid var(--home-border-soft);border-radius:12px;box-shadow:var(--home-shadow-soft);width:100%}.resolution-btn{border:none;cursor:pointer;padding:0;margin:0;padding:.35rem .8rem;border-radius:8px;color:var(--home-text-muted);font-weight:600;font-size:.75rem;background:transparent;transition:all .2s ease;border:1px solid transparent}.resolution-btn:hover{color:var(--home-text-strong);border-color:var(--home-border-strong)}.resolution-btn.is-active{color:var(--home-text-strong);background:linear-gradient(135deg,#58b1ff2e,#34d39926);border-color:var(--home-border-strong);box-shadow:var(--home-shadow-strong)}.resolution-hint{margin-top:.35rem;color:var(--home-text-muted);font-size:.7rem;line-height:1.3}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.hamburger-btn{display:none;background:transparent;border:none;padding:0;margin:0;width:40px;height:40px;position:relative;border-radius:12px;background:var(--home-control-strong);border:1px solid var(--home-border-strong);box-shadow:var(--home-shadow-soft);cursor:pointer;transition:.2s ease;flex-shrink:0}@media(max-width:768px){.hamburger-btn{display:flex;align-items:center;justify-content:center}}.hamburger-btn:hover{background:var(--home-control-hover);border-color:var(--home-border-strong);transform:scale(1.02)}.hamburger-btn span{position:absolute;display:block;width:22px;height:2px;background:var(--home-text-strong);border-radius:2px;transition:all .3s cubic-bezier(.4,0,.2,1);left:50%;transform:translate(-50%)}.hamburger-btn span:nth-child(1){top:12px}.hamburger-btn span:nth-child(2){top:19px}@media(max-width:768px){.topbar-right:not(.is-collapsed)~.topbar-left .hamburger-btn span:nth-child(1),.topbar-left:has(~.topbar-right:not(.is-collapsed)) .hamburger-btn span:nth-child(1){top:19px;transform:translate(-50%) rotate(45deg)}.topbar-right:not(.is-collapsed)~.topbar-left .hamburger-btn span:nth-child(2),.topbar-left:has(~.topbar-right:not(.is-collapsed)) .hamburger-btn span:nth-child(2){opacity:0}.topbar-right:not(.is-collapsed)~.topbar-left .hamburger-btn span:nth-child(3),.topbar-left:has(~.topbar-right:not(.is-collapsed)) .hamburger-btn span:nth-child(3){top:19px;transform:translate(-50%) rotate(-45deg)}}.floating-sidebar-btn{display:none}@media(max-width:768px){.floating-sidebar-btn{display:flex;align-items:center;justify-content:center;position:absolute;bottom:1rem;left:1rem;width:3.5rem;height:3.5rem;border-radius:50%;background:linear-gradient(135deg,var(--floating-btn-start) 0%,var(--floating-btn-end) 100%);border:none;color:#fff;cursor:pointer;z-index:2;box-shadow:var(--floating-btn-shadow);transition:all .3s cubic-bezier(.4,0,.2,1)}.floating-sidebar-btn__icon{width:1.75rem;height:1.75rem;color:inherit;stroke:currentColor;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));transition:transform .2s ease}.floating-sidebar-btn:hover{transform:scale(1.08) translateY(-2px);box-shadow:var(--floating-btn-shadow-strong);background:linear-gradient(135deg,var(--floating-btn-hover-start) 0%,var(--floating-btn-hover-end) 100%)}.floating-sidebar-btn:hover .floating-sidebar-btn__icon{transform:translateY(-1px)}.floating-sidebar-btn:active{transform:scale(.96)}}@media(max-width:768px){[data-theme=dark] .floating-sidebar-btn{background:linear-gradient(135deg,var(--floating-btn-start) 0%,var(--floating-btn-end) 100%);box-shadow:var(--floating-btn-shadow)}[data-theme=dark] .floating-sidebar-btn:hover{background:linear-gradient(135deg,var(--floating-btn-hover-start) 0%,var(--floating-btn-hover-end) 100%);box-shadow:var(--floating-btn-shadow-strong)}}.pill-group{display:flex;gap:.4rem}.pill-btn{background:transparent;border:none;padding:0;margin:0;padding:.55rem .9rem;border-radius:12px;background:var(--home-control-bg);color:var(--home-text-strong);border:1px solid var(--home-border-soft);transition:.2s ease;display:inline-flex;align-items:center;gap:.35rem;cursor:pointer;box-shadow:var(--home-shadow-soft)}@media(max-width:768px){.pill-btn{padding:.5rem .72rem;width:100%;justify-content:center}.pill-btn svg{width:16px;height:16px}}@media(max-width:768px){.topbar-right:not(.is-collapsed) .pill-btn{padding:.6rem .85rem;font-size:.85rem}.topbar-right:not(.is-collapsed) .pill-btn svg{width:18px;height:18px}}.pill-btn.is-disabled{opacity:.4;cursor:not-allowed}.pill-btn.ghost{background:var(--home-surface-ghost)}.pill-btn:hover:not(.is-disabled){border-color:var(--home-border-strong);background:var(--home-control-hover);box-shadow:var(--home-shadow-strong);transform:translateY(-1px)}.pill-btn:active:not(.is-disabled){transform:translateY(0)}.layer-select{display:flex;align-items:center;gap:.5rem;color:var(--home-text-muted)}@media(max-width:768px){.layer-select{width:100%;flex-direction:column;align-items:stretch;gap:.35rem;padding-top:.35rem;border-top:1px solid var(--home-border-soft)}}.layer-select label{font-weight:600;font-size:.75rem;color:var(--home-text-muted)}@media(max-width:768px){.layer-select label{text-align:center;font-size:.8rem}}.layer-select select{appearance:none;background:linear-gradient(145deg,#2f6bd814,#2ab3ff0a),var(--home-control-strong);color:var(--home-text-strong);border:1px solid var(--home-control-border);border-radius:12px;padding:.45rem .7rem;min-width:140px;outline:none;transition:.2s ease;box-shadow:var(--home-shadow-soft);cursor:pointer}@media(max-width:768px){.layer-select select{padding:.6rem .75rem;min-width:100%;font-size:.85rem;text-align:center}}.layer-select select:focus{border-color:var(--home-border-strong);box-shadow:0 0 0 2px #4286ff38}.layer-select select option{background:var(--home-surface);color:var(--home-text-strong)}.weather-grid{display:grid;grid-template-columns:minmax(240px,1fr) minmax(0,2fr);gap:1rem;align-items:start;position:relative}@media(max-width:1024px){.weather-grid{grid-template-columns:minmax(220px,1fr) minmax(0,2fr)}}@media(max-width:768px){.weather-grid{grid-template-columns:1fr;gap:.75rem}}.sidebar-backdrop{display:none}@media(max-width:768px){.sidebar-backdrop{display:block;position:fixed;inset:0;background:#00000080;z-index:1000;backdrop-filter:blur(4px);animation:fadeIn .25s ease}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideOutLeft{0%{transform:translate(0)}to{transform:translate(-100%)}}.sidebar-card{background:linear-gradient(145deg,#2f6bd814,#2ab3ff0a),var(--home-surface);border:1px solid var(--home-border-soft);border-radius:20px;padding:1rem;display:flex;flex-direction:column;gap:.9rem;box-shadow:var(--home-shadow-strong);backdrop-filter:blur(14px)}@media(max-width:768px){.sidebar-card{position:fixed;top:0;left:0;bottom:0;width:85%;max-width:320px;z-index:1008;border-radius:0;padding:1.25rem;gap:1rem;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;overscroll-behavior:contain}.sidebar-card.is-open{transform:translate(0);box-shadow:4px 0 24px #0000004d}}@media(max-width:480px){.sidebar-card{width:90%;max-width:300px;padding:1rem}}.sidebar-header{display:flex;flex-direction:column;gap:.25rem}.sidebar-title-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.sidebar-close-btn{display:none;background:transparent;border:none;padding:0;margin:0;width:32px;height:32px;border-radius:12px;background:var(--home-control-bg);border:1px solid var(--home-border-soft);color:var(--home-text-strong);cursor:pointer;transition:.2s ease;align-items:center;justify-content:center;flex-shrink:0}@media(max-width:768px){.sidebar-close-btn{display:flex}}.sidebar-close-btn:hover{background:var(--home-control-hover);border-color:var(--home-border-strong);transform:scale(1.05)}.sidebar-close-btn:active{transform:scale(.95)}.sidebar-close-btn svg{width:20px;height:20px}.sidebar-title{font-size:1rem;font-weight:700;color:var(--home-text-strong)}@media(max-width:768px){.sidebar-title{font-size:.9rem}}.sidebar-subtitle{color:var(--home-text-muted);font-size:.75rem}@media(max-width:768px){.sidebar-subtitle{font-size:.7rem}}.sidebar-section{background:linear-gradient(145deg,#2f6bd80a,#2ab3ff05),var(--home-surface-soft);border:1px solid var(--home-border-soft);border-radius:16px;padding:.75rem .9rem;display:flex;flex-direction:column;gap:.55rem;backdrop-filter:blur(10px)}@media(max-width:768px){.sidebar-section{padding:.9rem 1rem;gap:.7rem}}.sidebar-section.sidebar-layer-select{display:none}@media(max-width:768px){.sidebar-section.sidebar-layer-select{display:flex}}.mobile-layer-select{appearance:none;background:linear-gradient(145deg,#2f6bd814,#2ab3ff0a),var(--home-control-strong);color:var(--home-text-strong);border:1px solid var(--home-control-border);border-radius:12px;padding:.7rem .85rem;width:100%;outline:none;transition:.2s ease;box-shadow:var(--home-shadow-soft);cursor:pointer;font-size:.85rem;font-weight:600;min-height:44px}.mobile-layer-select:focus{border-color:var(--home-border-strong);box-shadow:0 0 0 2px #4286ff38}.mobile-layer-select:hover{background:var(--home-control-hover);border-color:var(--home-border-strong)}.mobile-layer-select option{background:var(--home-surface);color:var(--home-text-strong);padding:.5rem}.section-label{font-size:.75rem;font-weight:600;color:var(--home-text-muted);text-transform:uppercase;letter-spacing:.5px}@media(max-width:768px){.section-label{font-size:.7rem}}.search-field{display:flex;align-items:center;gap:.6rem;background:var(--home-control-bg);border:1px solid var(--home-control-border);border-radius:12px;padding:.55rem .7rem;box-shadow:inset 0 0 0 1px #00000005,var(--home-shadow-soft)}@media(max-width:768px){.search-field{padding:.7rem .85rem}}.search-field svg{color:var(--home-text-muted);flex-shrink:0}.search-field input{flex:1;color:var(--home-text-strong);background:transparent;border:none;outline:none;font:inherit;font-size:.8rem}@media(max-width:768px){.search-field input{font-size:.85rem}}.search-field input::placeholder{color:var(--home-text-muted)}.search-dropdown{display:flex;flex-direction:column;gap:.35rem;border-top:1px solid var(--home-border-soft);padding-top:.5rem;max-height:280px;overflow-y:auto}@media(max-width:768px){.search-dropdown{gap:.45rem;padding-top:.7rem}}.dropdown-item{background:transparent;border:none;cursor:pointer;padding:0;margin:0;text-align:left;padding:.5rem .55rem;border-radius:12px;color:var(--home-text-strong);background:var(--home-control-bg);border:1px solid transparent;transition:.2s ease;box-shadow:var(--home-shadow-soft);font-size:.8rem}@media(max-width:768px){.dropdown-item{padding:.7rem .75rem;font-size:.85rem;min-height:44px}}.dropdown-item:hover{border-color:var(--home-border-strong);background:var(--home-control-hover);transform:translate(2px)}.dropdown-item:active{transform:translate(0)}.radius-row{display:flex;align-items:center;gap:.6rem}@media(max-width:768px){.radius-row{gap:.75rem}}.radius-row input[type=range]{flex:1;accent-color:var(--home-accent);cursor:pointer}@media(max-width:768px){.radius-row input[type=range]{height:6px}}.radius-row .radius-value{font-weight:600;color:var(--home-text-strong);min-width:52px;text-align:right}@media(max-width:768px){.radius-row .radius-value{font-size:.85rem}}.city-list{display:flex;flex-direction:column;gap:.4rem}@media(max-width:768px){.city-list{gap:.5rem}}.city-item{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;gap:.6rem;padding:.55rem .6rem;border-radius:12px;color:var(--home-text-strong);background:var(--home-control-bg);border:1px solid transparent;transition:.2s ease;width:100%;box-shadow:var(--home-shadow-soft);font-size:.8rem}@media(max-width:768px){.city-item{padding:.7rem .75rem;font-size:.85rem;min-height:48px}}.city-item:hover{border-color:var(--home-border-strong);background:var(--home-control-hover);transform:translate(2px)}.city-item:active{transform:translate(0)}.city-item[aria-pressed=true]{border-color:var(--home-accent);background:var(--home-control-hover)}.city-dot{width:10px;height:10px;border-radius:999px;background:var(--home-control-hover);border:1px solid var(--home-border-strong);flex-shrink:0;transition:.2s ease}.city-dot.active{background:var(--home-accent);border-color:var(--home-accent);box-shadow:0 0 0 4px var(--home-control-hover)}.city-item-text{display:flex;align-items:center;gap:.35rem;line-height:1.2;flex-wrap:wrap;flex:1;min-width:0}.city-name{font-weight:600;color:var(--home-text-muted)}.city-state{color:var(--home-text-muted);font-size:.7rem}.city-distance{margin-left:auto;color:var(--home-text-muted);font-size:.7rem;flex-shrink:0}.filter-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}@media(max-width:768px){.filter-list{gap:.6rem}}.filter-item{display:flex;align-items:center;gap:.45rem;color:var(--home-text-strong);font-weight:600;padding:.5rem .6rem;border-radius:12px;background:var(--home-control-bg);border:1px solid transparent;transition:.2s ease;cursor:pointer;user-select:none;font-size:.75rem}@media(max-width:768px){.filter-item{padding:.65rem .75rem;gap:.55rem;font-size:.8rem;min-height:44px}}.filter-item:hover{border-color:var(--home-border-soft);background:var(--home-control-hover)}.filter-item:active{transform:scale(.98)}.filter-item:has(input:checked){border-color:var(--home-accent);background:var(--home-control-hover)}.filter-item input[type=checkbox]{accent-color:var(--home-accent);cursor:pointer;width:16px;height:16px;flex-shrink:0}@media(max-width:768px){.filter-item input[type=checkbox]{width:18px;height:18px}}.map-area{position:relative;display:flex;flex-direction:column;gap:.75rem;min-width:0}@media(max-width:768px){.map-area{gap:.5rem}}.map-context-card{display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;gap:.75rem;padding:.65rem .85rem;border-radius:16px;border:1px solid var(--home-border-strong);background:linear-gradient(135deg,#2f6bd812,#34d3990d),var(--home-surface-soft);box-shadow:var(--home-shadow-soft);color:var(--home-text-strong);width:100%}@media(max-width:768px){.map-context-card{padding:.6rem .75rem;gap:.6rem}}.context-eyebrow{display:inline-flex;align-items:center;gap:.4rem;padding:.28rem .55rem;border-radius:12px;background:var(--home-control-bg);color:var(--home-text-muted);font-size:.7rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;border:1px solid var(--home-border-soft);width:fit-content;white-space:nowrap;flex-shrink:0}.context-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--home-accent);box-shadow:0 0 0 4px var(--home-control-hover)}.context-city-row{display:flex;align-items:center;flex-wrap:nowrap;justify-content:flex-end;gap:.45rem;margin-top:.1rem;flex:1;min-width:0}@media(max-width:768px){.context-city-row{gap:.4rem}}.context-label{color:var(--home-text-muted);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}@media(max-width:768px){.context-label{font-size:.7rem}}.context-city-link{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .6rem;border-radius:12px;background:var(--home-control-bg);border:1px solid var(--home-control-border);color:var(--home-text-strong);text-decoration:none;font-weight:600;font-size:.75rem;transition:.2s ease;box-shadow:var(--home-shadow-soft);min-width:0;max-width:60%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;margin-left:auto}.context-city-link:hover{background:var(--home-control-hover);border-color:var(--home-border-strong);transform:translateY(-1px)}.context-city-link:active{transform:translateY(0)}.context-city-link svg{color:var(--home-text-muted);flex-shrink:0;width:12px;height:12px}.context-city-placeholder{color:var(--home-text-muted);font-weight:600;font-size:.75rem;padding:.35rem .6rem;border-radius:12px;background:var(--home-control-bg);border:1px dashed var(--home-border-soft);min-width:0;max-width:100%}.map-wrapper{position:relative;min-height:68vh;border-radius:20px;overflow:hidden;border:1px solid var(--home-border-strong);box-shadow:var(--home-shadow-strong);background:var(--home-surface)}@media(max-width:768px){.map-wrapper{border-radius:16px;min-height:45vh}}#map{position:relative;z-index:1;width:100%;height:100%;min-height:68vh}#map svg path,#map .leaflet-interactive{outline:none!important}@media(max-width:768px){#map{min-height:45vh}#map .leaflet-control-zoom{display:none!important}}.legend-bar{display:flex;flex-wrap:nowrap;justify-content:space-between;gap:.45rem;align-items:center;padding:.6rem .85rem;background:linear-gradient(145deg,#2f6bd80f,#2ab3ff0a),var(--home-surface-soft);border:1px solid var(--home-border-strong);border-radius:16px;box-shadow:var(--home-shadow-soft);backdrop-filter:blur(10px);overflow-x:auto;scrollbar-width:thin;-webkit-overflow-scrolling:touch}@media(max-width:768px){.legend-bar{padding:.45rem .6rem;gap:.35rem;justify-content:space-between}}.legend-item{display:inline-flex;align-items:center;gap:.4rem;flex:0 0 auto;color:var(--home-text-strong);font-size:.7rem;font-weight:600;white-space:nowrap;padding:0 .35rem;min-height:32px;justify-content:center}@media(max-width:768px){.legend-item{font-size:.62rem;gap:.28rem;min-height:28px}}.legend-color{width:16px;height:10px;border-radius:8px;border:1px solid var(--home-border-soft);flex-shrink:0;box-shadow:inset 0 0 0 1px #0000000d}@media(max-width:768px){.legend-color{width:14px;height:8px}}.panel-fade-enter-active,.panel-fade-leave-active{transition:opacity .3s ease,transform .45s cubic-bezier(.22,1,.36,1)}.panel-fade-enter-from,.panel-fade-leave-to{opacity:0;transform:translate(36px)}.loading-overlay{position:absolute;inset:0;background:var(--home-surface);opacity:.92;z-index:1100;backdrop-filter:blur(8px)}.loading-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1101;display:flex;flex-direction:column;align-items:center;gap:1.25rem;color:var(--home-text-strong)}@media(max-width:768px){.loading-indicator{gap:1rem}}.weather-icon-loading{animation:bounce 1.5s ease-in-out infinite}.weather-icon-loading svg,.weather-icon-loading img{width:48px;height:48px;filter:drop-shadow(0 2px 8px var(--home-accent))}@media(max-width:768px){.weather-icon-loading svg,.weather-icon-loading img{width:40px;height:40px}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.spinner-container{width:48px;height:48px;position:relative}@media(max-width:768px){.spinner-container{width:40px;height:40px}}.spinner{width:100%;height:100%;border:3px solid var(--home-border-soft);border-top-color:var(--home-accent);border-radius:50%;animation:spin 1s linear infinite}.loading-text{display:flex;flex-direction:column;align-items:center;gap:.35rem;text-align:center}.loading-text .main-text{font-size:.9rem;font-weight:700;color:var(--home-text-strong)}@media(max-width:768px){.loading-text .main-text{font-size:.8rem}}.loading-text .sub-text{font-size:.75rem;color:var(--home-text-muted)}@media(max-width:768px){.loading-text .sub-text{font-size:.7rem}}.floating-header{position:absolute;top:20px;left:10rem;right:10rem;background:#122340d1;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 8px 32px #0006;z-index:1000;transition:.4s cubic-bezier(.4,0,.2,1);isolation:isolate}.floating-header:hover{background:#14345ceb;box-shadow:0 12px 40px #47474780}@media(max-width:900px){.floating-header{left:2rem;right:2rem}}@media(max-width:768px){.floating-header{top:0;left:0;right:0;border-radius:0;border-left:none;border-right:none;box-shadow:none}}@media(max-width:768px){.floating-header.menu-open .header-controls{max-height:400px!important;opacity:1!important;margin-top:.875rem;padding-top:.875rem;border-top:1px solid rgba(255,255,255,.2)}}.floating-header.menu-open .hamburger-btn span:nth-child(1){top:18px;transform:rotate(45deg)}.floating-header.menu-open .hamburger-btn span:nth-child(2){opacity:0}.floating-header.menu-open .hamburger-btn span:nth-child(3){top:18px;transform:rotate(-45deg)}.header-wrapper{padding:.875rem 1.25rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;color:#fff;flex-wrap:nowrap}@media(max-width:1100px){.header-wrapper{gap:1.25rem}}@media(max-width:900px){.header-wrapper{gap:.875rem;padding:.75rem 1rem}}@media(max-width:768px){.header-wrapper{padding:.75rem 1rem;gap:0;flex-wrap:wrap}}.header-left{display:flex;align-items:center;gap:.875rem;flex-shrink:0}@media(max-width:1100px){.header-left{gap:.5rem}}@media(max-width:768px){.header-left{justify-content:space-between;width:100%}}.weather-icon{flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}@media(max-width:768px){.weather-icon{width:32px;height:32px}}.header-title h1{margin:0;font-size:1.15rem;font-weight:700;letter-spacing:-.3px;line-height:1.2;color:#fff}@media(max-width:1100px){.header-title h1{font-size:1rem}}@media(max-width:768px){.header-title h1{font-size:1rem}}@media(max-width:768px){.header-title{text-align:right;flex:1}}.subtitle{font-size:.85rem;opacity:.7;font-weight:500;color:#e0e0e0}@media(max-width:768px){.subtitle{font-size:.8rem}}.city-search{position:relative;display:flex;align-items:center}.city-search .search-toggle-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;padding:.25rem;border-radius:8px;transition:all .3s ease}.city-search .search-toggle-btn:hover{background-color:#ffffff40;border-color:#fff6;transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.city-search .search-toggle-btn:active{transform:translateY(0)}.city-search .search-toggle-btn svg{width:20px;height:20px}.city-search .main-search-dropdown{position:absolute;top:100%;right:0;background:#122340d1;border-radius:12px;box-shadow:0 4px 20px #0006;min-width:300px;z-index:1010;margin-top:.5rem}.city-search .main-search-dropdown .main-search-input{width:100%;padding:.875rem;border:none;border-radius:12px;background:#ffffff1a;color:#fff;font-size:.8rem}.city-search .main-search-dropdown .main-search-input::placeholder{color:#e0e0e0}.city-search .main-search-dropdown .main-search-input:focus{outline:none;background:#fff3}.city-search .main-search-dropdown .main-search-results{max-height:200px;overflow-y:auto}.city-search .main-search-dropdown .main-search-results .main-search-result-item{padding:.5rem .875rem;cursor:pointer;color:#fff;transition:all .3s ease;border-radius:8px;margin:2px}.city-search .main-search-dropdown .main-search-results .main-search-result-item:hover{background:#fff3;transform:translate(4px);box-shadow:0 2px 8px #0000001a}.city-search .main-search-dropdown .main-search-results .main-search-result-item:active{transform:translate(2px)}.city-search .main-search-dropdown .main-search-results .main-search-result-item:not(:last-child){border-bottom:1px solid rgba(255,255,255,.2)}.header-controls{display:flex;align-items:center;gap:1.25rem;flex-shrink:1;min-width:0}@media(max-width:1100px){.header-controls{gap:.875rem}}@media(max-width:900px){.header-controls{gap:.5rem}}@media(max-width:768px){.header-controls{width:100%;max-height:0;overflow:hidden;opacity:0;transition:max-height .4s ease,opacity .3s ease,margin .3s ease,padding .3s ease;flex-direction:column;align-items:stretch;gap:.875rem;padding:0;margin:0;border-top:1px solid transparent}}.control-item{display:flex;flex-direction:column;gap:.4rem;padding-left:1.25rem;border-left:2px solid rgba(255,255,255,.2);align-self:stretch;justify-content:center;min-width:0}.control-item:first-child{padding-left:1.25rem}@media(max-width:1100px){.control-item,.control-item:first-child{padding-left:.875rem}}@media(max-width:900px){.control-item,.control-item:first-child{padding-left:.5rem}}@media(max-width:768px){.control-item{width:100%;border-left:none;padding-left:0;padding-bottom:.875rem;border-bottom:1px solid rgba(255,255,255,.2)}.control-item:last-child{border-bottom:none;padding-bottom:0}}.control-item label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;cursor:pointer;color:#f0f0f0}@media(max-width:768px){.control-item label{font-size:.9rem}}.control-item label svg{flex-shrink:0;opacity:.9}.theme-control{min-width:auto;padding-left:1.25rem}@media(max-width:900px){.theme-control{padding-left:.5rem}}@media(max-width:768px){.theme-control{padding-left:0;border-left:none}}.theme-toggle-btn{background:transparent;border:none;margin:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#ffffff26;border:2px solid rgba(255,255,255,.3);border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease;flex-shrink:0}.theme-toggle-btn:hover{background:#ffffff40;border-color:#ffffff80}@media(min-width:769px){.theme-toggle-btn:hover{transform:scale(1.05)}}.theme-toggle-btn:active{transform:scale(.98)}.theme-toggle-btn svg{width:20px;height:20px;transition:transform .3s ease}@media(max-width:768px){.theme-toggle-btn{width:100%;height:44px}}[data-theme=dark] .floating-header{background:var(--home-surface-soft);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--home-border-soft);box-shadow:0 16px 50px #00000073,0 0 0 1px var(--home-border-soft),0 0 22px var(--home-glow)}[data-theme=dark] .header-wrapper{color:var(--home-text-strong)}[data-theme=dark] .header-title h1{color:var(--home-text-strong);text-shadow:0 0 22px rgba(124,242,255,.28)}[data-theme=dark] .subtitle{color:var(--home-text-muted)}[data-theme=dark] .city-search .search-toggle-btn{background:linear-gradient(135deg,#5ec4ff33,#8b6dd92e);border-color:var(--home-border-strong);color:var(--home-text-strong);box-shadow:0 10px 24px #00000059,0 0 0 1px var(--home-border-soft)}[data-theme=dark] .city-search .search-toggle-btn:hover{background:linear-gradient(135deg,#5ec4ff47,#8b6dd93d);border-color:var(--home-border-strong);box-shadow:0 0 0 1px var(--home-border-strong),0 14px 32px #00000073}[data-theme=dark] .city-search .main-search-dropdown{background:var(--home-surface-strong);border:1px solid var(--home-border-soft);box-shadow:0 16px 50px #0000008c,0 0 0 1px var(--home-border-soft),0 0 20px #7cf2ff1f}[data-theme=dark] .city-search .main-search-dropdown .main-search-input{background:#ffffff08;color:var(--home-text-strong);border:1px solid transparent;box-shadow:inset 0 0 0 1px var(--home-border-soft)}[data-theme=dark] .city-search .main-search-dropdown .main-search-input::placeholder{color:var(--home-text-muted)}[data-theme=dark] .city-search .main-search-dropdown .main-search-input:focus{background:#ffffff0d;border-color:var(--home-border-strong);box-shadow:0 0 0 1px var(--home-border-strong),0 0 24px #7cf2ff2e}[data-theme=dark] .city-search .main-search-dropdown .main-search-result-item{color:var(--home-text-strong)}[data-theme=dark] .city-search .main-search-dropdown .main-search-result-item:hover{background:#7cf2ff1f;border-left:2px solid var(--home-border-strong);box-shadow:0 0 0 1px var(--home-border-soft)}[data-theme=dark] .city-search .main-search-dropdown .main-search-result-item:not(:last-child){border-bottom-color:var(--home-border-soft)}[data-theme=dark] .control-item{border-left:2px solid var(--home-border-soft)}[data-theme=dark] .control-item label{color:var(--home-text-strong);text-shadow:0 0 18px rgba(124,242,255,.15)}@media(max-width:768px){[data-theme=dark] .control-item{border-left:none;padding-left:0;border-bottom:1px solid var(--home-border-soft)}[data-theme=dark] .control-item:last-child{border-bottom:none;padding-bottom:0}}[data-theme=dark] .theme-toggle-btn{background:linear-gradient(135deg,#7cf2ff24,#9f7aea1f);border-color:var(--home-border-strong);color:var(--home-text-strong);box-shadow:0 10px 30px #00000073,0 0 0 1px var(--home-border-soft),0 0 18px #7cf2ff40}[data-theme=dark] .theme-toggle-btn:hover{background:linear-gradient(135deg,#7cf2ff2e,#9f7aea29);border-color:var(--home-border-strong)}.radius-control input[type=range]{width:140px;height:6px;border-radius:3px;background:#fff3;outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}@media(max-width:1100px){.radius-control input[type=range]{width:120px}}@media(max-width:900px){.radius-control input[type=range]{width:100px}}@media(max-width:768px){.radius-control input[type=range]{width:100%}}.radius-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,#2f6bd8,#48c7ff);cursor:pointer;box-shadow:0 2px 6px #0006;transition:.2s ease}.radius-control input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 6px 20px #667eea99}.radius-control input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,#2f6bd8,#48c7ff);cursor:pointer;border:none;box-shadow:0 2px 6px #0006;transition:.2s ease}.radius-control input[type=range]::-moz-range-thumb:hover{transform:scale(1.15);box-shadow:0 6px 20px #667eea99}[data-theme=dark] .radius-control input[type=range]{background:var(--home-surface-soft);box-shadow:inset 0 0 0 1px var(--home-border-soft),0 8px 20px #0006}[data-theme=dark] .radius-control input[type=range]::-webkit-slider-thumb{background:linear-gradient(135deg,var(--home-accent),var(--home-accent-2));box-shadow:0 0 0 1px var(--home-border-strong),0 12px 24px #00000073,0 0 18px #7cf2ff4d}[data-theme=dark] .radius-control input[type=range]::-moz-range-thumb{background:linear-gradient(135deg,var(--home-accent),var(--home-accent-2));box-shadow:0 0 0 1px var(--home-border-strong),0 12px 24px #00000073,0 0 18px #7cf2ff4d;border:none}.datetime-control{display:flex!important;flex-direction:row!important;align-items:center;gap:.5rem;justify-content:space-between}@media(max-width:1100px){.datetime-control{gap:.35rem}}@media(max-width:900px){.datetime-control{gap:.25rem}}.datetime-control .datetime-toggle{user-select:none;-webkit-user-select:none;-moz-user-select:none}.datetime-control .datetime-toggle input[type=checkbox]{cursor:pointer;width:1rem;height:1rem;accent-color:#2f6bd8}.datetime-control .date-btn{padding:.4rem .7rem;border-radius:8px;border:1px solid rgba(255,255,255,.25);background:#ffffff26;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:.2s ease}.datetime-control .date-btn:hover{background:#fff3;border-color:#fff3;transform:translateY(-1px)}.datetime-control .date-btn:focus{outline:none;border-color:#2f6bd8;background:#fff3;box-shadow:0 0 0 3px #667eea4d}.datetime-control .date-btn{background:linear-gradient(135deg,#2f6bd8,#48c7ff);color:#fff;font-weight:600;padding:.625rem 1.25rem;border-radius:12px;border:none;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap;box-shadow:0 4px 12px #667eea33}.datetime-control .date-btn svg{flex-shrink:0}.datetime-control .date-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea59}.datetime-control .date-btn:active{transform:translateY(0)}@media(max-width:1100px){.datetime-control .date-btn{padding:.5rem 1rem;font-size:.85rem}}@media(max-width:900px){.datetime-control .date-btn{padding:.45rem .875rem;font-size:.8rem;gap:.35rem}}@media(max-width:768px){.datetime-control .date-btn{padding:.5rem 1rem;font-size:.85rem}}@media(max-width:480px){.datetime-control .date-btn{padding:.45rem .875rem;font-size:.75rem}}.datetime-control .date-nav-btn{background:#fff;border:2px solid rgba(255,255,255,.3);border-radius:10px;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;flex-shrink:0;color:#fff;background:#ffffff26;backdrop-filter:blur(10px)}.datetime-control .date-nav-btn:hover:not(:disabled){background:#ffffff40;border-color:#ffffff80;transform:scale(1.05)}.datetime-control .date-nav-btn:active:not(:disabled){transform:scale(.95)}.datetime-control .date-nav-btn:disabled{opacity:.3;cursor:not-allowed}@media(max-width:768px){.datetime-control .date-nav-btn{width:2rem;height:2rem}.datetime-control .date-nav-btn svg{width:18px;height:18px}}@media(max-width:480px){.datetime-control .date-nav-btn{width:2rem;height:2rem}.datetime-control .date-nav-btn svg{width:16px;height:16px}}.datetime-control .datetime-inputs{display:flex;gap:.5rem;align-items:center}@media(max-width:768px){.datetime-control .datetime-inputs{flex-direction:row;gap:.5rem}}.datetime-control .datetime-inputs .input-wrapper{display:flex;align-items:center}@media(max-width:768px){.datetime-control .datetime-inputs .input-wrapper{flex:1}}.datetime-control .datetime-inputs input[type=date],.datetime-control .datetime-inputs input[type=time]{padding:.4rem .7rem;border-radius:8px;border:1px solid rgba(255,255,255,.25);background:#ffffff26;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:.2s ease}.datetime-control .datetime-inputs input[type=date]:hover,.datetime-control .datetime-inputs input[type=time]:hover{background:#fff3;border-color:#fff3;transform:translateY(-1px)}.datetime-control .datetime-inputs input[type=date]:focus,.datetime-control .datetime-inputs input[type=time]:focus{outline:none;border-color:#2f6bd8;background:#fff3;box-shadow:0 0 0 3px #667eea4d}.datetime-control .datetime-inputs input[type=date],.datetime-control .datetime-inputs input[type=time]{width:115px;text-align:center}@media(max-width:768px){.datetime-control .datetime-inputs input[type=date],.datetime-control .datetime-inputs input[type=time]{width:100%;font-size:.85rem;padding:.45rem .5rem}}.datetime-control .datetime-inputs input[type=date]::-webkit-calendar-picker-indicator,.datetime-control .datetime-inputs input[type=time]::-webkit-calendar-picker-indicator{cursor:pointer;filter:brightness(0) invert(1);opacity:.8;transition:opacity .2s;padding:2px}.datetime-control .datetime-inputs input[type=date]::-webkit-calendar-picker-indicator:hover,.datetime-control .datetime-inputs input[type=time]::-webkit-calendar-picker-indicator:hover{opacity:1}[data-theme=dark] .datetime-control .date-btn{background:linear-gradient(135deg,var(--home-accent),var(--home-accent-2));box-shadow:0 10px 26px #0006,0 0 0 1px var(--home-border-soft),0 0 18px var(--home-glow);color:var(--home-text-strong)}[data-theme=dark] .datetime-control .date-nav-btn{background:linear-gradient(135deg,#5ec4ff2e,#8b6dd929);border-color:var(--home-border-strong);color:var(--home-text-strong);box-shadow:0 10px 26px #00000080,0 0 0 1px var(--home-border-soft)}[data-theme=dark] .datetime-control .date-nav-btn:hover:not(:disabled){background:linear-gradient(135deg,#5ec4ff47,#8b6dd938);border-color:var(--home-border-strong);box-shadow:0 0 0 1px var(--home-border-strong),0 12px 28px #0000008c}[data-theme=dark] .datetime-control .date-nav-btn:disabled{color:var(--home-text-muted)}[data-theme=dark] .datetime-control .datetime-inputs input[type=date],[data-theme=dark] .datetime-control .datetime-inputs input[type=time]{background:var(--home-surface-soft);border-color:var(--home-border-soft);color:var(--home-text-strong);box-shadow:0 0 0 1px var(--home-border-soft),0 10px 22px #00000073}[data-theme=dark] .datetime-control .datetime-inputs input[type=date]:focus,[data-theme=dark] .datetime-control .datetime-inputs input[type=time]:focus{border-color:var(--home-border-strong);box-shadow:0 0 0 1px var(--home-border-strong),0 0 22px #7cf2ff3d}.day-carousel-overlay{position:fixed;inset:0;background:radial-gradient(circle at 18% 18%,rgba(139,157,225,.12),transparent 32%),radial-gradient(circle at 82% 8%,rgba(157,133,199,.1),transparent 30%),#0f172a52;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:flex-start;justify-content:center;padding-top:80px;z-index:2000;animation:fadeIn .2s ease}.day-carousel-container{position:relative;background:linear-gradient(160deg,#fffffff5,#f8fafff2 45%,#f1f3fdf5);border:1px solid rgba(139,157,225,.16);border-radius:20px;box-shadow:0 20px 60px #7b8fd238,0 0 0 1px #fff9;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);max-width:90%;width:600px;overflow:hidden;animation:slideDown .3s ease}.day-carousel-container:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(139,157,225,.14),transparent 34%),radial-gradient(circle at 80% 0%,rgba(157,133,199,.12),transparent 32%);pointer-events:none}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.carousel-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e8e8e8}.carousel-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#2c3e50}.carousel-header .close-btn{background:none;border:none;cursor:pointer;color:#666;padding:.5rem;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.carousel-header .close-btn:hover{background:#f5f5f5;color:#2c3e50}.carousel-wrapper{position:relative;padding:2.75rem 0 2.25rem;display:flex;align-items:center;gap:.5rem}.carousel-nav{background:#fff;border:2px solid #e8e8e8;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;margin:0 .5rem}.carousel-nav:hover:not(:disabled){background:#2f6bd8;border-color:#2f6bd8;color:#fff;transform:scale(1.1)}.carousel-nav:disabled{opacity:.3;cursor:not-allowed}.carousel-track{display:flex;gap:1rem;overflow-x:auto;scroll-behavior:smooth;padding:.5rem 1rem .75rem;flex:1;align-items:center;scrollbar-width:none;-ms-overflow-style:none}.carousel-track::-webkit-scrollbar{display:none}.day-item{flex-shrink:0;background:#f8f9fa;border:2px solid transparent;border-radius:16px;padding:1rem;min-width:100px;cursor:pointer;transition:all .3s;text-align:center}.day-item .day-label{font-size:.875rem;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:.5rem}.day-item .day-date{font-size:2rem;font-weight:700;color:#2c3e50;line-height:1;margin-bottom:.25rem}.day-item .day-month{font-size:.875rem;color:#666;text-transform:capitalize}.day-item:hover{background:#e8eaf6;border-color:#2f6bd8;transform:translateY(-1px)}.day-item.selected{background:linear-gradient(135deg,#2f6bd8,#48c7ff);border-color:#2f6bd8;transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}.day-item.selected .day-label,.day-item.selected .day-date,.day-item.selected .day-month{color:#fff}.time-selector{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;border-top:1px solid #e8e8e8;border-bottom:1px solid #e8e8e8}.time-selector label{font-weight:600;color:#2c3e50}.time-selector input[type=time]{padding:.75rem 1rem;border:2px solid #e8e8e8;border-radius:12px;font-size:1rem;font-weight:600;color:#2c3e50;transition:all .2s;text-align:center;min-width:120px}.time-selector input[type=time]:focus{outline:none;border-color:#2f6bd8;box-shadow:0 0 0 3px #667eea1a}.carousel-footer{display:flex;gap:1rem;padding:1.5rem;justify-content:flex-end}.carousel-footer button{padding:.75rem 2rem;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;border:none}.carousel-footer button.btn-secondary{background:#f5f5f5;color:#666}.carousel-footer button.btn-secondary:hover{background:#e8e8e8}.carousel-footer button.btn-primary{background:linear-gradient(135deg,#2f6bd8,#48c7ff);color:#fff}.carousel-footer button.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}[data-theme=dark] .day-carousel-overlay{background:radial-gradient(circle at 20% 20%,rgba(94,196,255,.06),transparent 28%),radial-gradient(circle at 80% 10%,rgba(139,109,217,.08),transparent 30%),#0a1628a6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}[data-theme=dark] .day-carousel-container{background:linear-gradient(160deg,#142037e0,#121e34e6,#0f192de6);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--home-border-soft);box-shadow:0 20px 60px #00000080,0 0 0 1px var(--home-border-soft),0 0 24px var(--home-glow)}[data-theme=dark] .day-carousel-container:before{background:radial-gradient(circle at 18% 18%,rgba(94,196,255,.16),transparent 32%),radial-gradient(circle at 82% 8%,rgba(139,109,217,.14),transparent 30%)}[data-theme=dark] .carousel-header{border-bottom:1px solid var(--home-border-soft)}[data-theme=dark] .carousel-header h3{color:var(--home-text-strong);text-shadow:0 0 18px rgba(124,242,255,.2)}[data-theme=dark] .carousel-header .close-btn{color:var(--home-text-muted)}[data-theme=dark] .carousel-header .close-btn:hover{background:#7cf2ff1f;color:var(--home-text-strong)}[data-theme=dark] .carousel-nav{background:var(--home-surface-soft);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-color:var(--home-border-soft);color:var(--home-text-strong);box-shadow:0 10px 24px #0006,0 0 0 1px var(--home-border-soft)}[data-theme=dark] .carousel-nav:hover:not(:disabled){background:linear-gradient(135deg,var(--home-accent),var(--home-accent-2));border-color:var(--home-border-strong);color:var(--home-text-strong);box-shadow:0 0 0 1px var(--home-border-strong),0 12px 26px #00000073,0 0 16px #5ec4ff38}[data-theme=dark] .day-item{background:var(--home-surface-soft);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-color:var(--home-border-soft);color:var(--home-text-strong);box-shadow:0 8px 22px #0006}[data-theme=dark] .day-item .day-label,[data-theme=dark] .day-item .day-month{color:var(--home-text-muted)}[data-theme=dark] .day-item .day-date{color:var(--home-text-strong);text-shadow:0 0 18px rgba(124,242,255,.16)}[data-theme=dark] .day-item:hover{background:#5ec4ff14;border-color:var(--home-border-strong);transform:translateY(-2px);box-shadow:0 10px 26px #00000073,0 0 0 1px var(--home-border-strong),0 0 16px #5ec4ff2e}[data-theme=dark] .day-item.selected{background:linear-gradient(135deg,var(--home-accent) 0%,var(--home-accent-2) 100%);border-color:var(--home-border-strong);box-shadow:0 10px 28px #00000080,0 0 0 1px var(--home-border-strong),0 0 20px #5ec4ff3d}[data-theme=dark] .day-item.selected .day-label,[data-theme=dark] .day-item.selected .day-date,[data-theme=dark] .day-item.selected .day-month{color:var(--home-text-strong)}[data-theme=dark] .time-selector{border-top:1px solid var(--home-border-soft);border-bottom:1px solid var(--home-border-soft)}[data-theme=dark] .time-selector label{color:var(--home-text-strong)}[data-theme=dark] .time-selector input[type=time]{background:var(--home-surface-soft);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-color:var(--home-border-soft);color:var(--home-text-strong);box-shadow:0 0 0 1px var(--home-border-soft),0 8px 20px #0006}[data-theme=dark] .time-selector input[type=time]:focus{border-color:var(--home-border-strong);box-shadow:0 0 0 1px var(--home-border-strong),0 0 20px #7cf2ff33}[data-theme=dark] .carousel-footer button.btn-secondary{background:var(--home-surface-soft);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--home-text-muted);border:1px solid var(--home-border-soft)}[data-theme=dark] .carousel-footer button.btn-secondary:hover{background:#5ec4ff14;color:var(--home-text-strong)}[data-theme=dark] .carousel-footer button.btn-primary{background:linear-gradient(135deg,var(--home-accent),var(--home-accent-2));color:var(--home-text-strong);box-shadow:0 10px 24px #00000073,0 0 0 1px var(--home-border-soft),0 0 18px var(--home-glow)}[data-theme=dark] .carousel-footer button.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px #00000080,0 0 0 1px var(--home-border-strong),0 0 20px #5ec4ff38}@media(max-width:768px){.day-carousel-overlay{padding-top:20px;align-items:flex-start}.day-carousel-container{max-width:95%;margin:0 auto}.carousel-header{padding:1rem}.carousel-header h3{font-size:1.1rem}.carousel-wrapper{padding:1.5rem 0}.carousel-nav{width:36px;height:36px;margin:0 .25rem}.day-item{min-width:80px;padding:.75rem}.day-item .day-date{font-size:1.75rem}.time-selector{flex-direction:column;gap:.75rem;padding:1rem}.time-selector input[type=time]{width:100%;max-width:200px}.carousel-footer{padding:1rem;flex-direction:column-reverse}.carousel-footer button{width:100%}}@media(max-width:480px){.day-item{min-width:70px;padding:.625rem}.day-item .day-label{font-size:.75rem}.day-item .day-date{font-size:1.5rem}.day-item .day-month{font-size:.75rem}}.hamburger-btn{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:transparent;border:none;margin:0;padding:8px;width:40px;height:40px;position:relative;background:linear-gradient(135deg,#58b1ff26,#8bd3ff14),#ffffff40;border:1px solid rgba(88,177,255,.3);border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #58b1ff1a}@media(max-width:768px){.hamburger-btn{display:flex}}.hamburger-btn:hover{background:linear-gradient(135deg,#58b1ff40,#8bd3ff26),#ffffff59;border-color:#58b1ff73;transform:scale(1.05);box-shadow:0 4px 12px #58b1ff33}.hamburger-btn:active{transform:scale(.98)}.hamburger-btn span{display:block;width:24px;height:3px;background:#fff;border-radius:3px;transition:.4s cubic-bezier(.4,0,.2,1);position:absolute;box-shadow:0 1px 4px #00000026,0 0 8px #fff6}.hamburger-btn span:nth-child(1){top:10px}.hamburger-btn span:nth-child(2){top:18px}.hamburger-btn span:nth-child(3){top:26px}[data-theme=dark] .hamburger-btn{background:linear-gradient(135deg,#5ec4ff33,#8b6dd92e);border-color:var(--home-border-strong);box-shadow:0 10px 24px #0006,0 0 0 1px var(--home-border-soft)}[data-theme=dark] .hamburger-btn:hover{background:linear-gradient(135deg,#5ec4ff4d,#8b6dd942);border-color:var(--home-border-strong);box-shadow:0 0 0 1px var(--home-border-strong),0 12px 26px #00000073}[data-theme=dark] .hamburger-btn span{background:var(--home-text-strong);box-shadow:0 0 12px #7cf2ff33}.bottom-container{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-end;padding:1.5rem;pointer-events:none;z-index:999;gap:.875rem;isolation:isolate}@media(max-width:768px){.bottom-container{padding:.5rem;flex-direction:column;align-items:stretch;gap:.5rem}}.bottom-container>*{pointer-events:auto}.bottom-container .legend-footer,.bottom-container .stats-group{height:60px}@media(max-width:768px){.bottom-container .legend-footer,.bottom-container .stats-group{height:auto}}@media(max-width:768px){.bottom-container .legend-footer{order:2}}@media(max-width:768px){.bottom-container .stats-group{order:1}}.stats-group{display:flex;align-items:stretch;gap:0;height:60px}@media(max-width:768px){.stats-group{flex-direction:row;height:auto;gap:.25rem;width:100%}}.legend-footer{background:linear-gradient(145deg,#2f6bd80f,#2ab3ff0a),var(--home-surface-soft);padding:.5rem .875rem;border-radius:16px;box-shadow:var(--home-shadow-soft);backdrop-filter:blur(12px);border:1px solid var(--home-border-soft);display:flex;align-items:center;justify-content:center}@media(max-width:768px){.legend-footer{padding:.25rem .5rem;width:100%;border-radius:12px;height:auto!important}}.legend-title{font-size:.85rem;font-weight:700;color:var(--home-text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}@media(max-width:768px){.legend-title{font-size:.8rem}}.legend-scale{display:flex;gap:.875rem;align-items:center}@media(max-width:768px){.legend-scale{gap:.25rem;flex-wrap:nowrap;overflow-x:auto;width:100%;justify-content:space-between;scrollbar-width:none;-ms-overflow-style:none}.legend-scale::-webkit-scrollbar{display:none}}@media(max-width:480px){.legend-scale{gap:.375rem}}.legend-item{display:flex;align-items:center;gap:.4rem;flex-shrink:0}@media(max-width:768px){.legend-item{gap:.25rem;flex-direction:column;align-items:center;text-align:center}}.legend-item span{font-size:.72rem;font-weight:600;color:var(--home-text-strong);white-space:nowrap}@media(max-width:768px){.legend-item span{font-size:.6rem;line-height:1.2;max-width:4rem;white-space:normal}}@media(max-width:480px){.legend-item span{font-size:.55rem;max-width:3.5rem}}.legend-color{width:18px;height:14px;border-radius:4px;border:1px solid var(--home-border-soft);box-shadow:0 6px 16px #0000001f}@media(max-width:768px){.legend-color{width:20px;height:20px;border-radius:8px}}@media(max-width:480px){.legend-color{width:18px;height:18px}}[data-theme=dark] .legend-footer{background:var(--home-surface-soft);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--home-border-soft);box-shadow:0 8px 30px #0006,0 0 0 1px var(--home-border-soft),0 0 16px var(--home-glow)}[data-theme=dark] .legend-title{color:var(--home-text-muted)}[data-theme=dark] .legend-item span{color:var(--home-text-strong)}[data-theme=dark] .legend-color{border-color:var(--home-border-soft);box-shadow:0 0 0 1px var(--home-border-soft),0 0 14px #7cf2ff29}.info-toggle-btn{background:linear-gradient(145deg,#2f6bd814,#2ab3ff0d),var(--home-surface-strong);border:1px solid var(--home-border-soft);border-left:none;padding:0 .875rem;border-radius:0 16px 16px 0;display:flex;align-items:center;cursor:pointer;transition:.3s ease;box-shadow:var(--home-shadow-soft);font-weight:600;color:var(--home-text-strong);backdrop-filter:blur(16px);min-width:180px;height:100%}@media(max-width:768px){.info-toggle-btn{padding:.25rem .5rem;border-radius:12px;border-left:1px solid var(--home-border-soft);height:auto!important;min-width:auto;flex:1;justify-content:center}}.info-toggle-btn:hover{background:var(--home-control-hover);transform:translateY(-2px);border-color:var(--home-border-strong);box-shadow:var(--home-shadow-strong)}.info-toggle-btn:active{transform:translateY(0) scale(.98)}.btn-content{display:flex;align-items:center;gap:.5rem;width:100%}.toggle-icon{flex-shrink:0;width:24px;height:24px;color:#2f6bd8}.toggle-text{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.8rem}@media(max-width:768px){.toggle-text{max-width:none;font-size:.7rem;overflow:visible;text-overflow:clip;white-space:normal;text-align:center;line-height:1.2}}.info-panel{--panel-shift-x: 100%;--panel-opacity: 0;--panel-shadow: var(--info-panel-shadow, -8px 0 32px rgba(0, 0, 0, .15));position:fixed;top:0;right:0;width:420px;height:100vh;background:var(--info-panel-surface, var(--home-surface-strong));border-left:1px solid var(--info-panel-border, var(--home-border-strong));box-shadow:var(--panel-shadow);overflow-y:auto;overflow-x:hidden;z-index:1004;transform:translate3d(var(--panel-shift-x),0,0);opacity:var(--panel-opacity);pointer-events:none;transition:transform .5s cubic-bezier(.22,1,.36,1),opacity .35s ease,box-shadow .3s ease,background .3s ease,border-color .3s ease;color:var(--home-text-strong);backdrop-filter:blur(16px)}.info-panel.is-open{--panel-shift-x: 0;--panel-opacity: 1;pointer-events:auto}.info-panel.panel-fade-enter-active,.info-panel.panel-fade-leave-active{transition:transform .55s cubic-bezier(.2,.8,.2,1),opacity .35s ease,box-shadow .35s ease}.info-panel.panel-fade-enter-from,.info-panel.panel-fade-leave-to{--panel-shift-x: calc(100% + 24px) ;--panel-opacity: 0;box-shadow:-2px 0 20px #00000014}.info-panel.panel-fade-enter-to,.info-panel.panel-fade-leave-from{--panel-shift-x: 0;--panel-opacity: 1}@media(max-width:768px){.info-panel{position:fixed;inset:0;width:100%;max-width:none;height:100vh;height:100dvh;max-height:none;border-left:none;border-top:none;border-radius:0;padding-bottom:calc(env(safe-area-inset-bottom) + .875rem);padding-top:calc(env(safe-area-inset-top) + .5rem);box-shadow:0 22px 64px #00000059}}.panel-header{color:var(--panel-header-text);padding:1rem 1.25rem;position:sticky;top:0;z-index:10;background:var(--panel-header-gradient);border-bottom:1px solid var(--info-panel-border);box-shadow:0 10px 30px #3556a329;backdrop-filter:blur(12px)}@media(max-width:768px){.panel-header{padding:.875rem .5rem}}.header-top{display:flex;align-items:center;justify-content:space-between;gap:.875rem;margin-bottom:.875rem}@media(max-width:768px){.header-top{gap:.25rem;margin-bottom:.25rem}}.header-top h2{margin:0;font-size:1.15rem;font-weight:700;flex:1}@media(max-width:768px){.header-top h2{font-size:1rem}}.header-top .city-name-clickable{margin:0;font-size:1.15rem;font-weight:700;color:var(--panel-header-text);cursor:pointer;transition:all .2s ease;padding:6px 12px;border-radius:12px;position:relative;background:#ffffffc7;border:1px solid rgba(59,130,246,.22);box-shadow:0 10px 24px #3556a324;width:fit-content}@media(max-width:768px){.header-top .city-name-clickable{font-size:1rem;padding:4px 8px}.header-top .city-name-clickable:after{font-size:.9rem;margin-left:6px}}.header-top .city-name-clickable:hover{text-decoration-color:#0f3f8cbf;background:#ffffffe6;transform:translate(2px)}.header-top .city-name-clickable:hover:after{opacity:1;transform:translate(0)}.header-top .city-name-clickable:active{transform:translate(0) scale(.98);background:#fffc}.time-navigation{display:flex;justify-content:center;align-items:center;gap:.25rem;padding:.5rem 0;border-top:1px solid var(--home-border-soft)}@media(max-width:768px){.time-navigation{padding:.25rem 0}}.nav-btn{background:transparent;border:none;cursor:pointer;padding:0;margin:0;width:32px;height:32px;border-radius:12px;display:flex;justify-content:center;align-items:center;background:var(--home-control-bg);color:var(--home-text-strong);transition:.2s ease;border:1px solid var(--home-border-soft);flex-shrink:0;box-shadow:var(--home-shadow-soft)}@media(max-width:768px){.nav-btn{width:28px;height:28px}}.nav-btn:hover:not(:disabled){background:var(--home-control-hover);transform:scale(1.08);border-color:var(--home-border-strong);box-shadow:var(--home-shadow-strong)}.nav-btn:active:not(:disabled){transform:scale(.95)}.nav-btn:disabled{opacity:.25;cursor:not-allowed}.nav-btn svg{width:16px;height:16px}@media(max-width:768px){.nav-btn svg{width:14px;height:14px}}.nav-btn.nav-btn-day{width:38px;height:38px;background:linear-gradient(135deg,#2f6bd81f,#2ab3ff14);border:1.5px solid var(--home-border-strong);border-radius:16px}@media(max-width:768px){.nav-btn.nav-btn-day{width:34px;height:34px}}.nav-btn.nav-btn-day svg{width:18px;height:18px}@media(max-width:768px){.nav-btn.nav-btn-day svg{width:16px;height:16px}}.nav-btn.nav-btn-day:hover:not(:disabled){background:linear-gradient(135deg,#2f6bd833,#2ab3ff24);border-color:var(--home-border-strong);box-shadow:var(--home-shadow-strong)}.datetime-display{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;background:var(--home-control-strong);border-radius:16px;color:var(--home-text-strong);border:1px solid var(--home-border-soft);transition:.2s ease;flex:1;min-width:0;box-shadow:var(--home-shadow-soft)}@media(max-width:768px){.datetime-display{padding:.25rem .5rem;gap:.25rem;margin:0 .5rem}}.datetime-display:hover{background:var(--home-control-hover);transform:translateY(-1px);border-color:var(--home-border-strong);box-shadow:var(--home-shadow-strong)}.datetime-display:active{transform:translateY(0)}.datetime-display svg{width:16px;height:16px;flex-shrink:0;opacity:.9}@media(max-width:768px){.datetime-display svg{width:14px;height:14px}}.datetime-display .datetime-text{font-size:.9rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}@media(max-width:768px){.datetime-display .datetime-text{font-size:.85rem}}.forecast-timeline{display:flex;gap:.5rem;padding:1.25rem;background:linear-gradient(145deg,#2563eb0f,#0ea5e90d),var(--info-panel-soft, var(--home-surface-soft));border-bottom:1px solid var(--home-border-soft);overflow-x:auto}@media(max-width:768px){.forecast-timeline{gap:.25rem;padding:.5rem}}.forecast-card{flex:1;min-width:100px;padding:.875rem;background:var(--info-panel-surface, var(--home-surface));border-radius:16px;border:1px solid var(--home-border-soft);cursor:pointer;transition:.2s ease;display:flex;flex-direction:column;align-items:center;gap:.25rem;box-shadow:var(--home-shadow-soft);color:var(--home-text-strong)}@media(max-width:768px){.forecast-card{min-width:80px;padding:.5rem}}.forecast-card.is-current{background:linear-gradient(135deg,#2563eb29,#0ea5e91f);border-color:var(--info-panel-border, var(--home-border-strong));box-shadow:0 0 0 3px var(--info-panel-highlight, rgba(66, 134, 255, .16))}.forecast-card:not(.is-current):hover{background:var(--home-control-hover);border-color:var(--home-border-strong);transform:translateY(-2px);box-shadow:var(--home-shadow-strong)}.forecast-card:active{transform:translateY(0)}.forecast-card.is-loading{cursor:wait;opacity:.7}.forecast-time{font-size:.9rem;font-weight:700;color:var(--home-text-strong);display:flex;flex-direction:column;align-items:center;gap:.15rem}@media(max-width:768px){.forecast-time{font-size:.8rem}}.forecast-date-label{font-size:.7rem;font-weight:600;color:var(--home-accent);opacity:.8}@media(max-width:768px){.forecast-date-label{font-size:.6rem}}.forecast-content{display:flex;flex-direction:column;align-items:center;gap:.25rem;width:100%}.forecast-temp{font-size:1.15rem;font-weight:800;background:linear-gradient(135deg,#2f6bd8,#48c7ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(max-width:768px){.forecast-temp{font-size:1rem}}.forecast-rain{display:flex;justify-content:center;align-items:center;gap:4px;font-size:.75rem;font-weight:600;color:var(--home-accent)}@media(max-width:768px){.forecast-rain{font-size:.7rem}}.forecast-rain svg{width:14px;height:14px}@media(max-width:768px){.forecast-rain svg{width:12px;height:12px}}.forecast-loading{display:flex;justify-content:center;align-items:center;padding:.875rem 0}.spinner-small{width:20px;height:20px;border:2px solid rgba(47,107,216,.22);border-top-color:var(--home-accent);border-radius:50%;animation:spin .8s linear infinite}.header-right{display:flex;align-items:center;gap:.5rem}@media(max-width:768px){.header-right{gap:.25rem}}.close-panel-btn{background:transparent;border:none;cursor:pointer;padding:0;margin:0;width:32px;height:32px;border-radius:50%;display:flex;justify-content:center;align-items:center;color:var(--panel-header-text);transition:.2s ease;flex-shrink:0;background:#ffffffe6;border:1px solid rgba(59,130,246,.22);box-shadow:0 10px 22px #3556a324}.close-panel-btn:hover{background:#3b82f624;border-color:#3b82f652;color:#0b3a83;transform:scale(1.1)}.close-panel-btn:active{transform:scale(.95)}.close-panel-btn svg{width:20px;height:20px}[data-theme=dark] .panel-header{box-shadow:var(--home-shadow-soft);border-bottom:1px solid var(--info-panel-border);backdrop-filter:blur(10px)}[data-theme=dark] .panel-header .city-name-clickable{color:#e8f2ff;text-decoration-color:#ffffff8c;background:#ffffff14;border-color:#ffffff1f;box-shadow:none}[data-theme=dark] .panel-header .city-name-clickable:hover{background:#ffffff29;text-decoration-color:#ffffffe6}[data-theme=dark] .header-right .close-panel-btn{background:var(--home-control-bg);border:1px solid var(--home-border-soft);color:var(--home-text-strong);box-shadow:var(--home-shadow-soft)}[data-theme=dark] .header-right .close-panel-btn:hover{background:var(--home-control-hover);border-color:var(--home-border-strong);color:var(--home-text-strong)}.intensity-badge{--intensity-color: var(--home-accent);display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600;color:var(--home-text-muted);white-space:nowrap;background:var(--home-control-bg);background:color-mix(in srgb,var(--home-control-bg) 55%,transparent);border:none;box-shadow:0 10px 26px #0000000f;backdrop-filter:blur(10px)}.intensity-badge:before{content:"";width:.6rem;height:.6rem;border-radius:50%;background:var(--intensity-color);box-shadow:0 0 0 4px var(--home-control-bg);box-shadow:0 0 0 4px color-mix(in srgb,var(--home-control-bg) 50%,transparent)}@media(max-width:768px){.intensity-badge{font-size:.7rem;padding:.2rem .25rem}}.info-panel .weather-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:1.25rem;background:var(--info-panel-soft, var(--home-surface-soft));border-top:1px solid var(--home-border-soft)}@media(max-width:768px){.info-panel .weather-grid{gap:.25rem;padding:.5rem}}.weather-item{display:flex;flex-direction:column;gap:.25rem}@media(max-width:768px){.weather-item{gap:.15rem}}.weather-label{font-size:.8rem;color:var(--home-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.7}@media(max-width:768px){.weather-label{font-size:.68rem}}.weather-value{font-size:1.4rem;font-weight:800;background:linear-gradient(135deg,#2f6bd8,#48c7ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.weather-value{font-size:1.2rem}}.update-time{padding:.875rem 1.25rem;font-size:.8rem;color:var(--home-text-muted);text-align:center;background:var(--info-panel-soft, var(--home-surface-soft));border-top:1px solid var(--home-border-soft);font-weight:500;opacity:.8}@media(max-width:768px){.update-time{padding:.5rem;font-size:.75rem}}@media(max-width:768px){.header-top .city-name-clickable{padding:8px 12px;min-height:44px;display:flex;align-items:center;text-decoration:none;text-decoration-thickness:2px;text-underline-offset:5px}.header-top .city-name-clickable:after{display:none}.header-top .city-name-clickable:active{background:#fff3;transform:scale(.97)}}@media(max-width:768px)and (hover:hover){.header-top .city-name-clickable:hover{background:#ffffff1f;text-decoration-color:#fff}}.stats-panel{background:#fffffff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);padding:.5rem .875rem;border-radius:16px 0 0 16px;box-shadow:none;display:flex;gap:.875rem;align-items:center;backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);border-right:none;height:100%}@media(max-width:768px){.stats-panel{padding:.25rem .5rem;gap:.5rem;border-radius:12px;border-right:1px solid rgba(255,255,255,.3);box-shadow:0 4px 20px #0006;height:auto!important;flex:1;justify-content:space-around}}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.15rem}.stat-label{font-size:.75rem;color:#2c3e50;font-weight:600;text-transform:uppercase;letter-spacing:.5px}@media(max-width:768px){.stat-label{font-size:.6rem}}.stat-value{font-size:1.2rem;font-weight:800;background:linear-gradient(135deg,#2f6bd8,#48c7ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(max-width:768px){.stat-value{font-size:.95rem}}.stat-divider{width:1px;height:30px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.2),transparent)}@media(max-width:768px){.stat-divider{height:20px}}[data-theme=dark] .stats-panel{background:var(--home-surface-soft);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--home-border-soft);box-shadow:0 10px 34px #0006,0 0 0 1px var(--home-border-soft),0 0 16px var(--home-glow)}[data-theme=dark] .stat-label{color:var(--home-text-muted)}[data-theme=dark] .stat-value{background-image:linear-gradient(135deg,var(--home-accent),var(--home-accent-2));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 22px rgba(124,242,255,.28)}[data-theme=dark] .stat-divider{background:linear-gradient(to bottom,transparent,var(--home-border-soft),transparent)}.loading-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1099;opacity:0;animation:fadeInDelayed .3s ease forwards;animation-delay:.8s}.loading-indicator{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1100;display:flex;flex-direction:column;align-items:center;gap:1.25rem;opacity:0;animation:slideUpDelayed .4s cubic-bezier(.34,1.56,.64,1) forwards;animation-delay:.8s}.loading-indicator .spinner-container{position:relative;width:4rem;height:4rem}.loading-indicator .spinner{width:100%;height:100%;border:.4rem solid rgba(255,255,255,.1);border-top:.4rem solid transparent;border-right:.4rem solid #2f6bd8;border-radius:50%;animation:spin 1.2s cubic-bezier(.5,0,.5,1) infinite;position:relative}@media(max-width:768px){.loading-indicator .spinner{border-width:.35rem}}.loading-indicator .spinner:before{content:"";position:absolute;inset:.2rem;border:.2rem solid transparent;border-bottom:.2rem solid rgba(255,255,255,.3);border-radius:50%;animation:spin-reverse .8s linear infinite}.loading-indicator .loading-text{background:#fffffff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.2);padding:.875rem 1.5rem;border-radius:20px;box-shadow:0 6px 20px #667eea99;border:1px solid rgba(255,255,255,.3);display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:200px}@media(max-width:768px){.loading-indicator .loading-text{padding:.5rem 1.25rem;min-width:180px}}.loading-indicator .loading-text .main-text{font-size:.9rem;font-weight:700;color:#2c3e50;background:linear-gradient(135deg,#2f6bd8,#48c7ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center}@media(max-width:768px){.loading-indicator .loading-text .main-text{font-size:.85rem}}.loading-indicator .loading-text .sub-text{font-size:.85rem;font-weight:500;color:#b0b0b0;text-align:center;opacity:.8}@media(max-width:768px){.loading-indicator .loading-text .sub-text{font-size:.75rem}}.loading-indicator .loading-text .dots{display:inline-flex;gap:2px}.loading-indicator .loading-text .dots span{width:4px;height:4px;background:#2f6bd8;border-radius:50%;animation:dots 1.4s ease-in-out infinite both}.loading-indicator .loading-text .dots span:nth-child(1){animation-delay:-.32s}.loading-indicator .loading-text .dots span:nth-child(2){animation-delay:-.16s}.loading-indicator .loading-text .dots span:nth-child(3){animation-delay:0s}.loading-indicator .weather-icon-loading{width:4rem;height:4rem;opacity:.8;animation:float 2s ease-in-out infinite}@media(max-width:768px){.loading-indicator .weather-icon-loading{width:3rem;height:3rem}}.loading-indicator .weather-icon-loading svg,.loading-indicator .weather-icon-loading img{width:100%;height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.loading-indicator .progress-ring circle{fill:none;stroke-width:4}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spin-reverse{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}@keyframes progress{0%{stroke-dashoffset:283}50%{stroke-dashoffset:70}to{stroke-dashoffset:283}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-50%) translateY(30px)}to{opacity:1;transform:translate(-50%,-50%) translateY(0)}}@keyframes slideUpDelayed{0%{opacity:0;transform:translate(-50%,-50%) translateY(30px)}to{opacity:1;transform:translate(-50%,-50%) translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInDelayed{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes dots{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}@media(max-width:768px){.loading-indicator{gap:.875rem}.loading-indicator .spinner-container{width:3rem;height:3rem}.loading-indicator .spinner{border-width:.3rem}.loading-indicator .spinner:before{inset:.15rem;border-width:.15rem}.loading-indicator .progress-ring{top:-.15rem;left:-.15rem;width:calc(100% + .3rem);height:calc(100% + .3rem)}}.weather-alerts{margin-top:20px;background:linear-gradient(135deg,#fff8dc,#fffaf0);padding:1rem;border-left:.1rem solid #ffa500}.weather-alerts__header{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:#d97706}.weather-alerts__header svg{flex-shrink:0}.weather-alerts__header h3{margin:0;font-size:16px;font-weight:600}.weather-alerts__list{display:flex;flex-direction:column;gap:12px}.weather-alerts__item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;background:#fff;border-left:3px solid;transition:transform .2s,box-shadow .2s;cursor:pointer;user-select:none}.info-panel .weather-alerts__item{background:#fff!important}.weather-alerts__item:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.weather-alerts__item:active{transform:translate(2px) scale(.98)}.weather-alerts__item:focus{outline:2px solid rgba(0,0,0,.2);outline-offset:2px}.weather-alerts__item--severity-danger{border-left-color:#dc2626}.weather-alerts__item--severity-danger .weather-alerts__icon{color:#dc2626}.weather-alerts__item--severity-alert{border-left-color:#ea580c}.weather-alerts__item--severity-alert .weather-alerts__icon{color:#ea580c}.weather-alerts__item--severity-warning{border-left-color:#d97706}.weather-alerts__item--severity-warning .weather-alerts__icon{color:#d97706}.weather-alerts__item--severity-info{border-left-color:#0284c7}.weather-alerts__item--severity-info .weather-alerts__icon{color:#0284c7}.weather-alerts__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.weather-alerts__content{flex:1;min-width:0}.weather-alerts__description{font-size:14px;font-weight:500;margin-bottom:6px;line-height:1.4}.weather-alerts__meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:12px;opacity:.7}.weather-alerts__code{font-weight:600;text-transform:uppercase;letter-spacing:.5px}.weather-alerts__time{color:#666}.weather-alerts__emoji{margin-right:4px}.weather-alerts__arrow{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;opacity:.4;transition:opacity .2s,transform .2s}.weather-alerts__arrow svg{width:16px;height:16px}.weather-alerts__item:hover .weather-alerts__arrow{opacity:.8;transform:translate(2px)}@media(max-width:768px){.weather-alerts{padding:12px}.weather-alerts__header h3{font-size:14px}.weather-alerts__item{padding:10px;gap:10px}.weather-alerts__icon{width:28px;height:28px}.weather-alerts__description{font-size:13px}.weather-alerts__meta{font-size:11px;gap:8px}}[data-theme=dark] .weather-alerts{background:linear-gradient(135deg,#7cf2ff1f,#9f7aea1f);border-left-color:var(--home-accent);box-shadow:0 12px 30px #00000073,0 0 0 1px var(--home-border-soft),0 0 18px var(--home-glow)}[data-theme=dark] .weather-alerts__header,[data-theme=dark] .weather-alerts__header h3{color:var(--home-text-strong)}[data-theme=dark] .weather-alerts__item{background:var(--home-surface)!important;box-shadow:0 12px 28px #00000080,0 0 0 1px var(--home-border-soft)}[data-theme=dark] .weather-alerts__item:hover{background:#7cf2ff14!important;box-shadow:0 14px 32px #0000008c,0 0 0 1px var(--home-border-strong),0 0 18px #7cf2ff33}[data-theme=dark] .weather-alerts__description{color:var(--home-text-strong)}[data-theme=dark] .weather-alerts__meta,[data-theme=dark] .weather-alerts__time{color:var(--home-text-muted)}[data-theme=dark] .weather-alerts__code{background:#7cf2ff1f;color:var(--home-text-strong)}.alert-detail__overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2010;padding:1.25rem}@media(max-width:768px){.alert-detail__overlay{padding:0;align-items:flex-end}}.alert-detail__card{background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;max-width:600px;width:100%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;border-left:4px solid}.alert-detail__card--severity-danger{border-left-color:#dc2626}.alert-detail__card--severity-alert{border-left-color:#ea580c}.alert-detail__card--severity-warning{border-left-color:#d97706}.alert-detail__card--severity-info{border-left-color:#0284c7}@media(max-width:768px){.alert-detail__card{max-width:100%;max-height:90vh;border-radius:20px 20px 0 0}}.alert-detail__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;border-bottom:1px solid rgba(0,0,0,.08)}@media(max-width:768px){.alert-detail__header{padding:.875rem}}.alert-detail__severity-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:12px;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.alert-detail__severity-badge--danger{background:#dc26261a;color:#dc2626}.alert-detail__severity-badge--alert{background:#ea580c1a;color:#ea580c}.alert-detail__severity-badge--warning{background:#d977061a;color:#d97706}.alert-detail__severity-badge--info{background:#0284c71a;color:#0284c7}.alert-detail__severity-icon{width:20px;height:20px}.alert-detail__severity-label{font-weight:700;letter-spacing:.6px}.alert-detail__close{background:#0000000d;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#0009}.alert-detail__close svg{width:20px;height:20px}.alert-detail__close:hover{background:#0000001a;color:#000c;transform:scale(1.1)}.alert-detail__close:active{transform:scale(.95)}.alert-detail__content{flex:1;overflow-y:auto;padding:1.25rem}@media(max-width:768px){.alert-detail__content{padding:.875rem}}.alert-detail__content::-webkit-scrollbar{width:8px}.alert-detail__content::-webkit-scrollbar-track{background:#00000008;border-radius:4px}.alert-detail__content::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px}.alert-detail__content::-webkit-scrollbar-thumb:hover{background:#00000040}.alert-detail__description{margin-bottom:1.5rem}.alert-detail__description h2{font-size:24px;font-weight:700;color:#000000e6;margin:0 0 .875rem;line-height:1.3}@media(max-width:768px){.alert-detail__description h2{font-size:20px}}.alert-detail__meta{display:flex;gap:.875rem;flex-wrap:wrap;font-size:14px}.alert-detail__type{padding:4px .5rem;background:#0000000f;border-radius:8px;font-weight:500;color:#000000b3}.alert-detail__time{padding:4px .5rem;background:#0000000a;border-radius:8px;color:#0009;display:flex;align-items:center;gap:4px;border:none;font-family:inherit;font-size:14px;cursor:default}.alert-detail__time--clickable{cursor:pointer;transition:all .2s ease}.alert-detail__time--clickable:hover{background:#677eea1a;color:#667eea;transform:translateY(-1px);box-shadow:0 2px 8px #677eea33}.alert-detail__time--clickable:active{transform:translateY(0)}.alert-detail__time--clickable svg{transition:transform .2s ease}.alert-detail__time--clickable:hover svg{transform:rotate(15deg)}.alert-detail__technical{margin-bottom:1.5rem;padding:.875rem;background:#00000005;border-radius:12px;border:1px solid rgba(0,0,0,.05)}.alert-detail__technical h3{font-size:16px;font-weight:600;color:#000c;margin:0 0 .875rem;display:flex;align-items:center;gap:.5rem}.alert-detail__technical h3:before{content:"📊"}.alert-detail__details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.875rem}@media(max-width:768px){.alert-detail__details-grid{grid-template-columns:1fr;gap:.5rem}}.alert-detail__detail{display:flex;flex-direction:column;gap:4px;padding:.5rem;background:#fff9;border-radius:8px}.alert-detail__detail-label{font-size:12px;font-weight:500;color:#00000080;text-transform:uppercase;letter-spacing:.3px}.alert-detail__detail-value{font-size:18px;font-weight:700;color:#000000d9}@media(max-width:768px){.alert-detail__detail-value{font-size:16px}}.alert-panel-enter-active,.alert-panel-leave-active{transition:opacity .3s ease}.alert-panel-enter-active .alert-detail__card,.alert-panel-leave-active .alert-detail__card{transition:transform .3s ease,opacity .3s ease}.alert-panel-enter-from,.alert-panel-leave-to{opacity:0}.alert-panel-enter-from .alert-detail__card,.alert-panel-leave-to .alert-detail__card{transform:translateY(20px);opacity:0}@media(max-width:768px){.alert-panel-enter-from .alert-detail__card,.alert-panel-leave-to .alert-detail__card{transform:translateY(100%)}}.alert-panel-enter-to,.alert-panel-leave-from{opacity:1}.alert-panel-enter-to .alert-detail__card,.alert-panel-leave-from .alert-detail__card{transform:translateY(0);opacity:1}[data-theme=dark] .alert-detail__card{background:#1e293bfa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);box-shadow:0 20px 60px #0009}[data-theme=dark] .alert-detail__severity-badge--danger{background:#dc262633;color:#fca5a5}[data-theme=dark] .alert-detail__severity-badge--alert{background:#ea580c33;color:#fdba74}[data-theme=dark] .alert-detail__severity-badge--warning{background:#d9770633;color:#fcd34d}[data-theme=dark] .alert-detail__severity-badge--info{background:#0284c733;color:#7dd3fc}[data-theme=dark] .alert-detail__close{background:#ffffff1a;color:#fffc}[data-theme=dark] .alert-detail__close:hover{background:#fff3;color:#fff}[data-theme=dark] .alert-detail__description h2{color:var(--weather-text-primary)}[data-theme=dark] .alert-detail__type,[data-theme=dark] .alert-detail__time{background:#4755694d;color:var(--weather-text-secondary)}[data-theme=dark] .alert-detail__type--clickable:hover,[data-theme=dark] .alert-detail__time--clickable:hover{background:#677eea4d;color:var(--weather-primary)}[data-theme=dark] .alert-detail__technical{background:#0f172a4d;border-color:#4755694d}[data-theme=dark] .alert-detail__technical h3{color:var(--weather-text-primary)}[data-theme=dark] .alert-detail__detail{background:#33415566}[data-theme=dark] .alert-detail__detail-label{color:var(--weather-text-muted)}[data-theme=dark] .alert-detail__detail-value{color:var(--weather-text-primary)}.search-modal-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:.875rem}.search-modal{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}@media(max-width:768px){.search-modal{max-height:90vh}}.search-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.1);flex-shrink:0}@media(max-width:768px){.search-modal-header{padding:.875rem 1.25rem}}.search-modal-title{color:#2c3e50;font-size:1rem;font-weight:700;margin:0}@media(max-width:768px){.search-modal-title{font-size:1rem}}.search-close-btn{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;color:#b0b0b0;border-radius:12px;transition:all .3s ease}.search-close-btn:hover{background:#0000000d;color:#2c3e50}.search-close-btn:active{transform:scale(.95)}.search-input-container{position:relative;padding:.875rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.1);flex-shrink:0}@media(max-width:768px){.search-input-container{padding:.875rem 1.25rem}}.search-icon{position:absolute;left:2.375rem;top:50%;transform:translateY(-50%);color:#b0b0b0;pointer-events:none}@media(max-width:768px){.search-icon{left:2.125rem}}.search-input{width:100%;padding:.875rem .875rem .875rem calc(1.75rem + 24px);border:2px solid rgba(0,0,0,.1);border-radius:16px;font-size:.8rem;color:#2c3e50;transition:all .3s ease;background:#00000008}.search-input::placeholder{color:#b0b0b0}.search-input:focus{outline:none;border-color:#2f6bd8;background:#fff;box-shadow:0 0 0 3px #667eea1a}@media(max-width:768px){.search-input{font-size:.75rem;padding:.5rem .5rem .5rem calc(1rem + 20px)}}.search-clear-btn{background:transparent;border:none;cursor:pointer;padding:0;margin:0;position:absolute;right:2rem;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;color:#b0b0b0;border-radius:12px;transition:all .3s ease}.search-clear-btn:hover{background:#0000000d;color:#2c3e50}.search-clear-btn:active{transform:translateY(-50%) scale(.95)}@media(max-width:768px){.search-clear-btn{right:1.75rem}}.search-results{flex:1;overflow-y:auto;padding:.875rem}@media(max-width:768px){.search-results{padding:.5rem}}.search-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;gap:.875rem;color:#b0b0b0}.search-spinner{width:40px;height:40px;border:3px solid rgba(0,0,0,.1);border-top-color:#2f6bd8;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-empty,.search-hint{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;gap:.875rem;color:#b0b0b0;text-align:center}.search-empty svg,.search-hint svg{opacity:.5}.search-empty p,.search-hint p{margin:0;font-size:.8rem}.search-results-list{display:flex;flex-direction:column;gap:.25rem}.search-result-item{background:transparent;border:none;padding:0;margin:0;display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;background:#fff;border:2px solid rgba(0,0,0,.1);border-radius:16px;transition:all .3s ease;cursor:pointer;text-align:left}.search-result-item:hover{background:#00000008;border-color:#2f6bd8;transform:translate(4px)}.search-result-item:hover .result-arrow{transform:translate(4px)}.search-result-item:active{transform:translate(2px)}@media(max-width:768px){.search-result-item{padding:.5rem .875rem}}.result-city-info{display:flex;flex-direction:column;gap:.25rem;flex:1;flex-grow:1}.result-city-name{color:#2c3e50;font-size:.9rem;font-weight:600}@media(max-width:768px){.result-city-name{font-size:.8rem}}.result-city-state{color:#b0b0b0;font-size:.75rem}@media(max-width:768px){.result-city-state{font-size:.7rem}}.result-arrow{color:#b0b0b0;transition:all .3s ease;flex-shrink:0}.modal-enter-active,.modal-leave-active{transition:opacity .3s ease}.modal-enter-active .search-modal,.modal-leave-active .search-modal{transition:transform .3s ease}.modal-enter-from,.modal-leave-to{opacity:0}.modal-enter-from .search-modal,.modal-leave-to .search-modal{transform:scale(.95) translateY(-20px)}.layer-selector{position:relative;min-width:160px}.layer-selector__trigger{background:transparent;border:none;padding:0;margin:0;width:100%;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.55rem .85rem;background:linear-gradient(135deg,#58b1ff0a,#8bd3ff05),var(--home-control-strong);border:1px solid var(--home-control-border);border-radius:12px;color:var(--home-text-strong);font-weight:600;font-size:.75rem;cursor:pointer;transition:all .2s ease;box-shadow:var(--home-shadow-soft);backdrop-filter:blur(12px)}.layer-selector__trigger:hover{background:linear-gradient(135deg,#58b1ff14,#8bd3ff0a),var(--home-control-strong);border-color:var(--home-border-strong);transform:translateY(-1px);box-shadow:var(--home-shadow-strong)}.layer-selector__trigger:active{transform:scale(.98)}.layer-selector__trigger--open{border-color:var(--home-accent);box-shadow:0 0 0 3px var(--home-glow),var(--home-shadow-strong)}.layer-selector__trigger-content{display:flex;align-items:center;justify-content:center;gap:.25rem;flex:1}@media(max-width:768px){.layer-selector__trigger-content{margin-left:calc((40px + .5rem)/2)}}.layer-selector__icon{flex-shrink:0;color:var(--home-accent);transition:transform .2s ease}.layer-selector__trigger:hover .layer-selector__icon{transform:scale(1.1)}.layer-selector__label{font-size:.75rem;line-height:1.1;display:inline-flex;align-items:center}.layer-selector__chevron{flex-shrink:0;color:var(--home-text-muted);transition:transform .3s ease;align-self:center}.layer-selector__chevron--rotated{transform:rotate(180deg)}.layer-selector__dropdown{position:absolute;top:calc(100% + 6px);left:0;width:100%;background:var(--home-surface-strong);border:1px solid var(--home-border-strong);border-radius:12px;box-shadow:var(--home-shadow-strong);overflow:hidden;z-index:1050;backdrop-filter:blur(16px);margin-top:0}.layer-selector__item{background:transparent;border:none;padding:0;margin:0;width:100%;display:flex;align-items:center;gap:.5rem;padding:.65rem .85rem;color:var(--home-text-strong);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;border-bottom:1px solid var(--home-border-soft)}.layer-selector__item:last-child{border-bottom:none}.layer-selector__item:hover{background:var(--home-control-hover);padding-left:1rem}.layer-selector__item:hover .layer-selector__item-icon{transform:scale(1.15)}.layer-selector__item:active{background:var(--home-control-hover);transform:scale(.98)}.layer-selector__item--active{background:linear-gradient(90deg,var(--home-glow),transparent);color:var(--home-accent)}.layer-selector__item--active .layer-selector__item-icon{color:var(--home-accent)}.layer-selector__item-icon{flex-shrink:0;transition:all .2s ease}.layer-selector__item-label{flex:1;text-align:left}.layer-selector__check-icon{flex-shrink:0;color:var(--home-accent)}.layer-selector-dropdown-enter-active{animation:layer-selector-dropdown-in .2s cubic-bezier(.34,1.56,.64,1)}.layer-selector-dropdown-leave-active{animation:layer-selector-dropdown-out .15s ease-in}@keyframes layer-selector-dropdown-in{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes layer-selector-dropdown-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-4px) scale(.98)}}.map-carousel{display:flex;align-items:center;gap:.4rem;width:100%;min-width:0;padding:.5rem .65rem;border-radius:16px;border:1px solid var(--home-border-strong);background:linear-gradient(140deg,#2f6bd814,#34d3990f),var(--home-surface-soft);box-shadow:var(--home-shadow-soft);min-height:60px}@media(max-width:768px){.map-carousel{padding:.45rem .55rem;gap:.3rem}}.map-carousel__nav{background:transparent;border:none;cursor:pointer;padding:0;margin:0;width:34px;height:34px;border-radius:50%;border:1px solid var(--home-border-soft);background:var(--home-control-bg);color:var(--home-text-muted);display:flex;align-items:center;justify-content:center;box-shadow:var(--home-shadow-soft);transition:.2s ease;flex-shrink:0}@media(max-width:768px){.map-carousel__nav{width:32px;height:32px}}.map-carousel__nav:hover:not(:disabled){color:var(--home-text-strong);background:linear-gradient(135deg,#2f6bd829,#34d39929);border-color:var(--home-border-strong);transform:translateY(-1px)}.map-carousel__nav:active:not(:disabled){transform:translateY(0)}.map-carousel__nav:disabled{opacity:.4;cursor:not-allowed}.map-carousel__nav svg{width:14px;height:14px}.map-carousel__nav--prev{margin-right:.1rem}.map-carousel__nav--next{margin-left:.1rem}.map-carousel__track{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;flex:1;min-width:0;width:100%;overflow-x:auto;padding:.1rem .2rem;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;scroll-snap-type:x mandatory;scroll-padding:.2rem;-webkit-overflow-scrolling:touch}.map-carousel__track::-webkit-scrollbar{display:none}@media(max-width:768px){.map-carousel__track{gap:.4rem}}.map-carousel__item{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.12rem;min-width:84px;padding:.5rem .55rem;border-radius:12px;border:1px solid var(--home-border-soft);background:var(--home-surface);color:var(--home-text-strong);box-shadow:var(--home-shadow-soft);transition:.2s ease;text-align:center;flex-grow:1;scroll-snap-align:start;white-space:nowrap}@media(max-width:768px){.map-carousel__item{min-width:78px;padding:.45rem .5rem}}.map-carousel__item:hover{border-color:var(--home-border-strong);transform:translateY(-1px)}.map-carousel__item:active{transform:translateY(0)}.map-carousel__item--active{background:linear-gradient(135deg,var(--home-accent),var(--home-accent-2));border-color:transparent;box-shadow:var(--home-shadow-strong);color:#fff}.map-carousel__item--active .map-carousel__label{color:#ffffffe6}.map-carousel__label{font-size:.68rem;letter-spacing:-.3px;color:var(--home-text-muted);font-weight:600;line-height:1.1}.map-carousel__value{font-size:.95rem;font-weight:600;line-height:1.05}@media(max-width:768px){.map-carousel__value{font-size:.9rem}}.touch-carousel{position:relative;width:100%;overflow:hidden;padding:.875rem 0 2rem}.touch-carousel__track{display:flex;width:100%;cursor:grab;user-select:none;-webkit-user-select:none;touch-action:pan-y;will-change:transform}.touch-carousel__track:active{cursor:grabbing}.touch-carousel__nav{background:transparent;border:none;padding:0;margin:0;position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid rgba(139,157,225,.2);color:#8b9de1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #8b9de126;z-index:10}.touch-carousel__nav:hover{background:#fff;border-color:#8b9de1;transform:translateY(-50%) scale(1.08);box-shadow:0 6px 24px #8b9de140}.touch-carousel__nav:active{transform:translateY(-50%) scale(1.02)}.touch-carousel__nav--prev{left:-24px}@media(max-width:768px){.touch-carousel__nav--prev{left:4px}}.touch-carousel__nav--next{right:-24px}@media(max-width:768px){.touch-carousel__nav--next{right:4px}}.touch-carousel__nav svg{width:20px;height:20px;flex-shrink:0}@media(max-width:768px){.touch-carousel__nav{width:40px;height:40px}.touch-carousel__nav svg{width:18px;height:18px}}.touch-carousel__pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:1.25rem;padding:.5rem}.touch-carousel__dot{background:transparent;padding:0;margin:0;width:10px;height:10px;border-radius:50%;background:#8b9de14d;border:none;cursor:pointer;transition:all .2s ease}.touch-carousel__dot:hover{background:#8b9de180;transform:scale(1.2)}.touch-carousel__dot--active{background:#8b9de1;width:28px;box-shadow:0 2px 8px #8b9de166}.wind-compass{display:flex;flex-direction:column;align-items:center;gap:.875rem;padding:0;background:transparent;border:none;box-shadow:none;min-width:auto;position:relative;transition:all .3s ease}.wind-compass:hover{transform:scale(1.02)}@media(max-width:768px){.wind-compass{min-width:auto;padding:0;gap:.5rem}}.wind-compass__svg{width:100%;max-width:180px;height:auto;color:#bfd4f2;filter:drop-shadow(0 2px 8px rgba(139,157,225,.15))}@media(max-width:768px){.wind-compass__svg{max-width:160px}}.wind-compass__cardinal{fill:#bfd4f2;font-weight:600}.wind-compass__cardinal--north{fill:#ef4444;font-weight:800;filter:drop-shadow(0 1px 2px rgba(239,68,68,.5))}.wind-compass__degree-marks{stroke:#8aa5c5}.wind-compass__arrow{transform-origin:100px 100px;transform:rotate(var(--wind-direction));animation:wind-compass-oscillation 2s ease-in-out infinite;filter:drop-shadow(0 3px 8px rgba(239,68,68,.4));will-change:transform}.wind-compass__speed{display:flex;flex-direction:column;align-items:center;gap:2px;padding-top:.25rem;width:100%}.wind-compass__speed-value{font-size:1.75rem;font-weight:800;color:#5fa8ff;line-height:1;font-variant-numeric:tabular-nums}@media(max-width:768px){.wind-compass__speed-value{font-size:1.5rem}}.wind-compass__speed-unit{font-size:.7rem;font-weight:700;color:#bfd4f2;text-transform:uppercase;letter-spacing:.5px;opacity:.75}@keyframes wind-compass-oscillation{0%,to{transform:rotate(calc(var(--wind-direction) - 3deg))}50%{transform:rotate(calc(var(--wind-direction) + 3deg))}}@media(prefers-reduced-motion:reduce){.wind-compass__arrow{animation:none}}.sun-timeline{display:flex;flex-direction:column;height:100%;width:100%;flex:1 1 auto;min-width:0}.sun-timeline__container{display:flex;align-items:center;gap:.5rem;flex:1}@media(max-width:768px){.sun-timeline__container{gap:.25rem}}.sun-timeline__time-point{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:50px}@media(max-width:768px){.sun-timeline__time-point{min-width:42px}}.sun-timeline__time-label{font-size:.65rem;font-weight:600;color:var(--weather-text-muted);text-transform:uppercase;letter-spacing:.3px}@media(max-width:768px){.sun-timeline__time-label{font-size:.55rem}}.sun-timeline__time-value{font-size:.75rem;font-weight:700;color:var(--weather-text-primary)}@media(max-width:768px){.sun-timeline__time-value{font-size:.7rem}}.sun-timeline__progress{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:60px;padding:0 .25rem}.sun-timeline__bar{position:relative;width:100%;height:16px;border-radius:8px;overflow:hidden;border:1px solid rgba(148,163,184,.3)}[data-theme=dark] .sun-timeline__bar{border-color:#47556980}@media(max-width:768px){.sun-timeline__bar{height:14px;border-radius:7px}}.sun-timeline__gradient{position:absolute;left:0;top:0;width:100%;height:100%;background:linear-gradient(to right,#fde047,#fbbf24,#fcd34d,#fb923c 60%,#f97316 75%,#ea580c,#4c1d95 95%,#1e3a8a 97%,#0f172a)}.sun-timeline__dark-cover{position:absolute;left:0;top:0;width:100%;height:100%;background:#0f172a;transition:clip-path .6s ease}.sun-timeline__status{font-size:.65rem;font-weight:600;color:var(--weather-text-muted);text-align:center;opacity:.8;letter-spacing:.2px}@media(max-width:768px){.sun-timeline__status{font-size:.6rem}}.sun-timeline__indicator{position:absolute;top:50%;transform:translate(-50%,-50%);z-index:10;pointer-events:none;transition:left .6s ease}.sun-timeline__dot{width:20px;height:20px;background:radial-gradient(circle,#fde047,#fbbf24 70%);border:3px solid white;border-radius:50%;box-shadow:0 0 0 2px #fbbf244d,0 3px 12px #fbbf24cc,0 0 20px #fde04780;animation:sun-timeline-pulse 2s ease-in-out infinite}[data-theme=dark] .sun-timeline__dot{border-color:#0f172af2;box-shadow:0 0 0 2px #fbbf2440,0 3px 12px #fbbf24b3,0 0 20px #fde04766}@media(max-width:768px){.sun-timeline__dot{width:16px;height:16px;border-width:2px}}@keyframes sun-timeline-pulse{0%,to{transform:scale(1);box-shadow:0 0 0 2px #fbbf244d,0 3px 12px #fbbf24cc,0 0 20px #fde04780}50%{transform:scale(1.15);box-shadow:0 0 0 4px #fbbf2466,0 5px 20px #fbbf24,0 0 30px #fde047b3}}.weather-chart{width:100%;min-height:500px;background:linear-gradient(135deg,#fffffffa,#f8fafffa);border-radius:20px;padding:1.5rem;box-shadow:0 4px 20px #667eea1f;border:2px solid rgba(139,157,225,.2);transition:all .3s ease}[data-theme=dark] .weather-chart{background:linear-gradient(135deg,#1e293bf2,#334155f2);box-shadow:0 4px 20px #0000004d;border-color:#47556966}.weather-chart:hover{box-shadow:0 8px 32px #667eea2e;border-color:#667eea4d}[data-theme=dark] .weather-chart:hover{box-shadow:0 8px 32px #0006;border-color:#47556999}@media(max-width:768px){.weather-chart{padding:1.25rem;min-height:400px}}.weather-chart__title{font-size:1rem;font-weight:700;background:linear-gradient(135deg,#667eeae6,#764ba2cc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 1.5rem;text-align:center}[data-theme=dark] .weather-chart__title{background:linear-gradient(135deg,#8b9de1e6,#a78bfae6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(max-width:768px){.weather-chart__title{font-size:.9rem;margin-bottom:1.25rem}}.weather-chart__container{position:relative;width:100%;height:400px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}@media(max-width:768px){.weather-chart__container{height:300px}}@media(max-width:480px){.weather-chart__container canvas{min-width:450px}}.weather-chart__container canvas{max-width:100%}@media(prefers-reduced-motion:reduce){.weather-chart *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.hourly-chart{width:100%;animation:hourly-chart-fade-in .6s ease-out .3s both}.hourly-chart__title{font-size:.9rem;font-weight:700;color:#e8f2ff;margin-bottom:1.25rem;text-align:center}[data-theme=dark] .hourly-chart__title{color:#e2e8f0f2}@media(max-width:768px){.hourly-chart__title{font-size:.8rem;margin-bottom:.875rem}}.hourly-chart__container{position:relative;width:100%;height:350px;background:linear-gradient(135deg,#ffffffe6,#f8faffeb);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem;border-radius:20px;box-shadow:0 4px 16px #8b9de11f;border:2px solid rgba(139,157,225,.15);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}[data-theme=dark] .hourly-chart__container{background:linear-gradient(135deg,#1e293be6,#334155e0);box-shadow:0 4px 16px #0000004d;border-color:#47556966}@media(max-width:768px){.hourly-chart__container{height:300px;padding:1.25rem}}@media(max-width:480px){.hourly-chart__container{height:280px;padding:.875rem}.hourly-chart__container canvas{min-width:500px}}@keyframes hourly-chart-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.forecast-insights{border:1px solid var(--home-border-strong);border-radius:16px;background:linear-gradient(135deg,#2f6bd80d,#2ab3ff08),var(--home-surface);box-shadow:var(--home-shadow-soft);padding:1rem;display:flex;flex-direction:column;gap:.8rem;color:var(--home-text-strong)}@media(max-width:768px){.forecast-insights{padding:.9rem;gap:.7rem}}.forecast-insights__header{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;justify-content:space-between;border-bottom:1px solid var(--home-border-soft);padding-bottom:.6rem}.forecast-insights__title{flex:1;min-width:220px}.forecast-insights__title h3{margin:0;font-size:.9rem;font-weight:700;letter-spacing:-.3px}.forecast-insights__title p{margin:.1rem 0 0;color:var(--home-text-muted);font-size:.75rem}.forecast-insights__eyebrow{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .6rem;border-radius:12px;background:var(--home-control-bg);color:var(--home-text-muted);border:1px solid var(--home-border-soft);font-size:.7rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.forecast-insights__eyebrow-dot{width:8px;height:8px;border-radius:50%;background:var(--home-accent);box-shadow:0 0 0 4px var(--home-control-hover)}.forecast-insights__pill{padding:.3rem .6rem;border-radius:12px;background:linear-gradient(120deg,#34d39929,#0ea5e91f);color:var(--home-text-strong);border:1px solid var(--home-border-soft);font-weight:600;font-size:.7rem;white-space:nowrap}.forecast-insights__carousel-wrapper{display:flex;align-items:center;gap:.35rem;width:100%;min-width:0}@media(max-width:768px){.forecast-insights__carousel-wrapper{gap:.3rem}}.forecast-insights__nav{background:transparent;border:none;cursor:pointer;padding:0;margin:0;width:36px;height:36px;border-radius:50%;border:1px solid var(--home-border-soft);background:var(--home-control-bg);color:var(--home-text-muted);display:flex;align-items:center;justify-content:center;box-shadow:var(--home-shadow-soft);transition:.2s ease;flex-shrink:0}@media(max-width:768px){.forecast-insights__nav{width:34px;height:34px}}.forecast-insights__nav:hover:not(:disabled){color:var(--home-text-strong);background:linear-gradient(135deg,#2f6bd824,#34d39924);border-color:var(--home-border-strong);transform:translateY(-1px)}.forecast-insights__nav:active:not(:disabled){transform:translateY(0)}.forecast-insights__nav:disabled{opacity:.45;cursor:not-allowed}.forecast-insights__nav svg{width:14px;height:14px}.forecast-insights__carousel{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(260px,1fr);grid-auto-rows:1fr;gap:.75rem;overflow-x:auto;padding-bottom:.2rem;scrollbar-width:thin;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;align-items:stretch;flex:1;min-width:0;scroll-behavior:smooth}@media(max-width:768px){.forecast-insights__carousel{grid-auto-columns:82%;gap:.65rem}}.forecast-insights__card{background:var(--home-surface-soft);border:1px solid var(--home-border-soft);border-radius:12px;padding:.85rem .9rem;box-shadow:var(--home-shadow-soft);display:grid;grid-template-rows:auto auto minmax(180px,1fr) auto;gap:.6rem;min-height:280px;height:100%;scroll-snap-align:start}@media(max-width:768px){.forecast-insights__card{min-height:260px;grid-template-rows:auto auto minmax(170px,1fr) auto}}.forecast-insights__card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;min-height:56px}@media(max-width:768px){.forecast-insights__card-header{min-height:52px}}.forecast-insights__card-kicker{font-size:.7rem;letter-spacing:.5px;text-transform:uppercase;color:var(--home-text-muted);font-weight:600}.forecast-insights__card-title{font-size:.85rem;font-weight:700;margin-top:.1rem}.forecast-insights__card-metric{background:var(--home-control-bg);color:var(--home-text-strong);padding:.35rem .6rem;border-radius:12px;font-weight:600;border:1px solid var(--home-border-soft)}.forecast-insights__card-description{margin:0;color:var(--home-text-muted);font-size:.75rem;line-height:1.45;min-height:44px}.forecast-insights__chart{position:relative;width:100%;height:180px;min-height:180px}.forecast-insights__chart canvas{width:100%;height:100%;max-width:100%;max-height:100%}@media(max-width:768px){.forecast-insights__chart{height:170px;min-height:170px}}.forecast-insights__legend{display:flex;flex-wrap:wrap;justify-content:center;gap:.35rem .75rem;margin-top:0;align-self:flex-end}.forecast-insights__legend-item{display:flex;align-items:center;gap:.4rem;color:var(--home-text-strong);font-size:.75rem;justify-content:center}.forecast-insights__legend-dot{width:12px;height:12px;border-radius:8px;box-shadow:inset 0 0 0 1px var(--home-border-soft);flex-shrink:0}.forecast-insights__legend-text{color:var(--home-text-muted)}.forecast-insights__placeholder{display:grid;gap:.35rem}.forecast-insights__skeleton-bar{height:12px;background:linear-gradient(90deg,#94a3b840,#94a3b826,#94a3b840);border-radius:12px;animation:forecast-insights-pulse 1.5s ease-in-out infinite}.forecast-insights__skeleton-bar--short{width:65%}.forecast-insights__empty{padding:.8rem;border-radius:12px;border:1px dashed var(--home-border-soft);color:var(--home-text-muted);font-size:.75rem}@keyframes forecast-insights-pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.chart-modal__overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:2000;padding:0}@media(min-width:769px){.chart-modal__overlay{display:none!important}}.chart-modal__container{background:linear-gradient(135deg,#fffffffa,#f8fafffa);width:100vw;height:100vh;display:flex;flex-direction:column;overflow:hidden}@media(orientation:portrait){.chart-modal__container{transform:rotate(90deg);transform-origin:center center;width:calc(100vh - 40px);height:calc(100vw - 40px);position:fixed;left:50%;top:50%;margin-left:calc(-50vh + 20px);margin-top:calc(-50vw + 20px)}}.chart-modal__header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .875rem;border-bottom:2px solid rgba(139,157,225,.2);background:#ffffffe6;backdrop-filter:blur(10px);flex-shrink:0;min-height:56px;gap:.5rem}@media(orientation:landscape){.chart-modal__header{padding:.875rem 1.25rem;min-height:64px}}.chart-modal__title{font-size:14px;font-weight:700;color:#667eea;margin:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(orientation:landscape){.chart-modal__title{font-size:.9rem}}.chart-modal__close{background:#8b9de126;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;z-index:10}.chart-modal__close span{font-size:22px;color:#667eea;font-weight:700;line-height:1}.chart-modal__close:active{transform:scale(.95);background:#8b9de140}.chart-modal__body{flex:1;overflow-x:auto;overflow-y:hidden;padding:.25rem;-webkit-overflow-scrolling:touch;min-height:0}.chart-modal__body .weather-chart,.chart-modal__body .hourly-chart{height:100%;width:100%;min-height:0}.chart-modal__body .weather-chart__title,.chart-modal__body .hourly-chart__title{display:none}.chart-modal__body .weather-chart__container,.chart-modal__body .hourly-chart__container{height:100%;width:100%;min-width:unset;margin:0;padding:.25rem;overflow-x:auto;overflow-y:hidden}.chart-modal__body .weather-chart__container canvas,.chart-modal__body .hourly-chart__container canvas{width:100%!important;height:100%!important}@media(orientation:landscape){.chart-modal__body{padding:.5rem}.chart-modal__body .weather-chart__container,.chart-modal__body .hourly-chart__container{padding:.25rem}}@media(orientation:portrait){.chart-modal__body .weather-chart__container,.chart-modal__body .hourly-chart__container{min-height:0}.chart-modal__body .weather-chart__container canvas,.chart-modal__body .hourly-chart__container canvas{max-height:calc(100vh - 60px)}.chart-modal__body .weather-chart{min-height:0;height:100%}}.chart-modal-enter-active,.chart-modal-leave-active{transition:opacity .3s ease}.chart-modal-enter-from,.chart-modal-leave-to{opacity:0}.chart-modal-enter-active .chart-modal__container,.chart-modal-leave-active .chart-modal__container{transition:transform .3s ease}.chart-modal-enter-from .chart-modal__container,.chart-modal-leave-to .chart-modal__container{transform:translateY(100%)}[data-theme=dark] .chart-modal__container{background:linear-gradient(135deg,#1e293bfa,#334155fa)}[data-theme=dark] .chart-modal__header{background:#1e293bf2;border-bottom-color:#47556966}[data-theme=dark] .chart-modal__title{color:var(--weather-primary)}[data-theme=dark] .chart-modal__close{background:#4755694d}[data-theme=dark] .chart-modal__close span{color:var(--weather-primary)}[data-theme=dark] .chart-modal__close:hover{background:#47556980}.ad-wrapper{width:100%;padding:.85rem 1rem 1rem;border-radius:20px;border:1px solid var(--home-border-soft);background:linear-gradient(135deg,#667eea0a,#764ba20a);box-shadow:var(--home-shadow-soft)}.ad-wrapper.ad-wrapper--sidebar{margin:1rem 0 0}.ad-wrapper.ad-wrapper--loading{opacity:.88}.ad-wrapper__label{margin:0 0 .5rem;font-size:.75rem;font-weight:600;letter-spacing:.6px;text-transform:uppercase;text-align:center;color:var(--home-text-muted)}.ad-wrapper__frame{display:flex;align-items:center;justify-content:center;width:100%;position:relative;overflow:hidden;min-height:var(--ad-height);height:var(--ad-height)}.ad-placeholder{width:100%;padding:.75rem;border-radius:12px;background:#fff6;border:1px dashed var(--home-border-soft);color:var(--home-text-muted);font-size:.75rem;text-align:center}.ad-placeholder code{font-size:.75rem}.ad-wrapper--inline{display:block;margin:0}@media(max-width:767px){.ad-wrapper--inline{margin:0}}.city-detail-page .ad-wrapper{margin:0}.ad-wrapper .adsbygoogle{display:block!important;width:var(--ad-width, 100%)!important;max-width:100%!important;height:var(--ad-height, auto)!important;max-height:var(--ad-height, none)!important}.app-shell{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(180deg,var(--bg-gradient-start),var(--bg-gradient-end))}.app-main{flex:1 0 auto}.content-page{--content-gap: clamp(1.35rem, 1rem + 1.4vw, 2.25rem);width:min(1100px,100% - 2rem);margin:0 auto;padding:4rem 1.5rem 3rem;display:flex;flex-direction:column;gap:var(--content-gap);color:var(--home-text-strong);line-height:1.65}@media(max-width:768px){.content-page{padding:3rem 1rem 2.5rem}}.content-page a{color:var(--home-accent);font-weight:600;text-decoration:none}.content-page a:hover{text-decoration:underline}.content-hero{display:flex;flex-direction:column;gap:.75rem;margin:0}.content-hero h1{font-size:clamp(2rem,3vw,2.6rem);letter-spacing:-.5px}.page-badge{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.2rem .65rem;min-height:1.75rem;border-radius:999px;font-size:.85rem;background:#667eea1f;color:var(--home-accent);font-weight:700;letter-spacing:.4px;line-height:1}.hero-lead{max-width:820px;color:var(--home-text-muted);font-size:1.15rem}.page-meta{display:flex;flex-wrap:wrap;gap:.75rem;color:var(--home-text-muted);font-size:.95rem}.content-section{margin:0}.content-section h2{font-size:1.2rem;margin-bottom:.75rem;letter-spacing:-.2px;color:var(--home-text-strong)}.content-section p{color:var(--home-text-muted)}.content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.content-grid.two{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.content-grid.three{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.content-card{background:var(--home-surface, rgba(255, 255, 255, .92));border:1px solid var(--home-border-soft);border-radius:20px;padding:1.25rem 1.4rem;box-shadow:0 20px 50px #0000000f;transition:transform .3s ease,box-shadow .3s ease}.content-card h3{margin-bottom:.35rem;font-size:1.05rem;color:var(--home-text-strong)}.content-card p,.content-card li{color:var(--home-text-muted)}.content-card:hover{transform:translateY(-3px);box-shadow:0 28px 60px #00000014}[data-theme=dark] .content-card{background:var(--home-surface, rgba(20, 32, 55, .7));border-color:var(--home-border-soft)}.highlight-list{padding-left:1rem;display:grid;gap:.6rem;list-style:disc;color:var(--home-text-muted)}.link-button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;margin-top:.75rem;padding:.6rem 1rem;border-radius:16px;background:linear-gradient(135deg,#2f6bd8,#48c7ff);color:#fff;font-weight:700;text-decoration:none;box-shadow:0 14px 35px #667eea4d;transition:transform .2s ease,box-shadow .2s ease}.link-button:hover{transform:translateY(-2px);box-shadow:0 18px 40px #764ba259}.site-footer{padding:3rem 1.5rem 2.5rem;background:linear-gradient(135deg,#2f6bd8,#48c7ff);color:#fff;margin-top:2rem;position:relative;overflow:hidden}.site-footer:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.12),transparent 45%),radial-gradient(circle at 80% 0%,rgba(255,255,255,.1),transparent 40%);pointer-events:none}.site-footer .footer-content{position:relative;width:min(1100px,100%);margin:0 auto 1.5rem;display:grid;grid-template-columns:1.3fr 1fr;gap:1.5rem}@media(max-width:768px){.site-footer .footer-content{grid-template-columns:1fr}}.site-footer .footer-brand h2{margin:.25rem 0;font-size:1.4rem;letter-spacing:-.3px}.site-footer .footer-kicker{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .7rem;min-height:1.8rem;border-radius:999px;background:#ffffff29;font-weight:700;letter-spacing:.4px;line-height:1}.site-footer .footer-description{margin:.5rem 0 .75rem;color:#ffffffd9;line-height:1.6}.site-footer .footer-contact{display:flex;gap:.5rem;flex-wrap:wrap;font-weight:700}.site-footer .footer-contact a{color:#fff;text-decoration:underline}.site-footer .footer-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.site-footer .footer-column h3{margin-bottom:.5rem;letter-spacing:.2px}.site-footer .footer-column a{display:block;color:#ffffffe0;text-decoration:none;padding:.2rem 0;transition:opacity .2s ease,transform .2s ease}.site-footer .footer-column a:hover{opacity:1;transform:translate(4px)}.site-footer .footer-meta{position:relative;width:min(1100px,100%);margin:0 auto;display:flex;flex-wrap:wrap;gap:.5rem;font-size:.95rem;color:#ffffffd9}.site-footer .meta-separator{opacity:.7}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(/assets/layers.BWBAp2CZ.png);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(/assets/layers-2x.Bpkbi35X.png);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(/assets/marker-icon.hN30_KVU.png)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}[data-v-1b7e5ae4]:root{--color-primary-start: #2f6bd8;--color-primary-end: #48c7ff;--weather-primary: #2f65e0;--weather-secondary: #3fa0f8;--weather-accent: #2bb8f2;--weather-text-primary: #233552;--weather-text-secondary: #3c4c68;--weather-text-muted: #5b6b88;--weather-surface: rgba(255, 255, 255, .94);--weather-surface-blur: rgba(255, 255, 255, .86);--weather-surface-card: rgba(253, 254, 255, .97);--weather-border: rgba(47, 101, 224, .18);--weather-border-light: rgba(47, 101, 224, .12);--weather-shadow: rgba(15, 23, 42, .1);--weather-shadow-md: rgba(15, 23, 42, .16);--weather-shadow-lg: rgba(15, 23, 42, .22);--header-bg: rgba(146, 180, 230, .86);--header-bg-scrolled: rgba(72, 126, 204, .9);--header-border: rgba(84, 123, 212, .2);--header-text: #f7fbff;--header-control-bg: rgba(255, 255, 255, .16);--header-control-hover-bg: rgba(255, 255, 255, .22);--header-control-border: rgba(255, 255, 255, .28);--header-control-hover-border: rgba(255, 255, 255, .4);--header-control-color: #f7fbff;--bg-gradient-start: rgba(227, 237, 255, .6);--bg-gradient-mid: rgba(214, 240, 255, .48);--bg-gradient-end: rgba(255, 255, 255, .98);--bg-base: #f7f9fd;--home-shell-bg: radial-gradient(circle at 20% 18%, rgba(47, 107, 216, .18), transparent 26%), radial-gradient(circle at 78% 10%, rgba(42, 179, 255, .22), transparent 24%), linear-gradient(135deg, #f5f8ff 0%, #e9f0ff 55%, #fdfbff 100%);--home-ambient-1: #f3f7ff;--home-ambient-2: #e6edff;--home-surface: rgba(255, 255, 255, .94);--home-surface-strong: rgba(255, 255, 255, .98);--home-surface-soft: rgba(255, 255, 255, .88);--home-surface-ghost: rgba(255, 255, 255, .75);--home-border-soft: rgba(53, 86, 163, .2);--home-border-strong: rgba(53, 86, 163, .35);--home-border-glow: rgba(66, 134, 255, .32);--home-accent: #2563eb;--home-accent-2: #0ea5e9;--home-glow: rgba(37, 99, 235, .18);--home-gridline: rgba(47, 107, 216, .12);--home-text-strong: #516481;--home-text-muted: #64748b;--home-control-bg: rgba(255, 255, 255, .92);--home-control-strong: rgba(248, 250, 252, .98);--home-control-hover: rgba(59, 130, 246, .12);--home-control-border: rgba(71, 100, 163, .28);--home-shadow-soft: 0 2px 8px rgba(71, 100, 163, .12), 0 1px 3px rgba(71, 100, 163, .08);--home-shadow-strong: 0 4px 16px rgba(53, 86, 163, .18), 0 2px 6px rgba(53, 86, 163, .12);--bg-primary: #f7f9fd;--bg-secondary: #eef3ff;--bg-tertiary: #e2e8f5;--bg-header: var(--header-bg);--bg-card: rgba(255, 255, 255, .96);--bg-card-hover: rgba(255, 255, 255, .98);--text-primary: #233552;--text-secondary: #3c4c68;--text-muted: #5b6b88;--text-dark: #233552;--border-light: rgba(53, 86, 163, .16);--border-medium: rgba(53, 86, 163, .24);--border-dark: rgba(53, 86, 163, .32);--overlay-light: rgba(255, 255, 255, .15);--overlay-medium: rgba(47, 107, 216, .08);--overlay-dark: rgba(0, 0, 0, .25);--floating-btn-start: #6aa1fa;--floating-btn-end: #3b75f1;--floating-btn-hover-start: #5f9afa;--floating-btn-hover-end: #2c6af1;--floating-btn-shadow: 0 6px 24px rgba(59, 130, 246, .45), 0 2px 8px rgba(37, 99, 235, .3);--floating-btn-shadow-strong: 0 10px 32px rgba(59, 130, 246, .55), 0 4px 12px rgba(68, 123, 243, .4);--weather-temp-cold: #3b82f6;--weather-temp-cool: #06b6d4;--weather-temp-pleasant: #22c55e;--weather-temp-warm: #eab308;--weather-temp-hot: #f97316;--weather-temp-extreme: #ef4444;--weather-rain-none: #e2e8f0;--weather-rain-light: #bae6fd;--weather-rain-moderate: #7dd3fc;--weather-rain-heavy: #38bdf8;--weather-rain-intense: #0284c7;--weather-uv-low: #22c55e;--weather-uv-moderate: #eab308;--weather-uv-high: #f97316;--weather-uv-very-high: #ef4444;--weather-uv-extreme: #a855f7;--alpha-10: .1;--alpha-15: .15;--alpha-20: .2;--alpha-30: .3;--alpha-50: .5;--alpha-70: .7;--alpha-90: .9;--alpha-95: .95;--info-panel-surface: linear-gradient(180deg, #fdfefe 0%, #e7f0ff 100%);--info-panel-soft: rgba(245, 249, 255, .94);--info-panel-border: rgba(59, 130, 246, .18);--info-panel-shadow: 0 22px 72px rgba(53, 86, 163, .14);--info-panel-highlight: rgba(59, 130, 246, .14);--panel-header-gradient: linear-gradient(135deg, #f9fbff 0%, #e4edff 45%, #c9ddff 100%);--panel-header-text: #0f3f8c}[data-theme=dark][data-v-1b7e5ae4]{--color-primary-start: #58b1ff;--color-primary-end: #8bd3ff;--weather-primary: #58b1ff;--weather-secondary: #7fc0ff;--weather-accent: #8bd3ff;--weather-text-primary: #e8f2ff;--weather-text-secondary: #c8dbf5;--weather-text-muted: #9fb5d6;--weather-surface: rgba(12, 22, 38, .95);--weather-surface-blur: rgba(12, 22, 38, .88);--weather-surface-card: rgba(12, 22, 38, .92);--weather-border: rgba(88, 177, 255, .3);--weather-border-light: rgba(88, 177, 255, .16);--weather-shadow: rgba(0, 0, 0, .45);--weather-shadow-md: rgba(0, 0, 0, .5);--weather-shadow-lg: rgba(0, 0, 0, .6);--header-bg: rgba(12, 22, 38, .88);--header-bg-scrolled: rgba(14, 30, 52, .94);--header-border: rgba(88, 177, 255, .26);--header-text: #e8f2ff;--header-control-bg: rgba(255, 255, 255, .08);--header-control-hover-bg: rgba(255, 255, 255, .12);--header-control-border: rgba(88, 177, 255, .24);--header-control-hover-border: rgba(139, 211, 255, .32);--header-control-color: #e8f2ff;--bg-gradient-start: rgba(6, 17, 33, .4);--bg-gradient-mid: rgba(8, 22, 40, .35);--bg-gradient-end: rgba(4, 10, 20, .6);--bg-base: #050d1a;--home-shell-bg: radial-gradient(circle at 18% 18%, rgba(88, 177, 255, .12), transparent 25%), radial-gradient(circle at 80% 12%, rgba(84, 152, 255, .18), transparent 28%), linear-gradient(135deg, #050d1a 0%, #0a1627 52%, #040a15 100%);--home-ambient-1: #050d1a;--home-ambient-2: #0a1627;--home-surface: rgba(10, 18, 32, .88);--home-surface-strong: rgba(12, 22, 40, .94);--home-surface-soft: rgba(12, 24, 41, .78);--home-surface-ghost: rgba(255, 255, 255, .05);--home-border-soft: rgba(88, 177, 255, .18);--home-border-strong: rgba(88, 177, 255, .32);--home-border-glow: rgba(88, 177, 255, .3);--home-accent: #7fd1ff;--home-accent-2: #58b1ff;--home-glow: rgba(88, 177, 255, .2);--home-gridline: rgba(88, 177, 255, .06);--home-text-strong: #e8f2ff;--home-text-muted: #9db4d6;--home-control-bg: rgba(255, 255, 255, .06);--home-control-strong: rgba(255, 255, 255, .1);--home-control-hover: rgba(88, 177, 255, .12);--home-control-border: rgba(88, 177, 255, .26);--home-shadow-soft: 0 18px 46px rgba(0, 0, 0, .45);--home-shadow-strong: 0 24px 66px rgba(0, 0, 0, .65);--floating-btn-start: #22d3ee;--floating-btn-end: #0ea5e9;--floating-btn-hover-start: #22d3ee;--floating-btn-hover-end: #0ea5e9;--floating-btn-shadow: 0 6px 24px rgba(56, 189, 248, .45), 0 2px 8px rgba(14, 165, 233, .3);--floating-btn-shadow-strong: 0 10px 32px rgba(56, 189, 248, .55), 0 4px 12px rgba(14, 165, 233, .4);--text-primary: #e8f2ff;--text-secondary: #c8dbf5;--text-muted: #9db4d6;--text-dark: #e5e7eb;--bg-primary: #050d1a;--bg-secondary: #0a1627;--bg-tertiary: #0d1b30;--bg-header: var(--header-bg);--bg-card: rgba(12, 22, 38, .94);--bg-card-hover: rgba(12, 22, 38, .98);--info-panel-surface: linear-gradient(180deg, rgba(10, 18, 32, .98) 0%, rgba(8, 24, 46, .94) 100%);--info-panel-soft: rgba(12, 24, 41, .86);--info-panel-border: rgba(88, 177, 255, .28);--info-panel-shadow: 0 28px 90px rgba(0, 0, 0, .68);--info-panel-highlight: rgba(88, 177, 255, .14);--panel-header-gradient: linear-gradient(135deg, #0b1f3a 0%, #0f305a 55%, #164a78 100%);--panel-header-text: #e8f2ff}[data-v-1b7e5ae4]{transition:background-color .3s ease,border-color .3s ease,color .3s ease,box-shadow .3s ease}:where(.leaflet-container[data-v-1b7e5ae4],.leaflet-pane[data-v-1b7e5ae4],img[data-v-1b7e5ae4],svg[data-v-1b7e5ae4],path[data-v-1b7e5ae4],circle[data-v-1b7e5ae4],rect[data-v-1b7e5ae4]){transition:none!important}.city-detail-page .weather-alerts[data-v-1b7e5ae4]{background:linear-gradient(135deg,#dbeafe99,#bfdbfe80);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:1.5rem;border-left:4px solid #5fa8ff;border-radius:20px;box-shadow:0 4px 16px #0000002e;border:2px solid rgba(88,177,255,.2);border-left-width:4px}@media(max-width:768px){.city-detail-page .weather-alerts[data-v-1b7e5ae4]{padding:1.25rem}}.city-detail-page .weather-alerts__header[data-v-1b7e5ae4]{display:flex;align-items:center;gap:.875rem;margin-bottom:1.25rem;color:#5fa8ff}.city-detail-page .weather-alerts__header svg[data-v-1b7e5ae4]{flex-shrink:0;width:24px;height:24px;filter:drop-shadow(0 2px 4px rgba(59,130,246,.2))}@media(max-width:768px){.city-detail-page .weather-alerts__header svg[data-v-1b7e5ae4]{width:20px;height:20px}}.city-detail-page .weather-alerts__header h3[data-v-1b7e5ae4]{margin:0;font-size:1rem;font-weight:800;color:#e8f2ff;letter-spacing:-.3px}@media(max-width:768px){.city-detail-page .weather-alerts__header h3[data-v-1b7e5ae4]{font-size:.9rem}}.city-detail-page .weather-alerts__list[data-v-1b7e5ae4]{display:flex;flex-direction:column;gap:.875rem}.city-detail-page .weather-alerts__item[data-v-1b7e5ae4]{display:flex;align-items:center;gap:1.25rem;padding:1.25rem;border-radius:16px;background:#ffffffe6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-left:4px solid;transition:all .3s ease;cursor:pointer;user-select:none;box-shadow:0 2px 8px #3b82f614}.city-detail-page .weather-alerts__item[data-v-1b7e5ae4]:hover{transform:translate(4px);box-shadow:0 4px 16px #3b82f626;background:#fff}.city-detail-page .weather-alerts__item[data-v-1b7e5ae4]:active{transform:translate(2px) scale(.99)}.city-detail-page .weather-alerts__item[data-v-1b7e5ae4]:focus-visible{outline:3px solid rgba(59,130,246,.5);outline-offset:2px}@media(max-width:768px){.city-detail-page .weather-alerts__item[data-v-1b7e5ae4]{padding:.875rem;gap:.875rem}}.city-detail-page .weather-alerts__icon[data-v-1b7e5ae4]{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.city-detail-page .weather-alerts__icon svg[data-v-1b7e5ae4]{width:28px;height:28px}@media(max-width:768px){.city-detail-page .weather-alerts__icon[data-v-1b7e5ae4]{width:36px;height:36px}.city-detail-page .weather-alerts__icon svg[data-v-1b7e5ae4]{width:24px;height:24px}}.city-detail-page .weather-alerts__content[data-v-1b7e5ae4]{flex:1;min-width:0}.city-detail-page .weather-alerts__description[data-v-1b7e5ae4]{font-size:.8rem;font-weight:700;margin-bottom:.5rem;line-height:1.5;color:#e8f2ff}.city-detail-page .weather-alerts__description .weather-alerts__emoji[data-v-1b7e5ae4]{margin-right:.25rem;font-size:1.2em}@media(max-width:768px){.city-detail-page .weather-alerts__description[data-v-1b7e5ae4]{font-size:.75rem}}.city-detail-page .weather-alerts__meta[data-v-1b7e5ae4]{display:flex;align-items:center;gap:.875rem;flex-wrap:wrap;font-size:.75rem;color:#bfd4f2}@media(max-width:768px){.city-detail-page .weather-alerts__meta[data-v-1b7e5ae4]{font-size:.7rem;gap:.5rem}}.city-detail-page .weather-alerts__code[data-v-1b7e5ae4]{font-weight:800;text-transform:uppercase;letter-spacing:.8px;padding:4px 10px;background:#3b82f61a;border-radius:12px;color:#5fa8ff}.city-detail-page .weather-alerts__time[data-v-1b7e5ae4]{color:#8aa5c5;font-weight:600;font-variant-numeric:tabular-nums}.city-detail-page .weather-alerts__arrow[data-v-1b7e5ae4]{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:#8aa5c5;opacity:.5;transition:all .3s ease}.city-detail-page .weather-alerts__arrow svg[data-v-1b7e5ae4]{width:20px;height:20px}.weather-alerts__item:hover .city-detail-page .weather-alerts__arrow[data-v-1b7e5ae4]{opacity:1;transform:translate(4px);color:#5fa8ff}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-danger[data-v-1b7e5ae4]{border-left-color:#dc2626!important}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-danger .weather-alerts__icon[data-v-1b7e5ae4]{color:#dc2626}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-danger .weather-alerts__code[data-v-1b7e5ae4]{background:#dc26261a;color:#dc2626}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-alert[data-v-1b7e5ae4]{border-left-color:#ea580c!important}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-alert .weather-alerts__icon[data-v-1b7e5ae4]{color:#ea580c}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-alert .weather-alerts__code[data-v-1b7e5ae4]{background:#ea580c1a;color:#ea580c}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-warning[data-v-1b7e5ae4]{border-left-color:#d97706!important}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-warning .weather-alerts__icon[data-v-1b7e5ae4]{color:#d97706}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-warning .weather-alerts__code[data-v-1b7e5ae4]{background:#d977061a;color:#d97706}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-info[data-v-1b7e5ae4]{border-left-color:#0284c7!important}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-info .weather-alerts__icon[data-v-1b7e5ae4]{color:#0284c7}.city-detail-page .weather-alerts__list .weather-alerts__item--severity-info .weather-alerts__code[data-v-1b7e5ae4]{background:#0284c71a;color:#0284c7}[data-theme=dark] .city-detail-page .weather-alerts[data-v-1b7e5ae4]{background:linear-gradient(135deg,#1e3a8a40,#1e40af33)!important;border-left-color:var(--weather-primary)!important;border-color:var(--weather-border)!important;box-shadow:0 4px 16px var(--weather-shadow)!important}[data-theme=dark] .city-detail-page .weather-alerts__header h3[data-v-1b7e5ae4]{color:var(--weather-text-primary)!important}[data-theme=dark] .city-detail-page .weather-alerts__list .weather-alerts__item[data-v-1b7e5ae4]{background:#1e293be6!important;box-shadow:0 2px 8px #0000004d!important}[data-theme=dark] .city-detail-page .weather-alerts__list .weather-alerts__item[data-v-1b7e5ae4]:hover{background:#334155f2!important;box-shadow:0 4px 16px #0006!important}[data-theme=dark] .city-detail-page .weather-alerts__list .weather-alerts__item[data-v-1b7e5ae4]:focus-visible{outline-color:var(--weather-primary)!important}[data-theme=dark] .city-detail-page .weather-alerts__description[data-v-1b7e5ae4]{color:var(--weather-text-primary)!important}[data-theme=dark] .city-detail-page .weather-alerts__meta[data-v-1b7e5ae4]{color:var(--weather-text-secondary)!important}[data-theme=dark] .city-detail-page .weather-alerts__time[data-v-1b7e5ae4]{color:var(--weather-text-muted)!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-danger[data-v-1b7e5ae4]{border-left-color:#f87171!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-danger .weather-alerts__icon[data-v-1b7e5ae4]{color:#f87171!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-danger .weather-alerts__code[data-v-1b7e5ae4]{background:#f8717126!important;color:#fca5a5!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-alert[data-v-1b7e5ae4]{border-left-color:#fb923c!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-alert .weather-alerts__icon[data-v-1b7e5ae4]{color:#fb923c!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-alert .weather-alerts__code[data-v-1b7e5ae4]{background:#fb923c26!important;color:#fdba74!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-warning[data-v-1b7e5ae4]{border-left-color:#fbbf24!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-warning .weather-alerts__icon[data-v-1b7e5ae4]{color:#fbbf24!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-warning .weather-alerts__code[data-v-1b7e5ae4]{background:#fbbf2426!important;color:#fcd34d!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-info[data-v-1b7e5ae4]{border-left-color:#38bdf8!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-info .weather-alerts__icon[data-v-1b7e5ae4]{color:#38bdf8!important}[data-theme=dark] .city-detail-page .alerts-section .weather-alerts__list .weather-alerts__item--severity-info .weather-alerts__code[data-v-1b7e5ae4]{background:#38bdf826!important;color:#7dd3fc!important}.city-detail-page[data-v-1b7e5ae4]{min-height:100vh;min-height:100dvh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-mid) 35%,var(--bg-gradient-end) 70%,var(--bg-gradient-start) 100%);background-color:var(--bg-base);overflow-x:hidden;display:flex;flex-direction:column}.page-content[data-v-1b7e5ae4]{--section-gap: clamp(1.4rem, 1.1rem + 1.6vw, 2.75rem);max-width:1400px;margin:0 auto;padding:0 1.5rem 2rem;flex:1 0 auto;width:100%;display:flex;flex-direction:column;gap:var(--section-gap)}@media(max-width:768px){.page-content[data-v-1b7e5ae4]{padding:0 .875rem 2rem}}.current-weather-section[data-v-1b7e5ae4]{margin:0;animation:fadeIn-1b7e5ae4 .6s ease-out;padding:1.5rem;background:linear-gradient(135deg,#2f65e014,#2bb8f214,#3bd6ff14);border-radius:24px;backdrop-filter:blur(10px);border:1px solid var(--weather-border);box-shadow:0 4px 24px var(--weather-shadow)}@media(max-width:768px){.current-weather-section[data-v-1b7e5ae4]{padding:1.25rem}}.section-title[data-v-1b7e5ae4]{font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,#2f65e0f2,#2bb8f2e6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;position:relative;letter-spacing:-.3px}[data-theme=dark] .section-title[data-v-1b7e5ae4]{background:linear-gradient(135deg,#8b9de1f2,#a78bfae6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(max-width:768px){.section-title[data-v-1b7e5ae4]{font-size:1rem}}.section-header[data-v-1b7e5ae4]{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;gap:1.25rem;padding-bottom:.875rem;border-bottom:2px solid rgba(47,101,224,.12)}@media(max-width:768px){.section-header[data-v-1b7e5ae4]{flex-direction:column;align-items:flex-start;margin-bottom:1.5rem;gap:.875rem}}.forecast-date-badge[data-v-1b7e5ae4]{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--weather-text-secondary);background:var(--weather-surface);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:.5rem 1.25rem;border-radius:16px;border:2px solid var(--weather-border);font-weight:700;white-space:nowrap;box-shadow:0 2px 8px var(--weather-shadow);transition:all .3s ease}.forecast-date-badge[data-v-1b7e5ae4]:hover{border-color:var(--weather-border-light);box-shadow:0 4px 12px var(--weather-shadow-md)}.forecast-date-badge svg[data-v-1b7e5ae4]{width:16px;height:16px;opacity:.9;flex-shrink:0}@media(max-width:768px){.forecast-date-badge[data-v-1b7e5ae4]{font-size:.7rem;padding:.25rem .875rem;gap:.25rem;width:100%;justify-content:center}.forecast-date-badge svg[data-v-1b7e5ae4]{width:14px;height:14px}}.loading-container[data-v-1b7e5ae4],.error-container[data-v-1b7e5ae4]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.25rem;padding:2rem}.loading-container svg[data-v-1b7e5ae4],.error-container svg[data-v-1b7e5ae4]{color:var(--weather-text-muted)}.loading-container h2[data-v-1b7e5ae4],.error-container h2[data-v-1b7e5ae4]{font-size:1rem;color:var(--weather-text-primary);margin:0}.loading-container p[data-v-1b7e5ae4],.error-container p[data-v-1b7e5ae4]{color:var(--weather-text-muted);text-align:center;max-width:400px}.spinner[data-v-1b7e5ae4]{width:48px;height:48px;border:4px solid rgba(0,0,0,.1);border-left-color:#2f6bd8;border-radius:50%;animation:spin-1b7e5ae4 1s linear infinite}@keyframes spin-1b7e5ae4{to{transform:rotate(360deg)}}.retry-button[data-v-1b7e5ae4]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;padding:.875rem 1.5rem;background:#2f6bd8;color:#fff;border-radius:12px;font-weight:600;transition:.2s ease}.retry-button[data-v-1b7e5ae4]:hover{background:#48c7ff;transform:translateY(-2px);box-shadow:0 4px 16px #667eea80}.alerts-section[data-v-1b7e5ae4]{margin:0;animation:fadeIn-1b7e5ae4 .6s ease-out .3s both}.visualization-section[data-v-1b7e5ae4]{margin:0;animation:fadeIn-1b7e5ae4 .6s ease-out .3s both;padding:1.5rem;background:linear-gradient(135deg,#2f65e014,#2bb8f214,#3bd6ff14);border-radius:24px;backdrop-filter:blur(10px);border:1px solid var(--weather-border);box-shadow:0 4px 24px var(--weather-shadow)}@media(max-width:768px){.visualization-section[data-v-1b7e5ae4]{padding:1.25rem}}.page-header[data-v-1b7e5ae4]{background:var(--header-bg);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);padding:clamp(.7rem,.55rem + .4vw,1.25rem) clamp(1.25rem,1rem + .6vw,1.5rem);box-shadow:0 4px 24px var(--weather-shadow-lg);position:sticky;top:0;z-index:100;flex-shrink:0;border:2px solid var(--header-border);width:min(1400px,100% - clamp(1.5rem,4vw,3rem));margin:clamp(.875rem,.85rem + .5vw,1.5rem) auto clamp(1.25rem,1rem + .8vw,2rem);border-radius:clamp(16px,14px + .4vw,24px);transition:background-color .3s ease,backdrop-filter .3s ease,box-shadow .3s ease}@media(max-width:768px){.page-header[data-v-1b7e5ae4]{width:calc(100% - clamp(1.25rem,5vw,2.25rem));margin:.5rem auto 1.25rem;padding:.5rem .875rem;border-radius:16px}}.page-header.scrolled[data-v-1b7e5ae4]{background:var(--header-bg-scrolled);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);box-shadow:0 8px 32px var(--weather-shadow-lg)}.header-content[data-v-1b7e5ae4]{display:flex;align-items:center;gap:.875rem;max-width:1400px;margin:0 auto}@media(max-width:768px){.header-content[data-v-1b7e5ae4]{gap:.5rem}}.back-button[data-v-1b7e5ae4]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;color:var(--header-control-color);border-radius:16px;transition:all .3s ease;background:var(--header-control-bg);border:2px solid var(--header-control-border);flex-shrink:0;box-shadow:0 2px 8px var(--weather-shadow)}.back-button[data-v-1b7e5ae4]:hover{background:var(--header-control-hover-bg);transform:scale(1.05);box-shadow:0 4px 16px var(--weather-shadow-md);border-color:var(--header-control-hover-border)}.back-button[data-v-1b7e5ae4]:active{transform:scale(1.02)}.back-button svg[data-v-1b7e5ae4]{width:24px;height:24px}@media(max-width:768px){.back-button[data-v-1b7e5ae4]{width:40px;height:40px}.back-button svg[data-v-1b7e5ae4]{width:20px;height:20px}}.city-search-container[data-v-1b7e5ae4]{position:relative;flex:1}.city-search-button[data-v-1b7e5ae4]{background:transparent;border:none;padding:0;margin:0;display:flex;align-items:center;gap:.875rem;padding:.875rem 1.25rem;width:100%;color:var(--header-control-color);background:var(--header-control-bg);border:2px solid var(--header-control-border);border-radius:16px;transition:all .4s cubic-bezier(.4,0,.2,1);cursor:pointer;box-shadow:0 2px 8px var(--weather-shadow)}.city-search-button[data-v-1b7e5ae4]:hover{background:var(--header-control-hover-bg);border-color:var(--header-control-hover-border);transform:translateY(-2px);box-shadow:0 4px 16px var(--weather-shadow-md)}.city-search-button[data-v-1b7e5ae4]:active{transform:translateY(0)}.city-search-button .location-icon[data-v-1b7e5ae4]{flex-shrink:0;width:20px;height:20px;transition:all .4s cubic-bezier(.4,0,.2,1)}.city-search-button .city-info[data-v-1b7e5ae4]{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.city-search-button .city-name[data-v-1b7e5ae4]{color:var(--header-text);font-size:1rem;font-weight:700;text-shadow:0 1px 3px rgba(15,23,42,.12);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.city-search-button .city-state[data-v-1b7e5ae4]{color:var(--header-control-color);font-size:.8rem;font-weight:600;background:#2f65e01f;padding:.25rem .5rem;border-radius:8px;border:1px solid var(--header-control-border);white-space:nowrap;flex-shrink:0}@media(max-width:768px){.city-search-button[data-v-1b7e5ae4]{padding:.5rem .875rem;gap:.5rem}.city-search-button .location-icon[data-v-1b7e5ae4]{width:18px;height:18px}.city-search-button .city-name[data-v-1b7e5ae4]{font-size:.8rem}.city-search-button .city-state[data-v-1b7e5ae4]{font-size:.75rem;padding:2px .25rem}}.inline-search-box[data-v-1b7e5ae4]{position:relative;display:flex;align-items:center;gap:.875rem;padding:.875rem 1.25rem;width:100%;background:var(--header-control-bg);border:2px solid var(--header-control-border);border-radius:16px;box-shadow:0 2px 8px var(--weather-shadow);animation:searchBoxFadeIn-1b7e5ae4 .4s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@media(max-width:768px){.inline-search-box[data-v-1b7e5ae4]{padding:.5rem .875rem;gap:.5rem}}@keyframes searchBoxFadeIn-1b7e5ae4{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.inline-search-input[data-v-1b7e5ae4]{flex:1;border:none;background:transparent;font-size:.8rem;color:var(--header-text);outline:none;font-weight:600}.inline-search-input[data-v-1b7e5ae4]::placeholder{color:var(--weather-text-muted);font-weight:500}@media(max-width:768px){.inline-search-input[data-v-1b7e5ae4]{font-size:.75rem}}.inline-clear-btn[data-v-1b7e5ae4]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--header-text);border-radius:12px;transition:all .2s ease;flex-shrink:0}.inline-clear-btn[data-v-1b7e5ae4]:hover{background:var(--header-control-hover-bg);color:var(--header-text)}.inline-clear-btn[data-v-1b7e5ae4]:active{transform:scale(.95)}[data-theme=dark] .inline-search-box[data-v-1b7e5ae4]{background:var(--weather-surface);border-color:var(--weather-border);box-shadow:0 8px 24px var(--weather-shadow-md)}[data-theme=dark] .inline-search-input[data-v-1b7e5ae4]{color:var(--weather-text-primary)}[data-theme=dark] .inline-search-input[data-v-1b7e5ae4]::placeholder{color:var(--weather-text-muted)}[data-theme=dark] .inline-clear-btn[data-v-1b7e5ae4]{color:var(--weather-text-secondary)}[data-theme=dark] .inline-clear-btn[data-v-1b7e5ae4]:hover{background:#ffffff0f;color:var(--weather-text-primary)}[data-theme=dark] .search-dropdown[data-v-1b7e5ae4]{background:var(--weather-surface-card);border-color:var(--weather-border);box-shadow:0 12px 40px var(--weather-shadow-lg)}[data-theme=dark] .dropdown-item[data-v-1b7e5ae4]{border-bottom:1px solid var(--weather-border-light)}[data-theme=dark] .dropdown-item svg[data-v-1b7e5ae4]{color:var(--weather-text-muted)}[data-theme=dark] .dropdown-item[data-v-1b7e5ae4]:hover{background:linear-gradient(135deg,#5a6fa824,#4338ca1f)}[data-theme=dark] .dropdown-item:hover svg[data-v-1b7e5ae4]{color:var(--weather-primary)}[data-theme=dark] .dropdown-item:hover .dropdown-city-name[data-v-1b7e5ae4]{color:var(--weather-primary)}[data-theme=dark] .dropdown-city-name[data-v-1b7e5ae4]{color:var(--weather-text-primary)}[data-theme=dark] .dropdown-city-state[data-v-1b7e5ae4]{color:var(--weather-text-muted)}[data-theme=dark] .search-dropdown-empty[data-v-1b7e5ae4]{background:var(--weather-surface-card);border-color:var(--weather-border);color:var(--weather-text-muted)}.search-dropdown[data-v-1b7e5ae4]{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:var(--weather-surface-card);border-radius:16px;box-shadow:0 8px 32px var(--weather-shadow-lg);max-height:400px;overflow-y:auto;z-index:1000;animation:dropdownSlideIn-1b7e5ae4 .3s cubic-bezier(.4,0,.2,1);border:2px solid var(--weather-border)}@media(max-width:768px){.search-dropdown[data-v-1b7e5ae4]{max-height:300px}}@keyframes dropdownSlideIn-1b7e5ae4{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item[data-v-1b7e5ae4]{background:transparent;border:none;padding:0;margin:0;display:flex;align-items:center;gap:.875rem;padding:.875rem 1.25rem;width:100%;text-align:left;border-bottom:1px solid var(--weather-border-light);transition:all .2s ease;cursor:pointer}.dropdown-item svg[data-v-1b7e5ae4]{flex-shrink:0;width:16px;height:16px;color:var(--weather-text-muted);transition:all .2s ease}.dropdown-item[data-v-1b7e5ae4]:hover{background:linear-gradient(135deg,#2f65e014,#22b8f20f)}.dropdown-item:hover svg[data-v-1b7e5ae4]{color:var(--weather-primary);transform:scale(1.1)}.dropdown-item:hover .dropdown-city-name[data-v-1b7e5ae4]{color:var(--weather-primary)}.dropdown-item[data-v-1b7e5ae4]:last-child{border-bottom:none}.dropdown-item[data-v-1b7e5ae4]:first-child{border-top-left-radius:16px;border-top-right-radius:16px}.dropdown-item[data-v-1b7e5ae4]:last-child{border-bottom-left-radius:16px;border-bottom-right-radius:16px}@media(max-width:768px){.dropdown-item[data-v-1b7e5ae4]{padding:.5rem .875rem;gap:.5rem}}.dropdown-city-info[data-v-1b7e5ae4]{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.dropdown-city-name[data-v-1b7e5ae4]{color:var(--weather-text-primary);font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s ease}@media(max-width:768px){.dropdown-city-name[data-v-1b7e5ae4]{font-size:.75rem}}.dropdown-city-state[data-v-1b7e5ae4]{color:var(--weather-text-muted);font-size:.75rem}@media(max-width:768px){.dropdown-city-state[data-v-1b7e5ae4]{font-size:.7rem}}.search-dropdown-empty[data-v-1b7e5ae4]{padding:1.5rem;text-align:center;color:var(--weather-text-muted);font-size:.75rem;background:var(--weather-surface-card);border-radius:16px;box-shadow:0 8px 32px var(--weather-shadow-lg);position:absolute;top:calc(100% + .5rem);left:0;right:0;z-index:1000;animation:dropdownSlideIn-1b7e5ae4 .3s cubic-bezier(.4,0,.2,1);border:2px solid var(--weather-border)}.theme-toggle-button[data-v-1b7e5ae4]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;color:var(--header-control-color);border-radius:16px;transition:all .3s ease;background:var(--header-control-bg);border:2px solid var(--header-control-border);flex-shrink:0;box-shadow:0 2px 8px var(--weather-shadow)}.theme-toggle-button[data-v-1b7e5ae4]:hover{background:var(--header-control-hover-bg);transform:scale(1.05);box-shadow:0 4px 16px var(--weather-shadow-md);border-color:var(--header-control-hover-border)}.theme-toggle-button[data-v-1b7e5ae4]:active{transform:scale(1.02)}.theme-toggle-button svg[data-v-1b7e5ae4]{width:20px;height:20px;transition:transform .3s ease}@media(max-width:768px){.theme-toggle-button[data-v-1b7e5ae4]{width:40px;height:40px}.theme-toggle-button svg[data-v-1b7e5ae4]{width:18px;height:18px}}.hero-cards-grid[data-v-1b7e5ae4]{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem}@media(max-width:768px){.hero-cards-grid[data-v-1b7e5ae4]{grid-template-columns:1fr;gap:1.25rem}}.hero-temp-card[data-v-1b7e5ae4]{background:var(--weather-surface-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:2rem;border-radius:24px;box-shadow:0 4px 24px var(--weather-shadow);display:flex;align-items:center;gap:1.5rem;border:2px solid var(--weather-border);transition:all .3s ease;animation:slideDown-1b7e5ae4 .6s ease-out;position:relative;overflow:hidden}.hero-temp-card[data-v-1b7e5ae4]:hover{transform:translateY(-4px);box-shadow:0 12px 40px var(--weather-shadow-md);border-color:var(--weather-border-light)}.hero-temp-card:hover .hero-icon[data-v-1b7e5ae4]{transform:scale(1.15) rotate(5deg)}.hero-temp-card:hover .hero-temp-value[data-v-1b7e5ae4]{transform:scale(1.05)}@media(max-width:768px){.hero-temp-card[data-v-1b7e5ae4]{flex-direction:column;padding:1.5rem;gap:.875rem}}.hero-icon[data-v-1b7e5ae4]{font-size:120px;line-height:1;filter:drop-shadow(0 8px 20px rgba(47,101,224,.28));transition:all .4s cubic-bezier(.34,1.56,.64,1);animation:floatIcon-1b7e5ae4 3s ease-in-out infinite;position:relative;z-index:1}@media(max-width:768px){.hero-icon[data-v-1b7e5ae4]{font-size:96px}}@keyframes floatIcon-1b7e5ae4{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-temp-info[data-v-1b7e5ae4]{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1;position:relative;z-index:2;margin-left:-40px}@media(max-width:768px){.hero-temp-info[data-v-1b7e5ae4]{margin-left:0}}.hero-temp-value[data-v-1b7e5ae4]{font-size:96px;font-weight:800;background:linear-gradient(135deg,#2f65e0eb,#2bb8f2e6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;letter-spacing:-3px;transition:transform .3s ease;text-shadow:0 4px 12px rgba(47,101,224,.22);animation:pulseTemp-1b7e5ae4 2s ease-in-out infinite}@media(max-width:768px){.hero-temp-value[data-v-1b7e5ae4]{font-size:72px;letter-spacing:-2px}}@keyframes pulseTemp-1b7e5ae4{0%,to{opacity:1}50%{opacity:.95}}.hero-temp-label[data-v-1b7e5ae4]{font-size:1rem;color:#2f65e0c7;text-transform:capitalize;font-weight:600}@media(max-width:768px){.hero-temp-label[data-v-1b7e5ae4]{font-size:.9rem}}.hero-temp-range[data-v-1b7e5ae4]{display:flex;align-items:center;gap:.875rem;margin-top:.875rem;padding:.5rem 1.25rem;background:linear-gradient(135deg,#2f65e01a,#2bb8f21a);border-radius:16px;border:1px solid rgba(47,101,224,.2)}@media(max-width:768px){.hero-temp-range[data-v-1b7e5ae4]{gap:.5rem;padding:.25rem .875rem}}.temp-range-max[data-v-1b7e5ae4],.temp-range-min[data-v-1b7e5ae4]{display:flex;align-items:center;gap:.25rem;font-size:.9rem;font-weight:700}.temp-range-max svg[data-v-1b7e5ae4],.temp-range-min svg[data-v-1b7e5ae4]{width:16px;height:16px;flex-shrink:0}@media(max-width:768px){.temp-range-max[data-v-1b7e5ae4],.temp-range-min[data-v-1b7e5ae4]{font-size:.8rem}.temp-range-max svg[data-v-1b7e5ae4],.temp-range-min svg[data-v-1b7e5ae4]{width:14px;height:14px}}.temp-range-max[data-v-1b7e5ae4]{color:#fb923c}.temp-range-min[data-v-1b7e5ae4]{color:#60a5fa}.temp-range-separator[data-v-1b7e5ae4]{color:#2f65e047;font-weight:500;font-size:1rem}@media(max-width:768px){.temp-range-separator[data-v-1b7e5ae4]{font-size:.9rem}}.hero-wind-card[data-v-1b7e5ae4]{background:var(--weather-surface-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem;border-radius:24px;box-shadow:0 4px 24px var(--weather-shadow);border:2px solid var(--weather-border);transition:all .3s ease;animation:slideDown-1b7e5ae4 .6s ease-out .1s both;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.875rem}.hero-wind-card[data-v-1b7e5ae4]:hover{transform:translateY(-2px);box-shadow:0 8px 32px var(--weather-shadow-md);border-color:var(--weather-border-light)}@media(max-width:768px){.hero-wind-card[data-v-1b7e5ae4]{padding:1.25rem}}.wind-card-title[data-v-1b7e5ae4]{margin:0;font-size:.9rem;font-weight:700;color:var(--weather-text-secondary);text-align:center}@media(max-width:768px){.wind-card-title[data-v-1b7e5ae4]{font-size:.8rem}}@keyframes slideDown-1b7e5ae4{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.metrics-container[data-v-1b7e5ae4]{margin-top:1.5rem;animation:fadeIn-1b7e5ae4 .6s ease-out .2s both}.metrics-header[data-v-1b7e5ae4]{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;cursor:pointer;user-select:none}@media(max-width:768px){.metrics-header[data-v-1b7e5ae4]{margin-bottom:.875rem}}.metrics-title[data-v-1b7e5ae4]{font-size:1rem;font-weight:700;color:var(--weather-text-secondary);margin:0}@media(max-width:768px){.metrics-title[data-v-1b7e5ae4]{font-size:.9rem}}.metrics-toggle[data-v-1b7e5ae4]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;background:#2f65e01f;color:var(--weather-primary);transition:all .3s ease}.metrics-toggle svg[data-v-1b7e5ae4]{transition:transform .3s ease}.metrics-toggle.expanded svg[data-v-1b7e5ae4]{transform:rotate(180deg)}.metrics-toggle[data-v-1b7e5ae4]:hover{background:#2f65e029;color:var(--weather-accent)}@media(max-width:768px){.metrics-toggle[data-v-1b7e5ae4]{display:flex}}.metrics-grid[data-v-1b7e5ae4]{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}@media(max-width:768px){.metrics-grid[data-v-1b7e5ae4]{grid-template-columns:1fr;gap:.875rem;max-height:1000px;overflow:hidden;transition:max-height .4s ease-out,opacity .3s ease-out}.metrics-grid.collapsed[data-v-1b7e5ae4]{max-height:0;opacity:0}}.metric-item[data-v-1b7e5ae4]{display:flex;align-items:center;justify-content:space-between;gap:.875rem;padding:1.25rem;background:var(--weather-surface-blur);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:16px;border:2px solid var(--weather-border);box-shadow:0 2px 8px var(--weather-shadow);transition:all .3s ease}.metric-item[data-v-1b7e5ae4]:hover{transform:translateY(-2px);box-shadow:0 4px 16px var(--weather-shadow-md);border-color:var(--weather-border-light);background:var(--weather-surface)}@media(max-width:768px){.metric-item[data-v-1b7e5ae4]{padding:.875rem;gap:.5rem}}.metric-label[data-v-1b7e5ae4]{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--weather-text-muted);font-size:.8rem}@media(max-width:768px){.metric-label[data-v-1b7e5ae4]{font-size:.75rem;gap:.25rem}}.metric-value[data-v-1b7e5ae4]{font-weight:700;color:var(--weather-text-secondary);opacity:.9;font-size:.9rem;white-space:nowrap}@media(max-width:768px){.metric-value[data-v-1b7e5ae4]{font-size:.8rem}}.metric-icon[data-v-1b7e5ae4]{font-size:20px;line-height:1;filter:drop-shadow(0 2px 4px rgba(47,101,224,.16))}@media(max-width:768px){.metric-icon[data-v-1b7e5ae4]{font-size:18px}}.hourly-forecast-section[data-v-1b7e5ae4]{margin:0;animation:fadeIn-1b7e5ae4 .6s ease-out .35s both;padding:1.5rem;background:linear-gradient(135deg,#2f65e014,#2bb8f214,#3bd6ff14);border-radius:24px;backdrop-filter:blur(10px);border:1px solid var(--weather-border);box-shadow:0 4px 24px var(--weather-shadow)}@media(max-width:768px){.hourly-forecast-section[data-v-1b7e5ae4]{padding:1.25rem}}.hourly-scroll-container[data-v-1b7e5ae4]{display:flex;gap:.875rem;overflow-x:auto;scroll-snap-type:x mandatory;margin:0 -1.5rem;padding:.875rem 1.5rem 1.5rem;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.hourly-scroll-container[data-v-1b7e5ae4]::-webkit-scrollbar{height:6px}.hourly-scroll-container[data-v-1b7e5ae4]::-webkit-scrollbar-track{background:#2f65e01f;border-radius:50%;margin:0 1.5rem}.hourly-scroll-container[data-v-1b7e5ae4]::-webkit-scrollbar-thumb{background:#2bb8f259;border-radius:50%}.hourly-scroll-container[data-v-1b7e5ae4]::-webkit-scrollbar-thumb:hover{background:#2bb8f28c}@media(max-width:768px){.hourly-scroll-container[data-v-1b7e5ae4]{gap:.5rem;margin:0 -1.25rem;padding-left:1.25rem;padding-right:1.25rem}}.hourly-card[data-v-1b7e5ae4]{min-width:110px;max-width:110px;flex-shrink:0;scroll-snap-align:start;background:linear-gradient(135deg,#fffffff0,#f1f8fff5);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:.875rem;border-radius:16px;box-shadow:0 3px 12px var(--weather-shadow);border:2px solid var(--weather-border);transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.25rem}.hourly-card[data-v-1b7e5ae4]:hover{transform:translateY(-2px);box-shadow:0 6px 18px var(--weather-shadow-md);border-color:var(--weather-border-light)}@media(max-width:768px){.hourly-card[data-v-1b7e5ae4]{min-width:95px;max-width:95px;padding:.5rem}}.hourly-time[data-v-1b7e5ae4]{font-size:.7rem;font-weight:700;color:var(--weather-primary);text-align:center;white-space:pre-line;line-height:1.3}@media(max-width:768px){.hourly-time[data-v-1b7e5ae4]{font-size:10px}}.hourly-icon[data-v-1b7e5ae4]{font-size:32px;text-align:center;line-height:1;filter:drop-shadow(0 2px 6px rgba(47,101,224,.18));margin:.25rem 0;cursor:help}@media(max-width:768px){.hourly-icon[data-v-1b7e5ae4]{font-size:28px}}.hourly-description[data-v-1b7e5ae4]{font-size:10px;font-weight:600;color:var(--weather-text-secondary);text-align:center;line-height:1.2;min-height:24px;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.hourly-description[data-v-1b7e5ae4]{font-size:9px;min-height:22px}}.hourly-temp[data-v-1b7e5ae4]{font-size:.9rem;font-weight:700;color:var(--weather-primary);text-align:center}@media(max-width:768px){.hourly-temp[data-v-1b7e5ae4]{font-size:.8rem}}.hourly-detail[data-v-1b7e5ae4]{display:flex;align-items:center;justify-content:center;gap:.25rem;font-size:10px;font-weight:600;color:var(--weather-text-secondary);width:100%}@media(max-width:768px){.hourly-detail[data-v-1b7e5ae4]{font-size:9px}}.hourly-detail .detail-icon[data-v-1b7e5ae4]{font-size:12px}@media(max-width:768px){.hourly-detail .detail-icon[data-v-1b7e5ae4]{font-size:11px}}.forecast-section[data-v-1b7e5ae4]{margin:0;animation:fadeIn-1b7e5ae4 .6s ease-out .4s both;padding:1.5rem;background:linear-gradient(135deg,#2f65e014,#2bb8f214,#3bd6ff14);border-radius:24px;backdrop-filter:blur(10px);border:1px solid var(--weather-border);box-shadow:0 4px 24px var(--weather-shadow)}@media(max-width:768px){.forecast-section[data-v-1b7e5ae4]{padding:1.25rem}}.forecast-header[data-v-1b7e5ae4]{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}@media(max-width:768px){.forecast-header[data-v-1b7e5ae4]{flex-direction:row;align-items:center;gap:.5rem;margin-bottom:1.25rem}}.forecast-header .section-title[data-v-1b7e5ae4]{flex:1 1 auto;min-width:0}.forecast-nav-buttons[data-v-1b7e5ae4]{display:flex;gap:.5rem}@media(max-width:768px){.forecast-nav-buttons[data-v-1b7e5ae4]{width:auto;justify-content:flex-end}}.forecast-nav-btn[data-v-1b7e5ae4]{background:transparent;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:var(--weather-surface-blur);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid var(--weather-border);color:var(--weather-primary);transition:all .3s ease;box-shadow:0 2px 8px var(--weather-shadow)}[data-theme=dark] .forecast-nav-btn[data-v-1b7e5ae4]{color:var(--weather-primary)}.forecast-nav-btn[data-v-1b7e5ae4]:not(:disabled):hover{background:var(--weather-surface);border-color:var(--weather-border-light);color:var(--weather-accent);transform:scale(1.05);box-shadow:0 4px 12px var(--weather-shadow-md)}[data-theme=dark] .forecast-nav-btn[data-v-1b7e5ae4]:not(:disabled):hover{color:var(--weather-primary)}.forecast-nav-btn[data-v-1b7e5ae4]:not(:disabled):active{transform:scale(.98)}.forecast-nav-btn[data-v-1b7e5ae4]:disabled{opacity:.3;cursor:not-allowed}.forecast-nav-btn svg[data-v-1b7e5ae4]{width:20px;height:20px}@media(max-width:768px){.forecast-nav-btn[data-v-1b7e5ae4]{width:36px;height:36px}.forecast-nav-btn svg[data-v-1b7e5ae4]{width:18px;height:18px}}.forecast-scroll-container[data-v-1b7e5ae4]{display:flex;gap:1.25rem;overflow-x:auto;scroll-snap-type:x mandatory;margin:0 -1.5rem;padding:.875rem 1.5rem 1.5rem;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.forecast-scroll-container[data-v-1b7e5ae4]::-webkit-scrollbar{height:8px}.forecast-scroll-container[data-v-1b7e5ae4]::-webkit-scrollbar-track{background:#2f65e01f;border-radius:50%;margin:0 1.5rem}.forecast-scroll-container[data-v-1b7e5ae4]::-webkit-scrollbar-thumb{background:#2bb8f259;border-radius:50%}.forecast-scroll-container[data-v-1b7e5ae4]::-webkit-scrollbar-thumb:hover{background:#2bb8f28c}@media(max-width:768px){.forecast-scroll-container[data-v-1b7e5ae4]{gap:.875rem;margin:0 -1.25rem;padding-left:1.25rem;padding-right:1.25rem}}.forecast-card[data-v-1b7e5ae4]{min-width:220px;max-width:220px;flex-shrink:0;scroll-snap-align:start;background:var(--weather-surface-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem;border-radius:20px;box-shadow:0 4px 16px var(--weather-shadow);border:2px solid var(--weather-border);transition:all .3s ease;display:flex;flex-direction:column;gap:.875rem;color:var(--weather-text-muted)}.forecast-card[data-v-1b7e5ae4]:hover{transform:translateY(-4px);box-shadow:0 8px 24px var(--weather-shadow-md);border-color:var(--weather-border-light)}.forecast-card.has-rain[data-v-1b7e5ae4]{background:linear-gradient(135deg,#2f65e024,#2bb8f21f);border-color:#2bb8f24d}[data-theme=dark] .forecast-card.has-rain[data-v-1b7e5ae4]{background:linear-gradient(135deg,#58b1ff38,#4599eb29);border-color:#58b1ff66}@media(max-width:768px){.forecast-card[data-v-1b7e5ae4]{min-width:180px;max-width:180px;padding:1.25rem;gap:.5rem}}.forecast-date[data-v-1b7e5ae4]{font-size:.8rem;font-weight:700;color:var(--weather-text-muted);text-align:center;text-transform:capitalize;padding-bottom:.5rem;border-bottom:2px solid var(--weather-border-light)}[data-theme=dark] .forecast-date[data-v-1b7e5ae4]{border-bottom-color:#47556966}@media(max-width:768px){.forecast-date[data-v-1b7e5ae4]{font-size:.75rem}}.forecast-icon[data-v-1b7e5ae4]{font-size:48px;text-align:center;line-height:1;filter:drop-shadow(0 2px 8px rgba(47,101,224,.2));margin:.5rem 0}@media(max-width:768px){.forecast-icon[data-v-1b7e5ae4]{font-size:40px}}.forecast-temps[data-v-1b7e5ae4]{display:flex;align-items:center;justify-content:center;gap:.25rem;font-size:1rem;font-weight:700;margin:.5rem 0;color:var(--weather-text-primary)}@media(max-width:768px){.forecast-temps[data-v-1b7e5ae4]{font-size:1rem}}.temp-max[data-v-1b7e5ae4]{color:#fb923c}.temp-min[data-v-1b7e5ae4]{color:#60a5fa}.temp-separator[data-v-1b7e5ae4]{color:#2f65e047;font-weight:500}[data-theme=dark] .temp-separator[data-v-1b7e5ae4]{color:#58b1ff73}.forecast-detail[data-v-1b7e5ae4]{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap;padding:.5rem .875rem;background:#2f65e00f;border-radius:12px;font-size:.75rem;line-height:1.25;color:var(--weather-text-secondary)}[data-theme=dark] .forecast-detail[data-v-1b7e5ae4]{background:#58b1ff24}.forecast-detail.moon-phase[data-v-1b7e5ae4]{background:linear-gradient(135deg,#9333ea1a,#4f46e51a);border:1px solid rgba(147,51,234,.2)}.forecast-detail.moon-phase .detail-icon[data-v-1b7e5ae4]{font-size:20px}.forecast-detail.moon-phase .detail-value[data-v-1b7e5ae4]{color:#7c3aed;font-weight:700}[data-theme=dark] .forecast-detail.moon-phase .detail-value[data-v-1b7e5ae4]{color:#a78bfa}@media(max-width:768px){.forecast-detail[data-v-1b7e5ae4]{padding:.25rem .5rem;font-size:.7rem}}.detail-left[data-v-1b7e5ae4]{display:flex;align-items:center;gap:.25rem;min-width:0;max-width:100%;flex:1 1 auto}.detail-icon[data-v-1b7e5ae4]{font-size:18px}@media(max-width:768px){.detail-icon[data-v-1b7e5ae4]{font-size:16px}}.detail-label[data-v-1b7e5ae4]{font-weight:600;color:var(--weather-text-muted);letter-spacing:0;text-transform:uppercase;font-size:.7rem;line-height:1.15;white-space:nowrap}.detail-value[data-v-1b7e5ae4]{font-weight:600;color:var(--weather-text-muted);opacity:.95;text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;justify-self:end;flex:0 0 auto}.wind-detail .wind-value[data-v-1b7e5ae4]{display:inline-flex;align-items:center;gap:.25rem}.wind-arrow[data-v-1b7e5ae4]{font-size:.9rem;line-height:1}.wind-speed[data-v-1b7e5ae4]{font-weight:700;color:var(--weather-text-secondary)}.forecast-uv[data-v-1b7e5ae4]{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:.5rem .875rem;border-radius:12px;font-size:.75rem;font-weight:700;margin-top:.25rem;border:1px solid transparent}[data-theme=dark] .forecast-uv[data-v-1b7e5ae4]{border-color:#0003;box-shadow:0 1px 3px #0003}@media(max-width:768px){.forecast-uv[data-v-1b7e5ae4]{padding:.25rem .5rem;font-size:.7rem}}.uv-icon[data-v-1b7e5ae4]{width:14px;height:14px;flex-shrink:0}@media(max-width:768px){.uv-icon[data-v-1b7e5ae4]{width:12px;height:12px}}@keyframes fadeIn-1b7e5ae4{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chart-mobile-trigger[data-v-1b7e5ae4]{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1.25rem;background:linear-gradient(135deg,#667eea14,#764ba214);border:2px solid rgba(139,157,225,.2);border-radius:12px;cursor:pointer;transition:all .3s ease}@media(min-width:481px){.chart-mobile-trigger[data-v-1b7e5ae4]{display:none!important}}.chart-mobile-trigger[data-v-1b7e5ae4]:active{transform:scale(.98);background:linear-gradient(135deg,#667eea26,#764ba226)}[data-theme=dark] .chart-mobile-trigger[data-v-1b7e5ae4]{background:linear-gradient(135deg,#47556966,#33415566);border-color:#47556980}[data-theme=dark] .chart-mobile-trigger[data-v-1b7e5ae4]:active{background:linear-gradient(135deg,#47556999,#33415599)}[data-theme=dark] .chart-mobile-trigger .trigger-text[data-v-1b7e5ae4],[data-theme=dark] .chart-mobile-trigger .trigger-arrow[data-v-1b7e5ae4]{color:var(--weather-primary)}.chart-mobile-trigger .trigger-icon[data-v-1b7e5ae4]{font-size:24px;margin-right:.5rem}.chart-mobile-trigger .trigger-text[data-v-1b7e5ae4]{flex:1;font-size:.8rem;font-weight:700;color:#667eea;text-align:left}.chart-mobile-trigger .trigger-arrow[data-v-1b7e5ae4]{font-size:28px;color:#667eea;font-weight:700}.chart-desktop-wrapper[data-v-1b7e5ae4]{display:none}@media(min-width:481px){.chart-desktop-wrapper[data-v-1b7e5ae4]{display:block!important}}.sun-timeline-wrapper[data-v-1b7e5ae4]{margin-top:1.5rem;animation:fadeIn-1b7e5ae4 .6s ease-out .2s both;max-width:500px}@media(max-width:768px){.sun-timeline-wrapper[data-v-1b7e5ae4]{margin-top:1.25rem;max-width:100%}}
