*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary:#ffffff;--bg-secondary:#f8f9fa;--bg-tertiary:#e8eaed;--text-primary:#202124;--text-secondary:#5f6368;--text-tertiary:#80868b;--text-inverse:#ffffff;--weather-sunny:linear-gradient(180deg, #ff9800 0%, #ff6f00 100%);--weather-sunny-light:#fff3e0;--weather-cloudy:linear-gradient(180deg, #78909c 0%, #546e7a 100%);--weather-cloudy-light:#eceff1;--weather-rainy:linear-gradient(180deg, #2196f3 0%, #1976d2 100%);--weather-rainy-light:#e3f2fd;--weather-stormy:linear-gradient(180deg, #5c6bc0 0%, #3f51b5 100%);--weather-stormy-light:#e8eaf6;--weather-snowy:linear-gradient(180deg, #90caf9 0%, #64b5f6 100%);--weather-snowy-light:#e1f5fe;--weather-foggy:linear-gradient(180deg, #9e9e9e 0%, #757575 100%);--weather-foggy-light:#f5f5f5;--accent-blue:#1a73e8;--accent-orange:#ff9800;--accent-green:#34a853;--accent-red:#ea4335;--shadow-1:0 1px 2px 0 rgba(60, 64, 67, 0.3),0 1px 3px 1px rgba(60, 64, 67, 0.15);--shadow-2:0 1px 2px 0 rgba(60, 64, 67, 0.3),0 2px 6px 2px rgba(60, 64, 67, 0.15);--shadow-3:0 1px 3px 0 rgba(60, 64, 67, 0.3),0 4px 8px 3px rgba(60, 64, 67, 0.15);--shadow-4:0 2px 4px 0 rgba(60, 64, 67, 0.3),0 6px 12px 4px rgba(60, 64, 67, 0.15);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--transition:200ms cubic-bezier(0.4, 0, 0.2, 1);--transition-slow:400ms cubic-bezier(0.4, 0, 0.2, 1)}html{scroll-behavior:smooth}body.page-transitioning{opacity:.7;transition:opacity .3s ease}body.page-transitioning *{pointer-events:none}body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;background:radial-gradient(circle at 20% 50%,rgba(120,119,198,.03) 0,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,119,198,.03) 0,transparent 50%),linear-gradient(135deg,#f5f7fa 0,#e8ecf1 50%,#f1f5f9 100%);background-attachment:fixed;color:var(--text-primary);line-height:1.5;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;letter-spacing:-.01em;position:relative;z-index:1}body::before{content:'';position:fixed;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(0,0,0,.01) 2px,rgba(0,0,0,.01) 4px);pointer-events:none;z-index:0}body>*{position:relative;z-index:1}.container{max-width:1600px;margin:0 auto;padding:0 24px;position:relative;z-index:1}header{background:rgba(255,255,255,.95);backdrop-filter:blur(10px);padding:16px 0;border-bottom:1px solid rgba(0,0,0,.08);position:sticky;top:0;z-index:10003;box-shadow:var(--shadow-1);transition:opacity .3s ease;overflow:visible}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;flex-wrap:wrap;gap:12px;position:relative;overflow:visible}.header-left{display:flex;align-items:center;gap:12px;flex:1;flex-wrap:wrap}.header-right{display:flex;align-items:center;gap:16px;overflow:visible}.site-logo-link{display:flex;align-items:center;text-decoration:none;transition:opacity var(--transition)}.site-logo-link:hover{opacity:.8}.site-logo-link:active{opacity:.6}.site-logo{height:120px;width:auto;object-fit:contain;flex-shrink:0}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);margin-top:4px;flex-wrap:wrap}.breadcrumb-item{display:flex;align-items:center;gap:8px}.breadcrumb-item a{color:var(--accent-blue);text-decoration:none;transition:color var(--transition)}.breadcrumb-item a:hover{color:var(--accent-blue-dark);text-decoration:underline}.breadcrumb-separator{color:var(--text-tertiary);user-select:none}.breadcrumb-current{color:var(--text-primary);font-weight:500}@media (max-width:768px){.breadcrumb{font-size:12px;gap:6px;margin-top:2px}.breadcrumb-item{gap:6px}}header h1{font-size:28px;font-weight:400;color:var(--text-primary);letter-spacing:0;margin:0}.site-title-clickable{cursor:pointer;transition:color var(--transition),opacity var(--transition);user-select:none}.site-title-clickable:hover{color:var(--accent-blue);opacity:.8}.site-title-clickable:active{opacity:.6;transform:scale(.98)}.search-full-width{width:100%;margin-top:16px;position:relative;z-index:10}.search-container-full{position:relative;width:100%;z-index:10}.city-search-full{width:100%;padding:12px 20px;border:1px solid rgba(0,0,0,.12);border-radius:24px;font-size:15px;background:#fff;color:var(--text-primary);transition:all var(--transition);outline:0;box-sizing:border-box}.city-search-full:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px rgba(26,115,232,.1)}.city-search-full::placeholder{color:var(--text-secondary)}.search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid rgba(0,0,0,.12);border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.15);z-index:100;max-height:300px;overflow-y:auto;display:none;margin-top:4px}.search-result-item{padding:12px 16px;cursor:pointer;transition:background-color var(--transition);border-bottom:1px solid rgba(0,0,0,.06)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:rgba(26,115,232,.08)}.search-result-name{font-size:14px;color:var(--text-primary);font-weight:400}.language-selector-custom{position:relative;margin-left:auto;order:2;z-index:100;display:inline-block}.lang-selector-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-primary);border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);font-size:15px;font-weight:500;color:var(--text-primary);box-shadow:var(--shadow-1);min-width:130px;white-space:nowrap;position:relative;z-index:1}.lang-selector-btn:hover{background:var(--bg-secondary);box-shadow:var(--shadow-2);transform:translateY(-1px)}.lang-selector-btn:active{transform:translateY(0)}.lang-selector-btn[aria-expanded=true]{background:var(--bg-secondary)}.lang-selector-btn[aria-expanded=true] .lang-chevron{transform:rotate(180deg)}.lang-current-flag{font-size:18px;line-height:1}.lang-current-name{flex:1;text-align:left}.lang-chevron{transition:transform .3s cubic-bezier(.4, 0, .2, 1);color:var(--text-secondary)}.lang-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-primary);border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition);max-height:0;overflow:hidden;z-index:10100}.lang-dropdown.active{opacity:1;visibility:visible;transform:translateY(0);max-height:400px;overflow-y:auto}.lang-option{display:flex;align-items:center;gap:12px;padding:14px 18px;cursor:pointer;transition:all var(--transition);font-size:15px;font-weight:500;color:var(--text-primary);border-bottom:1px solid rgba(0,0,0,.06);text-decoration:none}.lang-option:last-child{border-bottom:none}.lang-option:hover{background:var(--bg-hover);padding-left:22px}.lang-option:active{background:rgba(0,0,0,.05)}.lang-option.selected{background:rgba(37,99,235,.08);color:var(--accent-blue);font-weight:600}.lang-option-flag{font-size:20px;line-height:1}.lang-option-name{flex:1}.subtitle{font-size:14px;color:var(--text-secondary);font-weight:400;text-align:center}main{padding:24px 0 48px}section{margin-bottom:24px}h2{font-size:20px;font-weight:400;color:var(--text-primary);margin-bottom:16px;letter-spacing:0;padding:0 4px}.current-weather{position:relative;border-radius:var(--radius-xl);padding:0;margin-bottom:32px;overflow:visible;box-shadow:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);transition:all var(--transition);background:#fff;border:1px solid rgba(0,0,0,.08)}.weather-bg-cloudy,.weather-bg-default,.weather-bg-foggy,.weather-bg-partly-cloudy,.weather-bg-rainy,.weather-bg-snowy,.weather-bg-stormy,.weather-bg-sunny{background:#fff;color:var(--text-primary)}.weather-background-icon{display:none}.weather-overlay{display:none}.current-weather-content{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:0;width:100%}.current-main{padding:0 40px 24px 40px;padding-top:0;text-align:center;position:relative;z-index:2;border-bottom:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;justify-content:flex-start;align-items:center;min-height:auto}.current-main>.weather-icon-img:first-child{width:320px;height:320px;max-width:320px;max-height:320px!important;margin:0;margin-bottom:40px;display:block;position:relative;z-index:2;filter:drop-shadow(0 2px 6px rgba(0, 0, 0, .12));object-fit:contain}.weather-icon{font-size:816px;margin:0;margin-top:0;margin-bottom:40px;line-height:1;height:1320px;display:flex;align-items:flex-start;justify-content:center;position:relative;z-index:2;filter:drop-shadow(0 2px 6px rgba(0, 0, 0, .12))}.weather-icon .wi{font-size:1em;display:block}.weather-icon-img{width:100%;height:100%;object-fit:contain;display:block}.weather-icon .weather-icon-img{width:100%;height:100%;max-width:1320px;max-height:1320px}.temperature-wrapper{display:flex;flex-direction:column;align-items:center;gap:8px}.temperature{font-size:80px;font-weight:300;line-height:1;margin:0;letter-spacing:-4px}.city-name{font-size:24px;font-weight:500;color:var(--text-primary);letter-spacing:0;margin:0}.description{font-size:19px;font-weight:400;color:var(--text-secondary);margin:10px 0 24px;text-transform:capitalize;font-feature-settings:"tnum";position:relative;z-index:2;font-variant-numeric:tabular-nums;letter-spacing:.2px}.rain-alert{background:rgba(0,0,0,.05);padding:12px 20px;border-radius:var(--radius-md);margin-top:20px;font-weight:500;text-align:center;font-size:14px;border:1px solid rgba(0,0,0,.1);position:relative;z-index:2;display:inline-block;color:var(--text-primary);letter-spacing:.1px}.rain-alert.no-rain{background:rgba(255,152,0,.1);border-color:rgba(255,152,0,.2);color:var(--text-primary)}.weather-metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:0;position:relative;z-index:2;margin-top:0;border-top:1px solid rgba(0,0,0,.06);height:auto;min-height:140px}.metric-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 6px;background:0 0;border-radius:0;transition:all var(--transition);border-right:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06);min-height:auto;height:100%;text-align:center}.metric-item:nth-child(3n){border-right:none}.metric-item:nth-last-child(-n+3){border-bottom:none}.metric-item:hover{background:rgba(0,0,0,.03);transform:scale(1.01);z-index:1}.metric-icon{font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;width:auto;height:auto;flex-shrink:0;opacity:.9;margin-bottom:2px}.metric-icon-img{width:96px;height:96px;max-width:96px;max-height:96px;object-fit:contain;display:block}.metric-icon .wi{font-size:1em;display:block}.metric-content{flex:1;min-width:0;width:100%}.metric-label{font-size:8px;margin-bottom:2px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;line-height:1.2}.metric-value{font-size:14px;font-weight:500;letter-spacing:-.2px;font-variant-numeric:tabular-nums;line-height:1.3;color:var(--text-primary)}.metric-desc{font-size:10px;margin-top:6px;font-weight:400;opacity:.75;line-height:1.4}.wind-direction{font-size:12px;transition:transform var(--transition);vertical-align:middle;margin-left:4px}@media (max-width:768px){.current-main{padding:24px 20px;min-height:auto}.current-main>.weather-icon-img:first-child{width:320px;height:320px;max-width:320px;max-height:320px!important}.weather-icon{font-size:816px;height:1320px;margin-bottom:40px}.weather-icon .weather-icon-img{max-width:1320px;max-height:1320px}.temperature{font-size:64px;margin:10px 0}.description{font-size:17px;margin:8px 0 20px}.rain-alert{padding:10px 18px;font-size:13px}.weather-metrics-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);min-height:180px}.metric-item:nth-child(3n){border-right:none}.metric-item:nth-last-child(-n+3){border-bottom:none}.metric-item{padding:10px 6px;min-height:auto;height:100%}.metric-icon{font-size:20px;margin-bottom:2px}.metric-icon-img{width:84px;height:84px;max-width:84px;max-height:84px}.metric-value{font-size:12px}.metric-label{font-size:7px;margin-bottom:2px}.weekly-icon-afternoon,.weekly-icon-morning{font-size:24px!important;width:24px!important;height:24px!important;min-width:24px!important;min-height:24px!important}.weekly-icon-afternoon .weather-icon-img,.weekly-icon-morning .weather-icon-img{width:24px!important;height:24px!important;max-width:24px!important;max-height:24px!important;min-width:24px!important;min-height:24px!important}}.additional-info,.air-quality,.hourly-forecast,.weekly-forecast{background:var(--bg-primary);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-1);border:1px solid rgba(0,0,0,.06);margin-bottom:24px}.hourly-container{display:flex!important;flex-direction:row!important;overflow-x:auto;overflow-y:hidden;gap:16px;padding:8px 0;-webkit-overflow-scrolling:touch;scrollbar-width:thin;justify-content:flex-start;align-items:stretch;flex-wrap:nowrap}@media (min-width:768px){.hourly-container{justify-content:center}}.hourly-container::-webkit-scrollbar{height:4px}.hourly-container::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:2px}.hourly-container::-webkit-scrollbar-thumb{background:var(--accent-blue);border-radius:2px}.hourly-item{min-width:80px;max-width:80px;text-align:center;padding:12px 10px;background:var(--bg-secondary);border-radius:var(--radius-md);transition:all var(--transition);flex-shrink:0;flex-grow:0;border:1px solid transparent;display:flex;flex-direction:column;justify-content:center;align-items:center}.hourly-item.hourly-past{opacity:.5}.hourly-item:hover{background:var(--bg-tertiary);box-shadow:var(--shadow-1);transform:translateY(-2px)}.hourly-item.has-rain{background:var(--weather-rainy-light);border-color:var(--accent-blue)}.hourly-time{font-size:12px;color:var(--text-secondary);margin-bottom:4px;font-weight:400;line-height:1.3}.hourly-icon{font-size:72px;margin:4px 0;line-height:1;height:88px;display:flex;align-items:center;justify-content:center;min-height:88px}.hourly-icon .weather-icon-img{width:72px;height:72px;max-width:72px;max-height:72px}.hourly-temp{font-size:18px;font-weight:400;margin:4px 0 0 0;color:var(--text-primary);letter-spacing:-.3px;font-variant-numeric:tabular-nums}.hourly-rain{font-size:11px;color:var(--accent-blue);font-weight:500;margin-top:4px}.weekly-container{display:flex;flex-direction:column;gap:0}.weekly-item{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:12px 12px;background:0 0;border-radius:var(--radius-md);transition:all var(--transition);border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer}.weekly-weather-group{display:flex;align-items:center;justify-content:flex-end;gap:24px;grid-column:2}.weekly-morning-group{display:flex;align-items:center;gap:8px}.weekly-evening-group{display:flex;align-items:center;gap:8px}.weekly-item:last-child{border-bottom:none}.weekly-item:hover{background:var(--bg-secondary)}.weekly-item.has-rain{background:var(--weather-rainy-light);border-left:3px solid var(--accent-blue);padding-left:9px}.weekly-day{font-weight:400;font-size:16px;color:var(--text-primary);letter-spacing:0}.weekly-day.today{font-weight:500}.weekly-icon-afternoon,.weekly-icon-morning{font-size:96px;color:var(--accent-blue);line-height:1;display:flex;align-items:center;justify-content:center;width:96px;height:96px}.weekly-icon-afternoon .weather-icon-img,.weekly-icon-morning .weather-icon-img{width:96px;height:96px;max-width:96px;max-height:96px}.weekly-icon-afternoon .wi,.weekly-icon-morning .wi{font-size:1em;display:block}.weekly-temp-high{font-size:18px;font-weight:600;color:var(--text-primary);letter-spacing:-.3px;font-variant-numeric:tabular-nums}.weekly-temp-low{font-size:18px;color:var(--text-secondary);font-weight:400;letter-spacing:-.3px;min-width:48px;text-align:right;font-variant-numeric:tabular-nums}.weekly-rain{font-size:14px;color:var(--accent-blue);font-weight:500;min-width:60px;text-align:right}.air-quality-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))!important;gap:16px;grid-auto-flow:row}#airQuality,#airQuality.air-quality-grid,.air-quality #airQuality,.air-quality .air-quality-grid,.air-quality-grid#airQuality{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))!important;grid-auto-flow:row!important;flex-direction:unset!important}.air-quality-item{padding:16px 12px;background:var(--bg-secondary);border-radius:var(--radius-md);text-align:center;transition:all var(--transition);border:1px solid transparent}.air-quality-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-1);background:var(--bg-tertiary)}.air-quality-label{font-size:13px;color:var(--text-secondary);margin-bottom:8px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;position:relative;display:flex;align-items:center;justify-content:center;gap:4px;cursor:help}.tooltip-icon{font-size:10px;opacity:.6;transition:opacity var(--transition)}.tooltip-trigger:hover .tooltip-icon{opacity:1}.tooltip-container{position:relative}.tooltip-trigger{position:relative}.tooltip-trigger::after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(-8px);background:var(--text-primary);color:#fff;padding:10px 14px;border-radius:8px;font-size:12px;font-weight:400;white-space:normal;width:220px;text-align:left;line-height:1.5;opacity:0;pointer-events:none;transition:opacity var(--transition),transform var(--transition);z-index:1000;box-shadow:var(--shadow-3);text-transform:none;letter-spacing:normal}.tooltip-trigger::before{content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(-2px);border:6px solid transparent;border-top-color:var(--text-primary);opacity:0;pointer-events:none;transition:opacity var(--transition),transform var(--transition);z-index:1001}.tooltip-trigger:active::after,.tooltip-trigger:active::before,.tooltip-trigger:hover::after,.tooltip-trigger:hover::before{opacity:1;transform:translateX(-50%) translateY(-12px)}.tooltip-trigger:active::before,.tooltip-trigger:hover::before{transform:translateX(-50%) translateY(-6px)}@media (max-width:767px){.tooltip-trigger::after{width:200px;font-size:11px}.tooltip-trigger.tooltip-active::after,.tooltip-trigger.tooltip-active::before{opacity:1;transform:translateX(-50%) translateY(-12px)}.tooltip-trigger.tooltip-active::before{transform:translateX(-50%) translateY(-6px)}}.air-quality-value{font-size:32px;font-weight:300;margin:6px 0;color:var(--text-primary);line-height:1;letter-spacing:-1px;font-variant-numeric:tabular-nums}.air-quality-status{font-size:11px;padding:4px 10px;border-radius:12px;font-weight:500;display:inline-block;margin-top:6px;margin-bottom:2px}.air-quality-limit{font-size:10px;color:var(--text-secondary);margin-top:4px;font-weight:400}.limit-good{color:var(--accent-green)}.limit-moderate{color:var(--accent-orange)}.limit-bad{color:var(--accent-red)}.status-good{background:rgba(52,168,83,.1);color:var(--accent-green)}.status-moderate{background:rgba(255,152,0,.1);color:var(--accent-orange)}.status-unhealthy{background:rgba(234,67,53,.1);color:var(--accent-red)}.weather-recommendation{margin-bottom:24px}.recommendation-card{background:var(--weather-sunny-light);border-radius:var(--radius-lg);padding:16px 20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-1);border:1px solid rgba(255,152,0,.2)}.recommendation-icon{font-size:28px;line-height:1;flex-shrink:0}.recommendation-text{font-size:15px;font-weight:400;color:var(--text-primary);line-height:1.5}.ad-section{margin:24px 0;width:100%}.ad-banner{width:100%;min-width:320px;max-width:100%;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);border-radius:var(--radius-lg);padding:0;overflow:visible;box-shadow:var(--shadow-2);position:relative;min-height:90px;display:block;border:1px solid rgba(255,255,255,.2)}.ad-banner::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><defs><pattern id="grid" width="20" height="20" patternUnits="userSpaceOnUse"><path d="M 20 0 L 0 0 0 20" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="1"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');opacity:.3}.ad-banner-content{position:relative;z-index:1;text-align:center;padding:40px 20px;color:#fff}.ad-banner-icon{font-size:48px;margin-bottom:12px;opacity:.9}.ad-banner-text{font-size:16px;font-weight:500;margin-bottom:8px}.ad-banner-subtext{font-size:12px;opacity:.9;font-weight:400}.adsbygoogle{display:block!important;width:100%!important;min-width:320px!important;min-height:90px!important}.loading{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px;font-weight:400}footer{background:var(--bg-primary);color:var(--text-secondary);padding:32px 0;margin-top:48px;text-align:center;border-top:1px solid rgba(0,0,0,.06)}footer p{margin:8px 0;font-size:13px;font-weight:400}.footer-links{margin-top:16px}.footer-links a{color:var(--text-secondary);text-decoration:none;font-size:13px;margin:0 12px;transition:color var(--transition);font-weight:400}.footer-links a:hover{color:var(--text-primary)}.main-footer{background:var(--bg-secondary);padding:40px 20px;margin-top:60px;border-top:1px solid rgba(0,0,0,.06)}.footer-container{max-width:1200px;margin:0 auto}.footer-content{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between}.footer-section{flex:1;min-width:200px}.footer-section h3{font-size:18px;margin-bottom:16px;color:var(--text-primary)}.footer-section ul{list-style:none;padding:0;line-height:2}.footer-section ul li{text-align:left}.footer-section ul li a{color:var(--text-secondary);text-decoration:none;transition:color var(--transition)}.footer-section ul li a:hover{color:var(--text-primary)}.footer-section p{color:var(--text-secondary);line-height:1.8;margin:0}@media (min-width:768px){.container{padding:0 32px}header h1{font-size:32px}.current-weather-content{grid-template-columns:1fr 1.2fr}.current-main{text-align:left;padding:24px 48px;border-bottom:none;border-right:1px solid rgba(0,0,0,.06);min-height:auto}.weather-metrics-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);border-top:none;min-height:200px}.metric-item{border-right:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06);padding:12px 8px;min-height:auto;height:100%}.metric-icon-img{width:96px;height:96px;max-width:96px;max-height:96px}.metric-value{font-size:14px}.metric-label{font-size:8px;margin-bottom:2px}.metric-item:nth-child(3n){border-right:none}.metric-item:nth-last-child(-n+3){border-bottom:none}.temperature{font-size:96px;margin:0}.city-name{font-size:26px}.weather-icon{font-size:816px;height:1320px;margin-bottom:40px}.weather-icon .weather-icon-img{max-width:1320px;max-height:1320px}.description{font-size:20px;margin:12px 0 28px}.hourly-item{min-width:100px}.weekly-item{grid-template-columns:200px 1fr auto auto auto;padding:20px 16px}}@media (min-width:1024px){main{padding:32px 0 56px}.current-main{padding:24px 48px;min-height:auto}.temperature{font-size:96px}.weather-icon{font-size:816px;height:1320px;margin-bottom:40px}.weather-icon .weather-icon-img{max-width:1320px;max-height:1320px}.metric-item{padding:28px 20px;min-height:110px}.metric-value{font-size:22px}}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.additional-info,.air-quality,.current-weather,.hourly-forecast,.weekly-forecast{animation:fadeIn .4s ease-out}.day-detail-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:10005;overflow-y:auto;scroll-behavior:auto;padding:20px;box-sizing:border-box}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);z-index:10006}.modal-content{position:relative;max-width:900px;margin:100px auto 20px auto;background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-4);padding:24px;z-index:10007}.modal-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border:none;background:var(--bg-secondary);border-radius:50%;font-size:24px;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);z-index:1002}.modal-close:hover{background:var(--bg-tertiary);transform:scale(1.1)}.day-detail-header{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--bg-tertiary)}.day-detail-header h2{font-size:28px;font-weight:400;color:var(--text-primary);margin-bottom:16px}.day-detail-summary{display:flex;align-items:center;gap:20px}.day-detail-icon{font-size:64px;line-height:1}.day-detail-temps{display:flex;align-items:baseline;gap:12px}.day-detail-temp-high{font-size:36px;font-weight:300;color:var(--text-primary);letter-spacing:-1px;font-variant-numeric:tabular-nums}.day-detail-temp-low{font-size:28px;font-weight:300;color:var(--text-secondary);letter-spacing:-.5px;font-variant-numeric:tabular-nums}.day-detail-chart{margin:24px 0;padding:20px;background:linear-gradient(135deg,rgba(255,149,0,.08) 0,rgba(255,149,0,.03) 100%);border-radius:var(--radius-md);overflow-x:auto;min-height:260px;border:1px solid rgba(255,149,0,.1);position:relative}.day-detail-chart::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0,rgba(255,149,0,.05) 50%,transparent 100%);pointer-events:none;border-radius:var(--radius-md)}.day-detail-chart svg{display:block;width:100%;height:auto;filter:drop-shadow(0 2px 8px rgba(0, 0, 0, .05))}.temperature-chart-svg path{transition:all .3s ease}.temperature-chart-svg circle{cursor:pointer;transition:all .2s ease}.temperature-chart-svg circle:hover{transform:scale(1.3);filter:drop-shadow(0 2px 4px rgba(255, 149, 0, .5))}.day-detail-hourly{display:grid;grid-template-columns:repeat(8,1fr);grid-auto-rows:auto;gap:12px;margin-top:24px;overflow-y:hidden;overflow-x:auto;min-width:0}.detail-hourly-item{text-align:center;padding:16px 12px;background:var(--bg-secondary);border-radius:var(--radius-md);transition:all var(--transition);border:1px solid transparent}.detail-hourly-item:hover{background:var(--bg-tertiary);box-shadow:var(--shadow-1);transform:translateY(-2px)}.detail-hourly-item.has-rain{background:var(--weather-rainy-light);border-color:var(--accent-blue)}.detail-hourly-time{font-size:12px;color:var(--text-secondary);margin-bottom:8px;font-weight:400}.detail-hourly-icon{font-size:64px;margin:8px 0;line-height:1;height:80px;display:flex;align-items:center;justify-content:center;width:64px}.detail-hourly-icon .weather-icon-img{width:64px;height:64px;max-width:64px;max-height:64px}.detail-hourly-temp{font-size:18px;font-weight:400;color:var(--text-primary);margin-top:8px;letter-spacing:-.3px;font-variant-numeric:tabular-nums}.detail-hourly-rain{font-size:10px;color:var(--accent-blue);font-weight:500;margin-top:4px}@media (max-width:767px){.day-detail-modal{padding:80px 0 0 0}.modal-content{margin:0;border-radius:0;min-height:calc(100vh - 80px);padding:20px 16px;max-width:100%}.day-detail-header h2{font-size:24px}.day-detail-icon{font-size:48px}.day-detail-temp-high{font-size:28px}.day-detail-temp-low{font-size:22px}.day-detail-chart{padding:20px 12px;margin:20px -16px;border-radius:0;background:linear-gradient(135deg,rgba(255,149,0,.08) 0,rgba(255,149,0,.03) 100%);min-height:320px;overflow-x:auto;-webkit-overflow-scrolling:touch}.day-detail-chart svg{width:100%;min-width:100%;height:320px;min-height:320px}.day-detail-chart svg text{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.day-detail-hourly{grid-template-columns:repeat(8,1fr);gap:8px}.detail-hourly-item{padding:12px 8px}.detail-hourly-icon{font-size:28px;height:36px}}.additional-info-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:16px}.additional-info-grid .hourly-item{display:none!important}#hourlyForecast.hourly-container,.hourly-forecast #hourlyForecast,.hourly-forecast .hourly-container{display:flex!important;flex-direction:row!important}.additional-info-item{display:flex;align-items:center;gap:24px;padding:20px;background:var(--bg-secondary);border-radius:var(--radius-md);transition:all var(--transition);border:1px solid transparent}.additional-info-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-1);background:var(--bg-tertiary)}.additional-info-item.uv-item{background:var(--weather-sunny-light);border-color:rgba(255,152,0,.2)}.additional-info-item.astronomy-item{background:var(--weather-rainy-light);border-color:rgba(26,115,232,.2)}.additional-info-icon{font-size:32px;line-height:1;flex-shrink:0;width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.6);border-radius:10px}.additional-info-icon-img{width:64px;height:64px;max-width:64px;max-height:64px;object-fit:contain;display:block}.additional-info-content{flex:1;min-width:0}.additional-info-label{font-size:11px;color:var(--text-secondary);margin-bottom:6px;font-weight:400;text-transform:uppercase;letter-spacing:.5px}.additional-info-value{font-size:22px;font-weight:400;color:var(--text-primary);line-height:1.2;letter-spacing:-.3px;font-variant-numeric:tabular-nums}.additional-info-desc{font-size:11px;margin-top:4px;font-weight:400;opacity:.8}.wind-direction{font-size:18px;transition:transform var(--transition)}.cantons-section{margin-bottom:32px}.cantons-scroll-container{width:100%;overflow-x:auto;overflow-y:hidden;padding:8px 0;margin-top:16px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,0.2) transparent}.cantons-scroll-container::-webkit-scrollbar{height:6px}.cantons-scroll-container::-webkit-scrollbar-track{background:0 0}.cantons-scroll-container::-webkit-scrollbar-thumb{background:rgba(0,0,0,.2);border-radius:3px}.cantons-scroll{display:flex;gap:12px;padding:0 4px;min-width:max-content}.canton-card{background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 2px 6px rgba(0,0,0,.08);cursor:pointer;transition:all var(--transition);border:1px solid rgba(0,0,0,.06);flex-shrink:0;width:100px;min-height:120px;display:flex;flex-direction:column}.canton-card:hover{transform:translateY(-2px);box-shadow:0 4px 10px rgba(0,0,0,.12)}.canton-card:active{transform:translateY(0);box-shadow:0 2px 6px rgba(0,0,0,.08)}.canton-card:focus{outline:0}.canton-card:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.canton-banner{height:80px;min-height:80px;display:flex;align-items:center;justify-content:center;position:relative;background-size:contain;background-position:center 65%;background-repeat:no-repeat;width:100%;overflow:hidden;flex-shrink:0;margin-top:20px;padding-top:15px;padding-left:8px;padding-right:8px;padding-bottom:8px;box-sizing:border-box}.canton-code{font-size:18px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);letter-spacing:1px;z-index:1}.canton-info{padding:6px 4px;text-align:center;flex:1;display:flex;align-items:center;justify-content:center;min-height:32px}.canton-name{font-size:10px;font-weight:500;color:var(--text-primary);line-height:1.2}.canton-cities-section{margin-bottom:32px}.canton-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.canton-cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.canton-city-card{background:#fff;border-radius:var(--radius-lg);padding:20px;text-align:center;box-shadow:0 2px 8px rgba(0,0,0,.08);cursor:pointer;transition:all var(--transition);border:1px solid rgba(0,0,0,.06)}.canton-city-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.12)}.canton-city-icon{font-size:48px;margin-bottom:12px;line-height:1;display:flex;align-items:center;justify-content:center}.canton-city-icon .meteocon-icon{width:48px;height:48px;object-fit:contain;display:block}.canton-city-name{font-size:16px;font-weight:500;color:var(--text-primary);margin-bottom:12px}.canton-city-temps{display:flex;justify-content:center;align-items:center;gap:12px}.canton-city-temp-max{font-size:20px;font-weight:600;color:var(--text-primary)}.canton-city-temp-min{font-size:18px;font-weight:400;color:var(--text-secondary)}@media (max-width:767px){.header-top{flex-direction:row;align-items:center;justify-content:space-between}.header-actions{flex-direction:column;gap:8px}.search-container{max-width:100%;width:100%}.language-selector{justify-content:flex-end;margin-left:0;order:2}.lang-selector-btn{min-width:140px;padding:8px 14px;font-size:13px}.lang-dropdown{min-width:160px}.canton-cities-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.temperature{font-size:64px}.city-name{font-size:18px}.additional-info-grid{grid-template-columns:1fr;gap:12px}.additional-info-item{padding:16px}.additional-info-icon{font-size:28px;width:56px;height:56px}.additional-info-icon-img{width:56px;height:56px;max-width:56px;max-height:56px}.additional-info-value{font-size:20px}.air-quality-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))!important;grid-auto-flow:row!important;overflow-x:auto}}.wi{display:inline-block;font-style:normal;font-variant:normal;text-rendering:auto;line-height:1;font-family:weathericons}@keyframes sunRotate{from{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes cloudFloat{0%,100%{transform:translateX(0) translateY(0) scale(1)}25%{transform:translateX(4px) translateY(-3px) scale(1.02)}50%{transform:translateX(2px) translateY(-4px) scale(1.01)}75%{transform:translateX(-2px) translateY(-2px) scale(1.02)}}@keyframes cloudFloatMain{0%,100%{transform:translateX(0) translateY(0) scale(1)}25%{transform:translateX(6px) translateY(-4px) scale(1.03)}50%{transform:translateX(3px) translateY(-6px) scale(1.02)}75%{transform:translateX(-3px) translateY(-3px) scale(1.03)}}@keyframes rainFall{0%{transform:translateY(0);opacity:1}100%{transform:translateY(8px);opacity:.7}}@keyframes gentlePulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}@keyframes iconFadeIn{from{opacity:0;transform:scale(.8) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes lightning{0%,100%{opacity:1;filter:brightness(1)}50%{opacity:.8;filter:brightness(1.3)}}.weather-icon{animation:iconFadeIn .6s ease-out}.weather-icon .wi-day-sunny,.weather-icon .wi-day-sunny-overcast{animation:sunRotate 20s linear infinite;transform-origin:center}.weather-icon .wi-cloud,.weather-icon .wi-cloudy,.weather-icon .wi-day-cloudy,.weather-icon .wi-night-alt-cloudy{animation:cloudFloatMain 6s ease-in-out infinite;transform-origin:center}.weather-icon .wi-day-rain,.weather-icon .wi-night-alt-rain,.weather-icon .wi-rain,.weather-icon .wi-showers{animation:rainFall 1.5s ease-in-out infinite}.weather-icon .wi-thunderstorm{animation:lightning 2s ease-in-out infinite}.weather-icon .wi-snow,.weather-icon .wi-snowflake-cold{animation:gentlePulse 3s ease-in-out infinite}.hourly-icon{transition:transform .3s ease,opacity .3s ease;animation:iconFadeIn .4s ease-out backwards}.hourly-icon .weather-icon-img{transition:transform .3s ease,filter .3s ease;animation:iconFadeIn .4s ease-out backwards}.hourly-item:hover .hourly-icon{transform:scale(1.15) translateY(-2px)}.hourly-item:hover .hourly-icon .weather-icon-img{transform:scale(1.1);filter:drop-shadow(0 4px 8px rgba(0, 0, 0, .15))}.hourly-icon .weather-icon-img[alt*=clear-day],.hourly-icon .weather-icon-img[alt*=clear-night]{animation:iconFadeIn .4s ease-out backwards,sunRotate 20s linear infinite;animation-delay:0s,.5s;transform-origin:center}.hourly-icon .weather-icon-img[alt*=overcast],.hourly-icon .weather-icon-img[alt*=partly-cloudy]{animation:iconFadeIn .4s ease-out backwards,cloudFloat 4s ease-in-out infinite;animation-delay:0s,.5s}.hourly-icon .weather-icon-img[alt*=drizzle],.hourly-icon .weather-icon-img[alt*=rain]{animation:iconFadeIn .4s ease-out backwards,rainFall 1.5s ease-in-out infinite;animation-delay:0s,.5s}.hourly-icon .weather-icon-img[alt*=thunderstorm]{animation:iconFadeIn .4s ease-out backwards,lightning 2s ease-in-out infinite;animation-delay:0s,.5s}.hourly-icon .weather-icon-img[alt*=snow]{animation:iconFadeIn .4s ease-out backwards,gentlePulse 3s ease-in-out infinite;animation-delay:0s,.5s}.weekly-icon-afternoon,.weekly-icon-morning{transition:transform .3s ease;animation:iconFadeIn .5s ease-out backwards}.weekly-item:hover .weekly-icon-afternoon,.weekly-item:hover .weekly-icon-morning{transform:scale(1.1)}.weekly-item:hover .weekly-icon-afternoon .wi-day-sunny,.weekly-item:hover .weekly-icon-morning .wi-day-sunny{animation:sunRotate 18s linear infinite}.weather-background-icon{animation:gentlePulse 8s ease-in-out infinite;opacity:.15}.icon-emoji{display:inline-block;animation:iconFadeIn .6s ease-out .2s backwards}.canton-city-icon{transition:transform .3s ease,filter .3s ease;animation:iconFadeIn .4s ease-out backwards}.canton-city-card:hover .canton-city-icon{transform:scale(1.2) translateY(-3px);filter:brightness(1.1)}.metric-icon{transition:transform .3s ease;display:inline-block}.metric-item:hover .metric-icon{transform:scale(1.15) rotate(5deg)}.hourly-item{animation:iconFadeIn .4s ease-out backwards}.hourly-item:first-child{animation-delay:50ms}.hourly-item:nth-child(2){animation-delay:.1s}.hourly-item:nth-child(3){animation-delay:.15s}.hourly-item:nth-child(4){animation-delay:.2s}.hourly-item:nth-child(5){animation-delay:.25s}.hourly-item:nth-child(6){animation-delay:.3s}.hourly-item:nth-child(7){animation-delay:.35s}.hourly-item:nth-child(8){animation-delay:.4s}.weekly-item{animation:iconFadeIn .5s ease-out backwards}.weekly-item:first-child{animation-delay:.1s}.weekly-item:nth-child(2){animation-delay:.2s}.weekly-item:nth-child(3){animation-delay:.3s}.weekly-item:nth-child(4){animation-delay:.4s}.weekly-item:nth-child(5){animation-delay:.5s}.weekly-item:nth-child(6){animation-delay:.6s}.weekly-item:nth-child(7){animation-delay:.7s}.air-quality-icon{transition:transform .3s ease;display:inline-block}.air-quality-item:hover .air-quality-icon{transform:scale(1.1) rotate(-5deg)}@media (prefers-reduced-motion:reduce){*{animation-duration:0s!important;animation-iteration-count:1!important;transition-duration:0s!important}.weather-icon .wi-day-sunny,.weather-icon .wi-day-sunny-overcast{animation:none}.weather-icon .wi-cloud,.weather-icon .wi-cloudy{animation:none}.weather-icon .wi-day-rain,.weather-icon .wi-showers{animation:none}.weather-icon .wi-thunderstorm{animation:none}.weather-icon .wi-snow{animation:none}.weather-background-icon{animation:none}}.location-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px}.location-modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}.location-modal-content{position:relative;background:var(--bg-primary);border-radius:16px;padding:32px;max-width:400px;width:100%;box-shadow:var(--shadow-4);z-index:10001;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{from{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.location-modal-title{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:16px;text-align:center}.location-modal-message{font-size:16px;color:var(--text-secondary);margin-bottom:24px;text-align:center;line-height:1.5}.location-modal-city-name{display:block;font-size:20px;font-weight:600;color:var(--accent-blue);margin-top:8px}.location-modal-buttons{display:flex;gap:12px;justify-content:center}.location-modal-btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:120px}.location-modal-btn-confirm{background:var(--accent-blue);color:var(--text-inverse)}.location-modal-btn-confirm:hover{background:#1557b7;transform:translateY(-1px);box-shadow:var(--shadow-2)}.location-modal-btn-confirm:active{transform:translateY(0)}.location-modal-btn-cancel{background:var(--bg-tertiary);color:var(--text-primary)}.location-modal-btn-cancel:hover{background:#d0d3d6;transform:translateY(-1px);box-shadow:var(--shadow-2)}.location-modal-btn-cancel:active{transform:translateY(0)}@media (max-width:768px){.location-modal-content{padding:24px;max-width:90%}.location-modal-title{font-size:20px}.location-modal-message{font-size:14px}.location-modal-city-name{font-size:18px}.location-modal-buttons{flex-direction:column}.location-modal-btn{width:100%}}.weather-map-section{margin:40px 0;padding:20px 0;overflow:visible;position:relative}.weather-map-section h2{font-size:24px;font-weight:600;margin-bottom:20px;text-align:center;color:var(--text-primary)}.weather-map-container{width:100%;height:500px;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-2);background:var(--bg-secondary);position:relative}.weather-map-section{position:relative}.weather-map-container .leaflet-container{height:100%;width:100%;border-radius:12px;overflow:hidden}.weather-map-container .leaflet-popup-pane{overflow:visible!important}.weather-map-container .leaflet-map-pane{overflow:visible!important}.weather-map-container .leaflet-popup{z-index:1000}.weather-map-container .leaflet-popup-pane{z-index:1000}.weather-map-marker{background:0 0!important;border:none!important}.map-marker-content{display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(255,255,255,.95);border-radius:8px;padding:4px 8px;box-shadow:0 2px 8px rgba(0,0,0,.15);min-width:60px;transition:transform .2s ease,box-shadow .2s ease}.map-marker-content:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(0,0,0,.25)}.map-marker-icon{width:32px;height:32px;object-fit:contain}.map-marker-temp{font-size:12px;font-weight:600;color:var(--text-primary);margin-top:2px}.map-marker-city{font-size:10px;color:var(--text-secondary);margin-top:2px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.map-popup-content{text-align:center;padding:8px}.map-popup-content h3{font-size:16px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.map-popup-content p{font-size:14px;margin-bottom:12px;color:var(--text-secondary)}.map-popup-btn{background:var(--primary);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s ease,transform .1s ease}.map-popup-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.map-popup-btn:active{transform:translateY(0)}.map-custom-popup{position:absolute;top:0;left:0;z-index:1000;pointer-events:auto;animation:popupFadeIn .3s ease-out;width:400px;display:none}@keyframes popupFadeIn{from{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.map-popup-close{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.2);border:none;color:#fff;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.map-popup-close:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}.modern-map-popup{margin-top:-10px!important}.modern-map-popup .leaflet-popup-content-wrapper{border-radius:16px;box-shadow:0 8px 24px rgba(0,0,0,.15);padding:0;overflow:hidden;margin:0}.modern-map-popup .leaflet-popup-tip{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);box-shadow:0 2px 8px rgba(0,0,0,.15)}.modern-popup-content{padding:20px;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);color:#fff;min-width:380px}.modern-popup-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.modern-popup-icon{flex-shrink:0}.modern-popup-icon img{filter:drop-shadow(0 2px 8px rgba(0, 0, 0, .2))}.modern-popup-title{flex:1;text-align:left}.modern-popup-title h3{margin:0 0 4px 0;font-size:20px;font-weight:600;color:#fff}.modern-popup-temp{font-size:32px;font-weight:700;color:#fff;line-height:1}.modern-popup-temps{margin-bottom:16px}.temp-min-max{display:flex;gap:16px;justify-content:center;font-size:14px}.temp-max{color:#ffd93d;font-weight:600}.temp-min{color:#a8dadc;font-weight:600}.modern-popup-graph{background:rgba(255,255,255,.15);backdrop-filter:blur(10px);border-radius:12px;padding:16px;margin-bottom:16px}.graph-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;opacity:.9}.temp-graph{width:100%;height:auto}.temp-graph rect{transition:opacity .2s ease}.temp-graph rect:hover{opacity:1}.modern-popup-btn{width:100%;background:#fff;color:#667eea;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px rgba(0,0,0,.1)}.modern-popup-btn:hover{background:#f0f0f0;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.modern-popup-btn:active{transform:translateY(0)}.leaflet-popup-content-wrapper{border-radius:8px;box-shadow:var(--shadow-2)}.leaflet-popup-tip{background:#fff}@media (max-width:768px){.weather-map-section{margin:30px 0;padding:15px 0}.weather-map-section h2{font-size:20px;margin-bottom:15px}.weather-map-container{height:400px;border-radius:8px}.map-marker-content{min-width:50px;padding:3px 6px}.map-marker-icon{width:24px;height:24px}.map-marker-temp{font-size:10px}.map-marker-city{font-size:9px;max-width:60px}.map-custom-popup{width:calc(100vw - 40px)!important;max-width:340px!important;left:50%!important;top:50%!important;transform:translate(-50%,-50%)!important;animation:popupFadeInMobile .3s ease-out;position:fixed!important;margin:0!important}@keyframes popupFadeInMobile{from{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.modern-popup-content{padding:16px;min-width:auto}.modern-popup-icon img{width:48px;height:48px}.modern-popup-title h3{font-size:18px}.modern-popup-temp{font-size:28px}.modern-popup-graph{padding:12px;margin-bottom:12px}.graph-title{font-size:10px;margin-bottom:8px}.temp-graph{width:100%;height:130px;max-width:100%;overflow:visible}.temp-graph text{font-size:7px!important}.temp-graph text[fill="#666"]{font-size:8px!important}.modern-popup-btn{width:100%;padding:10px 20px;font-size:13px}}.breadcrumbs{margin:16px 0 24px 0;padding:0}.breadcrumb-list{display:flex;flex-wrap:wrap;align-items:center;list-style:none;margin:0;padding:0;gap:4px}.breadcrumb-item{display:flex;align-items:center;font-size:14px;color:var(--text-secondary)}.breadcrumb-separator{margin:0 8px;color:var(--text-tertiary)}.breadcrumb-link{color:var(--accent-blue);text-decoration:none;transition:color var(--transition)}.breadcrumb-link:hover{color:var(--accent-blue);text-decoration:underline}.breadcrumb-current .breadcrumb-text{color:var(--text-primary);font-weight:500}.skeleton-screen{padding:20px}.skeleton-line{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px;margin-bottom:12px;height:20px}.skeleton-title{width:60%;height:24px}.skeleton-text{width:100%}.skeleton-text.short{width:80%}@keyframes skeleton-loading{0%{background-position:200% 0}100%{background-position:-200% 0}}.share-section{margin:32px 0;padding:24px;background:var(--bg-secondary);border-radius:var(--radius-lg)}.share-section h2{margin-bottom:16px;font-size:18px;font-weight:600;color:var(--text-primary)}.share-buttons{display:flex;gap:12px;flex-wrap:wrap;width:100%}.share-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 24px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:16px;font-weight:500;cursor:pointer;transition:all var(--transition);flex:1;min-width:0}.share-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}.share-btn:active{transform:translateY(0)}.share-facebook:hover{background:#1877f2;color:#fff;border-color:#1877f2}.share-twitter:hover{background:#1da1f2;color:#fff;border-color:#1da1f2}.share-whatsapp:hover{background:#25d366;color:#fff;border-color:#25d366}.share-instagram:hover{background:linear-gradient(45deg,#f09433 0,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);color:#fff;border-color:#bc1888}.share-tiktok:hover{background:#000;color:#fff;border-color:#000}.share-btn svg{width:24px;height:24px;flex-shrink:0}.air-quality-explanation{margin-top:20px;padding:16px;background:var(--bg-secondary);border-radius:var(--radius-md);border-left:4px solid var(--accent-blue)}.air-quality-risk-explanation{font-size:14px;line-height:1.6;color:var(--text-primary)}.air-quality-risk-explanation strong{color:var(--accent-blue);font-weight:600}.editorial-content{margin:32px 0;display:grid;gap:24px}.editorial-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-1);border:1px solid rgba(0,0,0,.06);transition:all var(--transition)}.editorial-card:empty,.editorial-card[style*="display: none"]{display:none!important}.editorial-card h3:empty,.editorial-card h3:empty+p:empty,.editorial-card p:empty{display:none}.editorial-card:has(h3:empty):has(p:empty){display:none!important}.editorial-card:hover{box-shadow:var(--shadow-2);transform:translateY(-2px)}.editorial-card h3{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.editorial-card p{font-size:15px;line-height:1.7;color:var(--text-secondary)}.nearby-cities-section,.same-canton-section{margin:32px 0}.nearby-cities-section h2,.same-canton-section h2{margin-bottom:16px;font-size:20px;font-weight:600;color:var(--text-primary)}.nearby-cities-grid,.same-canton-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;max-width:100%;justify-items:center}.nearby-city-card,.same-canton-city-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px;cursor:pointer;transition:all var(--transition);text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:200px}.nearby-city-card:hover,.same-canton-city-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-2);border-color:var(--accent-blue)}.nearby-city-card:active,.same-canton-city-card:active{transform:translateY(0)}.nearby-city-icon,.same-canton-city-icon{width:80px;height:80px;margin-bottom:12px;display:flex;align-items:center;justify-content:center}.nearby-city-weather-icon,.same-canton-city-weather-icon{width:100%;height:100%;object-fit:contain}.nearby-city-info,.same-canton-city-info{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%}.nearby-city-name,.same-canton-city-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.nearby-city-temp,.same-canton-city-temp{font-size:24px;font-weight:700;color:var(--accent-blue);margin-bottom:4px}.nearby-city-distance{font-size:13px;color:var(--text-secondary);margin-top:4px}.nearby-city-loading,.same-canton-city-loading{font-size:14px;color:var(--text-secondary);padding:20px}@media (max-width:768px){.share-buttons{flex-direction:column;gap:10px}.share-btn{width:100%;justify-content:center;padding:14px 20px;font-size:15px}.share-btn svg{width:22px;height:22px}.nearby-cities-grid,.same-canton-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;justify-items:center}.nearby-city-card,.same-canton-city-card{padding:16px;max-width:160px}.nearby-city-icon,.same-canton-city-icon{width:60px;height:60px;margin-bottom:10px}.nearby-city-name,.same-canton-city-name{font-size:14px}.nearby-city-temp,.same-canton-city-temp{font-size:20px}.nearby-city-distance{font-size:12px}.breadcrumbs{margin:12px 0 16px 0}.breadcrumb-item{font-size:12px}.breadcrumb-separator{margin:0 6px}.hourly-container{-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}.hourly-item{scroll-snap-align:start}.footer-content{flex-direction:column;align-items:center;text-align:center;gap:30px}.footer-section{width:100%;max-width:300px}.footer-section ul{display:flex;flex-direction:column;align-items:center}.footer-section ul li{text-align:center}.footer-section h3{text-align:center}.footer-section p{text-align:center}}.weather-alert-banner{position:sticky;top:0;z-index:1000;background:rgba(220,38,38,.85);backdrop-filter:blur(10px);border-bottom:2px solid rgba(220,38,38,.3);padding:12px 20px;margin-bottom:20px;box-shadow:0 4px 12px rgba(220,38,38,.2)}.alert-banner-content{display:flex;align-items:center;gap:12px;max-width:1200px;margin:0 auto}.alert-banner-icon{font-size:24px;flex-shrink:0}.alert-banner-text{flex:1;color:#fff;font-weight:600}#alertBannerTitle{display:block;margin-bottom:8px;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.alert-cities-scroll{display:flex;gap:24px;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.alert-cities-scroll::-webkit-scrollbar{display:none}.alert-city-item{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);padding:6px 12px;border-radius:20px;white-space:nowrap;font-size:13px;backdrop-filter:blur(5px);flex-shrink:0}.alert-city-item img{width:20px;height:20px;object-fit:contain}.alert-city-temp{font-weight:700;font-size:14px}.report-weather-section{margin:20px 0;text-align:right;position:relative}.report-weather-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--bg-secondary);border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-1)}.report-weather-btn:hover{background:var(--bg-primary);color:var(--text-primary);border-color:var(--accent-blue);box-shadow:var(--shadow-2)}.report-weather-btn:active{transform:scale(.98)}.report-weather-btn span:first-child{font-size:16px;filter:grayscale(.3)}.report-weather-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10005;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}.report-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}.report-modal-content{position:relative;background:var(--bg-primary);border-radius:var(--radius-lg);padding:32px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-3);z-index:1;border:1px solid rgba(0,0,0,.06)}.report-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:var(--bg-secondary);border-radius:50%;font-size:24px;line-height:1;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.report-modal-close:hover{background:var(--accent-blue);color:#fff;transform:rotate(90deg)}.report-modal-content h2{font-size:24px;margin-bottom:24px;color:var(--text-primary)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:15px;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:0;border-color:var(--accent-blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}.form-group input[readonly]{background:var(--bg-secondary);cursor:not-allowed}.report-submit-btn{width:100%;padding:14px;background:#dc2626;color:#fff;border:2px solid #dc2626;border-radius:var(--radius-md);font-size:16px;font-weight:600;cursor:pointer;transition:all var(--transition);margin-top:8px}.report-submit-btn:hover{background:#b91c1c;border-color:#b91c1c;transform:translateY(-2px);box-shadow:var(--shadow-2)}.report-submit-btn:active{transform:translateY(0)}.report-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width:768px){.weather-alert-banner{padding:10px 12px;margin-bottom:15px}.alert-banner-content{flex-direction:column;gap:8px;align-items:flex-start}.alert-banner-icon{font-size:18px}.alert-banner-text{width:100%}#alertBannerTitle{font-size:11px;margin-bottom:6px}.alert-cities-scroll{gap:12px;padding:4px 0}.alert-city-item{padding:6px 10px;font-size:11px;gap:6px;border-radius:16px}.alert-city-item img{width:16px;height:16px}.alert-city-temp{font-size:12px}.report-weather-section{margin:15px 0;text-align:center}.report-weather-btn{padding:10px 18px;font-size:13px;width:auto;max-width:100%}.report-weather-btn span:first-child{font-size:15px}.report-modal-content{padding:24px 16px;width:95%;max-height:calc(100vh - 100px);margin:0}.report-weather-modal{padding:80px 16px 20px;align-items:flex-start;overflow-y:auto}.report-modal-close{top:12px;right:12px;width:28px;height:28px;font-size:20px}.report-modal-content h2{font-size:18px;margin-bottom:20px;padding-right:30px}.form-group{margin-bottom:16px}.form-group label{font-size:13px;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{padding:10px;font-size:14px}.report-submit-btn{padding:12px;font-size:15px;margin-top:8px}.report-weather-modal{padding:80px 16px 20px;align-items:flex-start;overflow-y:auto}.report-modal-content{margin-top:0;max-height:calc(100vh - 100px)}}.weather-alert-banner{position:sticky;top:0;z-index:1000;background:rgba(220,38,38,.85);backdrop-filter:blur(10px);border-bottom:2px solid rgba(220,38,38,.3);padding:12px 20px;margin-bottom:20px;box-shadow:0 4px 12px rgba(220,38,38,.2)}.alert-banner-content{display:flex;align-items:center;gap:12px;max-width:1200px;margin:0 auto}.alert-banner-icon{font-size:24px;flex-shrink:0}.alert-banner-text{flex:1;color:#fff;font-weight:600}#alertBannerTitle{display:block;margin-bottom:8px;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.alert-cities-scroll{display:flex;gap:24px;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.alert-cities-scroll::-webkit-scrollbar{display:none}.alert-city-item{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);padding:6px 12px;border-radius:20px;white-space:nowrap;font-size:13px;backdrop-filter:blur(5px);flex-shrink:0}.alert-city-item img{width:20px;height:20px;object-fit:contain}.alert-city-temp{font-weight:700;font-size:14px}.report-weather-section{margin:20px 0;text-align:right;position:relative}.report-weather-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--bg-secondary);border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-1)}.report-weather-btn:hover{background:var(--bg-primary);color:var(--text-primary);border-color:var(--accent-blue);box-shadow:var(--shadow-2)}.report-weather-btn:active{transform:scale(.98)}.report-weather-btn span:first-child{font-size:16px;filter:grayscale(.3)}.report-weather-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10005;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}.report-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}.report-modal-content{position:relative;background:var(--bg-primary);border-radius:var(--radius-lg);padding:32px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-3);z-index:1;border:1px solid rgba(0,0,0,.06)}.report-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:var(--bg-secondary);border-radius:50%;font-size:24px;line-height:1;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.report-modal-close:hover{background:var(--accent-blue);color:#fff;transform:rotate(90deg)}.report-modal-content h2{font-size:24px;margin-bottom:24px;color:var(--text-primary)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:15px;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:0;border-color:var(--accent-blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}.form-group input[readonly]{background:var(--bg-secondary);cursor:not-allowed}.report-submit-btn{width:100%;padding:14px;background:#dc2626;color:#fff;border:2px solid #dc2626;border-radius:var(--radius-md);font-size:16px;font-weight:600;cursor:pointer;transition:all var(--transition);margin-top:8px}.report-submit-btn:hover{background:#b91c1c;border-color:#b91c1c;transform:translateY(-2px);box-shadow:var(--shadow-2)}.report-submit-btn:active{transform:translateY(0)}.report-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width:768px){.weather-alert-banner{padding:10px 12px;margin-bottom:15px}.alert-banner-content{flex-direction:column;gap:8px;align-items:flex-start}.alert-banner-icon{font-size:18px}.alert-banner-text{width:100%}#alertBannerTitle{font-size:11px;margin-bottom:6px}.alert-cities-scroll{gap:12px;padding:4px 0}.alert-city-item{padding:6px 10px;font-size:11px;gap:6px;border-radius:16px}.alert-city-item img{width:16px;height:16px}.alert-city-temp{font-size:12px}.report-weather-section{margin:15px 0;text-align:center}.report-weather-btn{padding:10px 18px;font-size:13px;width:auto;max-width:100%}.report-weather-btn span:first-child{font-size:15px}.report-modal-content{padding:24px 16px;width:95%;max-height:calc(100vh - 100px);margin:0}.report-weather-modal{padding:80px 16px 20px;align-items:flex-start;overflow-y:auto}.report-modal-close{top:12px;right:12px;width:28px;height:28px;font-size:20px}.report-modal-content h2{font-size:18px;margin-bottom:20px;padding-right:30px}.form-group{margin-bottom:16px}.form-group label{font-size:13px;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{padding:10px;font-size:14px}.report-submit-btn{padding:12px;font-size:15px;margin-top:8px}}.golden-hour-section{margin-bottom:24px;padding:20px;background:linear-gradient(135deg,rgba(255,248,220,.25) 0,rgba(255,240,200,.25) 100%);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);border:1px solid rgba(255,215,0,.12)}.golden-hour-section h2{font-size:20px;font-weight:400;color:var(--text-primary);margin-bottom:16px;letter-spacing:0;padding:0 4px;text-align:left}.golden-hour-content{margin-bottom:20px}.golden-hour-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.golden-hour-card{background:var(--bg-primary);border-radius:var(--radius-md);padding:20px;text-align:center;box-shadow:var(--shadow-1);border:2px solid rgba(255,215,0,.3);transition:all var(--transition);position:relative}.golden-hour-card.active{border-color:rgba(255,165,0,.6);background:linear-gradient(135deg,rgba(255,215,0,.15) 0,rgba(255,165,0,.15) 100%);box-shadow:var(--shadow-2);transform:translateY(-2px)}.golden-hour-icon{display:flex;align-items:center;justify-content:center;margin-bottom:12px;width:64px;height:64px;margin:0 auto 12px}.golden-hour-icon-img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0, 0, 0, .1))}.golden-hour-label{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.golden-hour-time{font-size:20px;font-weight:700;color:var(--accent-blue);margin-bottom:8px}.golden-hour-badge{display:inline-block;background:rgba(255,165,0,.9);color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;margin-top:8px;text-transform:uppercase;letter-spacing:.5px}.golden-hour-info{display:flex;align-items:flex-start;gap:12px;padding:16px;background:var(--bg-secondary);border-radius:var(--radius-md);border-left:4px solid rgba(255,215,0,.6);margin-top:16px}.golden-hour-info .info-icon{font-size:24px;flex-shrink:0}.golden-hour-info p{font-size:14px;line-height:1.7;color:var(--text-secondary);margin:0}@media (max-width:768px){.golden-hour-section{padding:20px 16px}.golden-hour-section h2{font-size:20px;margin-bottom:16px}.golden-hour-cards{grid-template-columns:1fr;gap:16px}.golden-hour-card{padding:16px}.golden-hour-icon{width:56px;height:56px;margin-bottom:10px}.golden-hour-icon-img{width:100%;height:100%}.golden-hour-time{font-size:18px}}.intro-section{margin:32px 0;padding:24px;background:var(--bg-secondary);border-radius:var(--radius-lg);border-left:4px solid var(--accent-blue)}.intro-content h1{font-size:28px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.intro-text{font-size:16px;line-height:1.8;color:var(--text-secondary);margin:0}.featured-news-section{margin:32px 0}.featured-news-section h2{font-size:20px;font-weight:400;color:var(--text-primary);margin-bottom:20px;letter-spacing:0;padding:0 4px}.featured-news-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.featured-news-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-1);border:1px solid rgba(0,0,0,.06);transition:all var(--transition)}.featured-news-card:hover{box-shadow:var(--shadow-2);transform:translateY(-2px)}.featured-news-icon{font-size:32px;margin-bottom:12px}.featured-news-card h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.featured-news-card p{font-size:14px;line-height:1.7;color:var(--text-secondary);margin-bottom:16px}.featured-news-link{display:inline-block;color:var(--accent-blue);text-decoration:none;font-weight:500;font-size:14px;transition:all var(--transition)}.featured-news-link:hover{color:var(--accent-blue-dark);text-decoration:underline}@media (max-width:768px){.intro-section{padding:20px 16px}.intro-content h1{font-size:24px}.intro-text{font-size:15px}.featured-news-content{grid-template-columns:1fr;gap:16px}.featured-news-card{padding:20px}}.main-nav{position:relative;display:inline-block;z-index:101}.nav-menu-toggle{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-primary);border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-md);font-size:15px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-1);position:relative;z-index:1}.nav-menu-toggle:hover{background:var(--bg-secondary);box-shadow:var(--shadow-2);transform:translateY(-1px)}.nav-menu-toggle:active{transform:translateY(0)}.nav-menu-icon{width:20px;height:2px;position:relative;background:var(--text-primary);border-radius:2px;transition:all var(--transition)}.nav-menu-icon::before{content:'';position:absolute;top:-6px;left:0;width:100%;height:2px;background:var(--text-primary);border-radius:2px;transition:all var(--transition)}.nav-menu-icon::after{content:'';position:absolute;bottom:-6px;left:0;width:100%;height:2px;background:var(--text-primary);border-radius:2px;transition:all var(--transition)}.nav-menu-toggle[aria-expanded=true] .nav-menu-icon{background:0 0}.nav-menu-toggle[aria-expanded=true] .nav-menu-icon::before{top:0;transform:rotate(45deg)}.nav-menu-toggle[aria-expanded=true] .nav-menu-icon::after{bottom:0;transform:rotate(-45deg)}.nav-menu-text{font-weight:500}.nav-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);border:1px solid rgba(0,0,0,.08);min-width:220px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition);z-index:10100;overflow:hidden;display:block!important;pointer-events:none}.nav-menu-dropdown.nav-menu-open{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.nav-menu-item{display:flex;align-items:center;gap:12px;padding:14px 20px;color:var(--text-primary);text-decoration:none;transition:all var(--transition);border-bottom:1px solid rgba(0,0,0,.05)}.nav-menu-item:last-child{border-bottom:none}.nav-menu-item:hover{background:var(--bg-secondary);color:var(--accent-blue)}.nav-menu-item:active{background:var(--bg-tertiary)}.nav-menu-icon-item{font-size:18px;width:24px;text-align:center;flex-shrink:0}.nav-menu-label{font-size:15px;font-weight:500}@media (max-width:768px){header{padding:10px 0}.site-logo{height:70px!important}.header-top{flex-direction:column;align-items:stretch;gap:2px}.header-left{gap:4px}.header-right{gap:8px}.header-left{justify-content:space-between}.header-right{justify-content:space-between;width:100%}.nav-menu-dropdown{right:auto;left:0;min-width:100%}.nav-menu-toggle{flex:1;justify-content:center}.header-right .language-selector-custom{flex:1}.lang-selector-btn{width:100%}.lang-dropdown{right:auto;left:0;min-width:100%}}.temp-unit-toggle{display:flex;justify-content:center;align-items:center;gap:0;margin:-10px auto 20px;padding:4px;background:var(--bg-secondary);border-radius:var(--radius-lg);width:fit-content;box-shadow:var(--shadow-1)}.temp-unit-btn{padding:8px 20px;background:0 0;border:none;border-radius:var(--radius-md);font-size:16px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);min-width:60px}.temp-unit-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.temp-unit-btn.active{background:var(--accent-blue);color:#fff;box-shadow:var(--shadow-2)}.current-weather-enhanced{display:flex;flex-direction:column;gap:20px;padding:30px;background:linear-gradient(135deg,var(--bg-primary) 0,var(--bg-secondary) 100%);border-radius:var(--radius-xl);box-shadow:var(--shadow-3);margin-bottom:30px}.current-weather-main{display:flex;align-items:center;justify-content:space-between;gap:30px}.current-weather-left{display:flex;flex-direction:column;align-items:center;gap:15px;flex:1;text-align:center}.current-weather-icon-large{width:150px;height:150px;flex-shrink:0;order:-1}.current-weather-icon-large img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0, 0, 0, .1))}.current-weather-temp-section{display:flex;flex-direction:column;gap:8px;align-items:center}.current-temp-display{display:flex;align-items:baseline;gap:8px;justify-content:center}.current-temp-value{font-size:72px;font-weight:700;line-height:1;color:var(--text-primary);letter-spacing:-2px}.current-temp-unit{font-size:32px;font-weight:400;color:var(--text-secondary)}.current-weather-description{font-size:20px;color:var(--text-secondary);font-weight:500}.current-weather-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;padding:20px;background:rgba(255,255,255,.5);border-radius:var(--radius-lg)}.current-metric-item{display:flex;flex-direction:row;align-items:center;gap:12px;padding:15px;border-radius:var(--radius-md);background:rgba(255,255,255,.6);transition:all var(--transition);min-height:120px}.current-metric-item:hover{background:rgba(255,255,255,.7);transform:translateY(-2px)}.current-metric-icon{width:90px;height:90px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:visible}.current-metric-icon img{width:100%;height:100%;object-fit:contain;filter:opacity(.8);max-width:none}.current-metric-content{display:flex;flex-direction:column;gap:2px;flex:1}.current-metric-label{font-size:11px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px;line-height:1}.current-metric-value{font-size:18px;font-weight:700;color:var(--text-primary);line-height:1.2}.forecast-tabs{display:flex;gap:8px;margin-bottom:20px;padding:8px;background:var(--bg-secondary);border-radius:var(--radius-lg);overflow-x:auto;scrollbar-width:thin}.forecast-tabs::-webkit-scrollbar{height:6px}.forecast-tabs::-webkit-scrollbar-track{background:0 0}.forecast-tabs::-webkit-scrollbar-thumb{background:var(--accent-blue);border-radius:3px}.forecast-tab{display:flex;align-items:center;gap:8px;padding:12px 20px;background:0 0;border:none;border-radius:var(--radius-md);font-size:15px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap;flex-shrink:0}.forecast-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.forecast-tab.active{background:var(--accent-blue);color:#fff;box-shadow:var(--shadow-2)}.tab-icon{font-size:20px}.tab-label{font-size:15px}.forecast-tab-content{display:none;animation:fadeIn .3s ease-in-out}.forecast-tab-content.active{display:block}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chart-container{position:relative;width:100%;height:400px;padding:20px;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-2);margin-bottom:20px}.chart-legend{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;padding:15px;background:var(--bg-secondary);border-radius:var(--radius-md)}.chart-legend-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.chart-legend-color{width:16px;height:16px;border-radius:4px}.hourly-card-enhanced{position:relative;padding:20px;background:linear-gradient(135deg,var(--bg-primary) 0,var(--bg-secondary) 100%);border-radius:var(--radius-lg);box-shadow:var(--shadow-2);transition:all var(--transition);min-width:140px}.hourly-card-enhanced:hover{transform:translateY(-4px);box-shadow:var(--shadow-3)}.hourly-card-enhanced.current{background:linear-gradient(135deg,var(--accent-blue) 0,#1e40af 100%);color:#fff;box-shadow:0 8px 24px rgba(37,99,235,.4)}.hourly-card-enhanced.current *{color:#fff!important}.hourly-time-enhanced{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:12px;text-align:center}.hourly-icon-enhanced{width:60px;height:60px;margin:12px auto;display:flex;align-items:center;justify-content:center}.hourly-temp-enhanced{font-size:24px;font-weight:700;text-align:center;margin-bottom:8px;color:var(--text-primary)}.hourly-details-enhanced{display:flex;flex-direction:column;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(0,0,0,.1)}.hourly-detail-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}.hourly-detail-label{color:var(--text-secondary);font-weight:500}.hourly-detail-value{color:var(--text-primary);font-weight:600}@media (max-width:768px){.current-weather-main{flex-direction:column;gap:20px}.current-weather-left{flex-direction:column;text-align:center}.current-weather-icon-large{width:110px;height:110px}.current-temp-value{font-size:56px}.current-temp-unit{font-size:24px}.current-weather-description{font-size:18px}.current-weather-metrics{grid-template-columns:repeat(2,1fr);gap:12px;padding:16px}.current-metric-item{gap:10px;padding:12px;min-height:100px}.current-metric-icon{width:70px;height:70px}.current-metric-label{font-size:10px}.current-metric-value{font-size:15px}.forecast-tabs{gap:4px;padding:4px}.forecast-tab{padding:10px 14px;font-size:13px}.tab-icon{font-size:16px}.tab-label{display:none}.forecast-tab.active .tab-label{display:inline}.chart-container{height:300px;padding:15px}.hourly-card-enhanced{min-width:110px;padding:15px}.hourly-icon-enhanced{width:48px;height:48px}.hourly-temp-enhanced{font-size:20px}}@media (max-width:480px){.current-temp-value{font-size:48px}.current-temp-unit{font-size:20px}.current-weather-metrics{grid-template-columns:repeat(2,1fr);gap:10px;padding:12px}.current-metric-item{justify-content:flex-start;padding:10px;min-height:90px;flex-direction:column;align-items:center;text-align:center}.current-metric-content{align-items:center}.current-metric-icon{width:55px;height:55px}.current-metric-label{font-size:9px}.current-metric-value{font-size:14px}.temp-unit-toggle{margin-top:10px}.temp-unit-btn{padding:6px 16px;font-size:14px}.forecast-tab{padding:8px 10px;font-size:12px}.tab-icon{font-size:14px}.chart-container{height:250px;padding:10px}.hourly-card-enhanced{min-width:90px;padding:12px 8px}}@media (max-width:375px){body{font-size:14px}.container{padding:0 12px}.current-temp-value{font-size:40px}.current-temp-unit{font-size:18px}.current-weather-icon-large{width:80px;height:80px}.current-weather-description{font-size:16px}.current-weather-metrics{grid-template-columns:repeat(2,1fr);gap:8px}.current-metric-item{min-height:85px;padding:8px}.current-metric-icon{width:48px;height:48px}.current-metric-label{font-size:9px}.current-metric-value{font-size:13px}.forecast-tab{padding:6px 8px;font-size:11px;min-width:auto}.tab-icon{font-size:12px}.chart-container{height:220px;padding:8px}.hourly-card-enhanced{min-width:80px;padding:10px 6px}.hourly-icon-enhanced{width:40px;height:40px}.hourly-temp-enhanced{font-size:18px}h1{font-size:24px}h2{font-size:20px}}@media (min-width:768px) and (max-width:1024px){.current-weather-metrics{grid-template-columns:repeat(2,1fr);gap:18px;padding:24px}.current-metric-item{min-height:110px;padding:16px}.current-metric-icon{width:85px;height:85px}.current-metric-label{font-size:12px}.current-metric-value{font-size:18px}.chart-container{height:350px}.hourly-card-enhanced{min-width:120px}}*{box-sizing:border-box}img{max-width:100%;height:auto}.current-metric-label,.current-weather-description,.hourly-temp-enhanced{overflow:hidden;text-overflow:ellipsis;word-wrap:break-word}.chart-container canvas{max-width:100%!important;height:auto!important}body{max-width:100vw;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.header-right,.header-top,header,header .container{overflow:visible!important}main .container,section{max-width:100%;overflow-x:hidden}.container{max-width:100%}@media (max-width:768px){.weekly-item{padding:12px;font-size:14px}.weekly-day{font-size:14px;min-width:70px}.weekly-temp{font-size:15px}.weekly-temp-high{font-size:16px}.weekly-temp-low{font-size:14px}.additional-info,.air-quality,.golden-hour-section,.intro-section{padding:16px;margin:20px 0}.aqi-value{font-size:32px}.aqi-label{font-size:14px}.additional-info-grid{grid-template-columns:1fr;gap:12px}.additional-info-item{padding:12px}.golden-hour-times{flex-direction:column;gap:12px}.modal-content{width:95%;max-width:95%;padding:20px;margin:10px}.day-detail-modal .modal-content{width:100%;max-width:100%;margin:0;border-radius:0}header{padding:12px 0}.header-left h1{font-size:20px}.header-right{gap:8px}input[type=email],input[type=text],select,textarea{font-size:16px;padding:10px}button{min-height:44px;padding:10px 16px}.search-btn{padding:10px 16px;font-size:14px}.lang-selector-btn{padding:10px 14px;font-size:14px}.lang-option{padding:10px 14px}}@media (max-width:480px){.weekly-item{padding:10px;font-size:13px;gap:8px}.weekly-day{font-size:13px;min-width:60px}.weekly-icon-afternoon,.weekly-icon-morning{width:20px!important;height:20px!important}.weekly-temp-high{font-size:15px}.weekly-temp-low{font-size:13px}.aqi-value{font-size:28px}.additional-info,.air-quality,.golden-hour-section{padding:12px;margin:15px 0}h2{font-size:18px}.header-left h1{font-size:18px}.search-btn{padding:8px 12px;font-size:13px}.lang-selector-btn{padding:8px 12px;font-size:13px;min-width:130px}.lang-current-flag{font-size:16px}.lang-option{padding:10px 12px}}@media (max-width:375px){.weekly-item{padding:8px;font-size:12px;gap:6px}.weekly-day{font-size:12px;min-width:55px}.weekly-temp{font-size:13px}.weekly-temp-high{font-size:14px}.weekly-temp-low{font-size:12px}.additional-info,.air-quality,.golden-hour-section,.intro-section{padding:10px;margin:12px 0}.aqi-value{font-size:24px}.additional-info-item{padding:8px}.header-left h1{font-size:16px}.site-logo{height:80px;width:auto}}@media (min-width:768px) and (max-width:1024px){.weekly-item{padding:16px}.weekly-temp-high{font-size:18px}.additional-info-grid{grid-template-columns:repeat(2,1fr)}.golden-hour-times{flex-direction:row}}@media (min-width:1024px) and (max-width:1366px){.container{padding:0 40px}.current-weather-metrics{grid-template-columns:repeat(2,1fr)}.current-metric-item{min-height:115px}}@media (max-width:768px) and (orientation:landscape){.current-weather-main{flex-direction:row}.current-weather-metrics{grid-template-columns:repeat(2,1fr)}.chart-container{height:280px}}.netatmo-section{background:var(--bg-primary);border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:var(--shadow-2)}.netatmo-section .section-header{margin-bottom:20px}.netatmo-section h2{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 8px 0}.netatmo-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.netatmo-filters{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.netatmo-filter-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:2px solid rgba(0,0,0,.1);border-radius:12px;background:#fff;font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.netatmo-filter-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue);transform:translateY(-2px)}.netatmo-filter-btn.active{border-color:var(--accent-blue);background:var(--accent-blue);color:#fff}.netatmo-filter-btn .filter-icon{font-size:18px}.netatmo-refresh-btn{padding:10px 16px;border:2px solid rgba(0,0,0,.1);border-radius:12px;background:#fff;font-size:18px;cursor:pointer;transition:all .2s ease;margin-left:auto}.netatmo-refresh-btn:hover{transform:rotate(180deg);border-color:var(--accent-blue)}.netatmo-refresh-btn:active{transform:rotate(360deg)}.netatmo-map-container{position:relative;width:100%;height:500px;border-radius:12px;overflow:hidden;margin-bottom:20px;background:#f0f0f0}.netatmo-map{width:100%;height:100%;z-index:1}.netatmo-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(255,255,255,.95);z-index:10}.netatmo-loading .spinner{width:48px;height:48px;border:4px solid rgba(0,0,0,.1);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.netatmo-loading p{margin-top:16px;font-size:14px;color:var(--text-secondary)}.netatmo-no-data{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;font-size:16px;color:var(--text-secondary);z-index:10}.netatmo-info{margin-top:16px}.netatmo-disclaimer{font-size:13px;color:var(--text-secondary);line-height:1.6;margin:0 0 12px 0;padding:12px;background:rgba(59,130,246,.05);border-radius:8px;border-left:3px solid var(--accent-blue)}.netatmo-stats{display:flex;gap:16px;flex-wrap:wrap}.netatmo-stat{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border-radius:8px;box-shadow:var(--shadow-1);font-size:14px}.netatmo-stat .stat-icon{font-size:20px}.netatmo-stat .stat-value{font-weight:700;color:var(--text-primary)}.netatmo-stat .stat-label{color:var(--text-secondary);font-size:12px}.leaflet-popup-content-wrapper{border-radius:12px;padding:0}.netatmo-popup{padding:16px;min-width:200px}.netatmo-popup-title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0 0 12px 0}.netatmo-popup-data{display:flex;flex-direction:column;gap:8px}.netatmo-popup-item{display:flex;justify-content:space-between;align-items:center;font-size:14px}.netatmo-popup-label{color:var(--text-secondary);display:flex;align-items:center;gap:6px}.netatmo-popup-value{font-weight:700;color:var(--text-primary)}.netatmo-popup-timestamp{font-size:12px;color:var(--text-secondary);margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.1);text-align:center}.netatmo-popup-badge{display:inline-block;padding:4px 8px;background:var(--accent-blue);color:#fff;border-radius:6px;font-size:11px;font-weight:600;margin-top:8px}.netatmo-marker{background:#fff;border:3px solid var(--accent-blue);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--text-primary);box-shadow:0 2px 8px rgba(0,0,0,.2)}.netatmo-marker.hot{border-color:#ef4444;color:#ef4444}.netatmo-marker.warm{border-color:#f97316;color:#f97316}.netatmo-marker.mild{border-color:#10b981;color:#10b981}.netatmo-marker.cool{border-color:#3b82f6;color:#3b82f6}.netatmo-marker.cold{border-color:#8b5cf6;color:#8b5cf6}@media (max-width:768px){.netatmo-section{padding:16px}.netatmo-filters{gap:8px}.netatmo-filter-btn{padding:8px 12px;font-size:13px}.netatmo-refresh-btn{padding:8px 12px}.netatmo-map-container{height:400px}.netatmo-stats{gap:8px}.netatmo-stat{flex:1 1 calc(50% - 8px);font-size:13px}}@media (max-width:480px){.netatmo-section h2{font-size:20px}.netatmo-filter-btn .filter-label{display:none}.netatmo-filter-btn{padding:8px;min-width:40px;justify-content:center}.netatmo-map-container{height:350px}.netatmo-stat{flex:1 1 100%}}.city-seo-section{background:linear-gradient(180deg,#f8fafc 0,#eef2f7 100%);border-top:1px solid #e5e7eb;padding:48px 0 56px;margin-top:40px}.city-seo-section .container{max-width:1080px;margin:0 auto;padding:0 20px}.city-context{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,sans-serif;color:#1f2937;line-height:1.7}.city-context h2{font-size:1.55rem;font-weight:700;color:#111827;margin:32px 0 14px;letter-spacing:-.01em;border-left:4px solid #2563eb;padding-left:12px}.city-context h2:first-child{margin-top:0}.city-context p{margin:0 0 14px;font-size:1rem;color:#374151}.city-context strong{color:#111827}.city-context em{font-style:normal;color:#2563eb;background:#dbeafe;padding:1px 6px;border-radius:4px;font-size:.92em}.city-seo-section ul.nearby-cities-grid{list-style:none;padding:0;margin:14px 0 24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.city-seo-section ul.nearby-cities-grid li{margin:0}.city-seo-section ul.nearby-cities-grid a{display:block;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:12px 14px;color:#1f2937;text-decoration:none;font-weight:500;font-size:.95rem;transition:all .15s ease}.city-seo-section ul.nearby-cities-grid a:hover{border-color:#2563eb;color:#2563eb;box-shadow:0 4px 10px -2px rgba(37,99,235,.18);transform:translateY(-1px)}.city-faq{margin-top:8px;display:flex;flex-direction:column;gap:8px}.city-faq details{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:14px 18px;transition:border-color .2s}.city-faq details[open]{border-color:#93c5fd;box-shadow:0 4px 14px -4px rgba(37,99,235,.12)}.city-faq summary{cursor:pointer;font-weight:600;color:#111827;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:1rem}.city-faq summary::-webkit-details-marker{display:none}.city-faq summary::after{content:'+';font-size:1.4rem;color:#2563eb;font-weight:300;line-height:1;transition:transform .2s}.city-faq details[open] summary::after{content:'−'}.city-faq details p{margin:12px 0 0;color:#4b5563;line-height:1.6;font-size:.95rem}@media (prefers-color-scheme:dark){.city-seo-section{background:linear-gradient(180deg,#0f172a 0,#111827 100%);border-top-color:#1f2937}.city-context{color:#e5e7eb}.city-context h2{color:#f3f4f6;border-left-color:#60a5fa}.city-context p{color:#cbd5e1}.city-context strong{color:#f9fafb}.city-context em{background:#1e3a8a;color:#bfdbfe}.city-seo-section ul.nearby-cities-grid a{background:#1f2937;border-color:#374151;color:#e5e7eb}.city-seo-section ul.nearby-cities-grid a:hover{border-color:#60a5fa;color:#60a5fa}.city-faq details{background:#1f2937;border-color:#374151}.city-faq summary{color:#f3f4f6}.city-faq details p{color:#cbd5e1}}@media (max-width:640px){.city-seo-section{padding:36px 0 44px}.city-context h2{font-size:1.3rem}.city-seo-section ul.nearby-cities-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}.city-seo-section ul.nearby-cities-grid a{padding:10px 12px;font-size:.9rem}}:root{--brand:oklch(0.62 0.16 235);--brand-hi:oklch(0.72 0.14 230);--brand-lo:oklch(0.48 0.18 240);--brand-wash:oklch(0.96 0.025 230);--warm:oklch(0.72 0.16 60);--warm-wash:oklch(0.97 0.04 75);--rain:oklch(0.55 0.12 240);--snow:oklch(0.85 0.05 220);--storm:oklch(0.45 0.15 280);--fog:oklch(0.75 0.02 230);--ink:oklch(0.18 0.015 240);--ink-2:oklch(0.38 0.015 235);--ink-3:oklch(0.58 0.012 230);--paper:oklch(0.99 0.005 230);--paper-2:oklch(0.97 0.008 230);--paper-3:oklch(0.94 0.01 230);--line:oklch(0.88 0.008 230);--r-xs:4px;--r-sm:8px;--r-md:14px;--r-lg:20px;--r-pill:999px;--el-1:0 1px 0 0 oklch(0.88 0.01 230 / 0.8);--el-2:0 8px 24px -12px oklch(0.5 0.1 230 / 0.18);--el-3:0 24px 48px -16px oklch(0.4 0.1 230 / 0.22);--t-fast:150ms;--t:220ms;--t-slow:320ms;--ease:cubic-bezier(0.22, 1, 0.36, 1);--serif:'Source Serif 4','Source Serif Pro',Georgia,'Times New Roman',serif;--sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;--mono:'JetBrains Mono','SF Mono',Menlo,monospace;--bg-primary:var(--paper);--bg-secondary:var(--paper-2);--bg-tertiary:var(--paper-3);--text-primary:var(--ink);--text-secondary:var(--ink-2);--text-tertiary:var(--ink-3);--text-inverse:var(--paper);--accent-blue:var(--brand);--accent-orange:var(--warm);--accent-green:oklch(0.65 0.15 145);--accent-red:oklch(0.6 0.2 25);--shadow-1:var(--el-1);--shadow-2:var(--el-2);--shadow-3:var(--el-3);--shadow-4:var(--el-3);--radius-sm:var(--r-sm);--radius-md:var(--r-md);--radius-lg:var(--r-lg);--radius-xl:var(--r-lg);--transition:var(--t) var(--ease);--transition-slow:var(--t-slow) var(--ease);--weather-sunny:linear-gradient(180deg, var(--warm) 0%, oklch(0.62 0.18 50) 100%);--weather-sunny-light:var(--warm-wash);--weather-cloudy:linear-gradient(180deg, var(--fog) 0%, oklch(0.6 0.02 230) 100%);--weather-cloudy-light:oklch(0.96 0.005 230);--weather-rainy:linear-gradient(180deg, var(--rain) 0%, var(--brand-lo) 100%);--weather-rainy-light:oklch(0.96 0.03 235);--weather-stormy:linear-gradient(180deg, var(--storm) 0%, oklch(0.35 0.13 285) 100%);--weather-stormy-light:oklch(0.95 0.025 285);--weather-snowy:linear-gradient(180deg, var(--snow) 0%, oklch(0.7 0.04 220) 100%);--weather-snowy-light:oklch(0.97 0.012 220);--weather-foggy:linear-gradient(180deg, var(--fog) 0%, oklch(0.6 0.015 230) 100%);--weather-foggy-light:oklch(0.96 0.005 230)}@media (prefers-color-scheme:dark){:root{--ink:oklch(0.95 0.012 230);--ink-2:oklch(0.74 0.012 230);--ink-3:oklch(0.58 0.01 230);--paper:oklch(0.16 0.018 240);--paper-2:oklch(0.20 0.018 240);--paper-3:oklch(0.24 0.018 240);--line:oklch(0.30 0.015 240);--brand-wash:oklch(0.22 0.04 235);--el-1:0 1px 0 0 oklch(0.30 0.015 240 / 0.6);--el-2:0 8px 24px -12px oklch(0.05 0.04 240 / 0.5);--el-3:0 24px 48px -16px oklch(0.05 0.04 240 / 0.6)}}html{color-scheme:light dark;scroll-behavior:smooth}body{font-family:var(--sans)!important;font-feature-settings:'cv02','cv03','cv04','cv11';font-size:16px;line-height:1.55;color:var(--ink)!important;background:radial-gradient(ellipse 100% 70% at 50% -10%,var(--brand-wash),transparent 60%),var(--paper)!important;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--serif)!important;font-weight:600;letter-spacing:-.015em;color:var(--ink);line-height:1.15}h1{font-size:clamp(28px, 5vw, 48px);font-weight:600}h2{font-size:clamp(22px, 3.5vw, 32px)}h3{font-size:clamp(18px, 2.5vw, 22px);font-weight:600}h4{font-size:16px;font-weight:600}a{color:var(--brand);text-decoration:none;transition:color var(--t) var(--ease)}a:hover{color:var(--brand-hi);text-decoration:underline;text-underline-offset:3px}::selection{background:var(--brand);color:oklch(.99 .005 230)}.header-top,header,header .container{background:oklch(.99 .005 230 / .85)!important;backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px)}header{border-bottom:1px solid var(--line)!important;position:sticky;top:0;z-index:50}@media (prefers-color-scheme:dark){.header-top,header,header .container{background:oklch(.16 .018 240 / .85)!important}}.site-logo{height:36px!important;width:auto!important;filter:drop-shadow(0 1px 0 oklch(0 0 0 / .05))}.site-logo-link{display:inline-flex;align-items:center}.breadcrumb{font-family:var(--sans);font-size:13px;color:var(--ink-3)}.breadcrumb a{color:var(--ink-2);font-weight:500}.breadcrumb a:hover{color:var(--brand)}.breadcrumb-separator{margin:0 8px;color:var(--ink-3)}.nav-menu-toggle{background:0 0!important;border:1px solid var(--line)!important;color:var(--ink)!important;padding:8px 14px!important;border-radius:var(--r-sm)!important;font-weight:500;font-size:14px;transition:all var(--t) var(--ease)}.nav-menu-toggle:hover{border-color:var(--brand);color:var(--brand)!important}.nav-menu-dropdown{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-md)!important;box-shadow:var(--el-3)!important;padding:6px!important}.nav-menu-item{color:var(--ink)!important;border-radius:var(--r-sm)!important;padding:10px 12px!important;transition:background var(--t-fast) var(--ease)}.nav-menu-item:hover{background:var(--brand-wash)!important;color:var(--brand)!important}.lang-selector-btn{background:var(--paper-2)!important;border:1px solid var(--line)!important;color:var(--ink)!important;border-radius:var(--r-pill)!important;padding:7px 14px!important;font-size:13px!important;transition:all var(--t) var(--ease)}.lang-selector-btn:hover{border-color:var(--brand)}.lang-dropdown{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-md)!important;box-shadow:var(--el-3)!important}.lang-option:hover{background:var(--brand-wash)!important;color:var(--brand)!important}.search-full-width{padding:16px 0!important;background:0 0!important}.city-search-full{width:100%;max-width:720px;margin:0 auto;display:block;background:var(--paper)!important;border:1.5px solid var(--line)!important;border-radius:var(--r-pill)!important;padding:14px 22px!important;font-family:var(--sans);font-size:16px!important;color:var(--ink)!important;box-shadow:var(--el-1);transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.city-search-full::placeholder{color:var(--ink-3)}.city-search-full:focus{outline:0;border-color:var(--brand)!important;box-shadow:0 0 0 4px oklch(.62 .16 235 / .12),var(--el-2)}.search-results{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-md)!important;box-shadow:var(--el-3)!important;max-width:720px;margin:8px auto 0}.search-result-item{padding:12px 18px!important;border-bottom:1px solid var(--line);color:var(--ink)!important;font-size:14px}.search-result-item:hover{background:var(--brand-wash)!important;color:var(--brand)!important}.intro-section{background:0 0!important;padding:48px 0 32px!important;text-align:left!important}.intro-section h1{font-family:var(--serif)!important;font-size:clamp(36px, 6vw, 64px)!important;font-weight:600!important;letter-spacing:-.02em!important;color:var(--ink)!important;margin-bottom:12px!important}.intro-text{font-family:var(--sans)!important;font-size:18px!important;color:var(--ink-2)!important;max-width:68ch;line-height:1.6}.cantons-section,.same-canton-section{background:0 0!important;padding:32px 0!important}#cantonsTitle,.cantons-section h2,.cantonsTitle{font-family:var(--serif)!important;font-size:22px!important;color:var(--ink)!important;margin:0 0 16px!important;position:relative;padding-left:14px}#cantonsTitle::before,.cantons-section h2::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--brand);border-radius:2px}.cantons-scroll-container{padding:4px 0!important}.cantons-scroll{gap:8px!important;padding:4px 0!important}.canton-banner-card,.canton-card{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-md)!important;padding:14px 16px!important;color:var(--ink)!important;font-weight:500;transition:all var(--t) var(--ease);box-shadow:none!important}.canton-banner-card:hover,.canton-card:hover{border-color:var(--brand)!important;color:var(--brand)!important;transform:translateY(-1px);box-shadow:var(--el-2)!important}.canton-banner-card.active,.canton-card.active{background:var(--brand)!important;border-color:var(--brand)!important;color:oklch(.99 .005 230)!important}.current-weather,.weather-card-modern,.weather-section{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-lg)!important;padding:32px!important;box-shadow:var(--el-1)!important;margin-bottom:24px}.current-weather h2,.weather-section h2{font-family:var(--serif)!important;font-size:18px!important;font-weight:600;color:var(--ink-2)!important;text-transform:none;letter-spacing:0;margin-bottom:16px!important}.current-temp,.temp-current,.temperature,.weather-temp{font-family:var(--sans)!important;font-feature-settings:'tnum','ss01';font-variant-numeric:tabular-nums;font-size:clamp(72px, 14vw, 128px)!important;font-weight:200!important;line-height:.95!important;color:var(--ink)!important;letter-spacing:-.04em!important}.condition-text,.weather-condition,.weather-description{font-family:var(--sans)!important;font-size:18px!important;font-weight:500;color:var(--ink-2)!important;letter-spacing:0;text-transform:none!important}.forecast-hourly,.hourly-forecast,.hourly-strip{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-lg)!important;padding:20px!important;overflow-x:auto}.forecast-hour,.hour-card,.hourly-item{background:0 0!important;border:none!important;border-right:1px solid var(--line)!important;border-radius:0!important;padding:8px 18px!important;box-shadow:none!important;min-width:88px;text-align:center}.hour-card:last-child,.hourly-item:last-child{border-right:none!important}.hour-time,.hourly-time{font-size:12px!important;color:var(--ink-3)!important;text-transform:uppercase;letter-spacing:.04em;font-weight:500}.hour-temp,.hourly-temp{font-family:var(--sans)!important;font-feature-settings:'tnum';font-variant-numeric:tabular-nums;font-size:20px!important;font-weight:500;color:var(--ink)!important}.daily-forecast,.forecast-weekly,.weekly-forecast{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-lg)!important;padding:20px!important;margin-top:24px}.daily-item,.day-card,.forecast-day{background:0 0!important;border:none!important;border-bottom:1px solid var(--line)!important;border-radius:0!important;padding:14px 8px!important;display:grid!important;grid-template-columns:90px 32px 1fr auto auto;gap:14px;align-items:center}.daily-item:last-child,.day-card:last-child{border-bottom:none!important}.day-name{font-weight:500;color:var(--ink)}.day-temp-high,.day-temp-low{font-variant-numeric:tabular-nums;font-feature-settings:'tnum'}.day-temp-high{color:var(--ink);font-weight:500}.day-temp-low{color:var(--ink-3)}.stats-row,.weather-details,.weather-stats{display:flex!important;flex-wrap:wrap!important;gap:8px!important;padding:16px 0!important}.detail-item,.stat-item,.weather-stat{background:var(--paper-2)!important;border:1px solid var(--line)!important;border-radius:var(--r-pill)!important;padding:8px 14px!important;font-size:13px!important;color:var(--ink-2)!important;display:inline-flex!important;align-items:center;gap:6px;box-shadow:none!important}.stat-value{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}.weather-map-section{padding:32px 0!important}.weather-map-section h2{font-family:var(--serif)!important;font-size:22px!important;padding-left:14px;position:relative;margin-bottom:16px}.weather-map-section h2::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--brand);border-radius:2px}#weatherMap,.weather-map-container{border-radius:var(--r-lg)!important;overflow:hidden;border:1px solid var(--line);box-shadow:var(--el-1);min-height:480px}.featured-news-section{padding:24px 0!important}.featured-news-section h2{font-family:var(--serif)!important;font-size:22px!important;padding-left:14px;position:relative;margin-bottom:16px}.featured-news-section h2::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--warm);border-radius:2px}.weather-alert-banner{background:linear-gradient(95deg,oklch(.62 .16 30 / .08),oklch(.62 .16 60 / .08))!important;border:1px solid oklch(.62 .16 40 / .3)!important;border-radius:var(--r-md)!important;padding:14px 18px!important;color:var(--ink)!important;margin:16px 0}.city-seo-section{background:var(--paper-2)!important;border-top:1px solid var(--line)!important;padding:56px 0 64px!important;margin-top:48px!important}.city-context{color:var(--ink);font-family:var(--sans);line-height:1.7}.city-context h2{font-family:var(--serif)!important;font-size:26px!important;font-weight:600;color:var(--ink)!important;margin:36px 0 14px!important;border-left:3px solid var(--brand)!important;padding-left:14px!important}.city-context h2:first-child{margin-top:0!important}.city-context p{color:var(--ink-2);font-size:16px;margin:0 0 14px}.city-context strong{color:var(--ink);font-weight:600}.city-context em{font-style:normal;color:var(--brand);background:var(--brand-wash);padding:1px 8px;border-radius:var(--r-xs);font-size:.92em}.city-seo-section ul.nearby-cities-grid{list-style:none;padding:0;margin:14px 0 24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.city-seo-section ul.nearby-cities-grid a{display:block;background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-sm)!important;padding:12px 14px;color:var(--ink)!important;font-weight:500;font-size:14px;transition:all var(--t-fast) var(--ease)}.city-seo-section ul.nearby-cities-grid a:hover{border-color:var(--brand)!important;color:var(--brand)!important;transform:translateY(-1px);box-shadow:var(--el-2);text-decoration:none}.canton-link a{display:inline-flex!important;align-items:center;gap:8px;background:var(--brand)!important;color:oklch(.99 .005 230)!important;padding:12px 22px!important;border-radius:var(--r-pill)!important;font-weight:500!important;font-size:15px!important;transition:all var(--t) var(--ease);text-decoration:none;box-shadow:var(--el-1)}.canton-link a:hover{background:var(--brand-lo)!important;transform:translateY(-1px);box-shadow:var(--el-2);color:oklch(.99 .005 230)!important;text-decoration:none}.city-faq{margin-top:8px;display:flex;flex-direction:column;gap:6px}.city-faq details{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-sm)!important;padding:16px 20px!important;transition:border-color var(--t) var(--ease)}.city-faq details[open]{border-color:var(--brand)!important;box-shadow:var(--el-2)}.city-faq summary{cursor:pointer;font-family:var(--sans);font-weight:600;color:var(--ink);font-size:16px;list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center}.city-faq summary::-webkit-details-marker{display:none}.city-faq summary::after{content:'+';font-size:24px;line-height:1;color:var(--brand);font-weight:300;transition:transform var(--t) var(--ease)}.city-faq details[open] summary::after{content:'−'}.city-faq details p{margin:12px 0 0;color:var(--ink-2);line-height:1.65;font-size:15px}.main-footer,footer.main-footer{background:oklch(.15 .02 240)!important;color:oklch(.74 .012 230)!important;padding:56px 0 32px!important;margin-top:64px;border-top:none!important}.main-footer h3,.main-footer h4{font-family:var(--serif)!important;color:oklch(.95 .012 230)!important;font-size:16px!important;margin-bottom:14px;font-weight:600}.main-footer a{color:oklch(.74 .012 230)!important;font-size:14px;transition:color var(--t) var(--ease)}.main-footer a:hover{color:oklch(.95 .012 230)!important;text-decoration:underline}.footer-bottom{border-top:1px solid oklch(.3 .015 240)!important;margin-top:24px;padding-top:18px;text-align:center;font-size:12px;color:oklch(.58 .01 230)!important}.btn,.button,button{font-family:var(--sans);font-weight:500;border-radius:var(--r-sm);transition:all var(--t) var(--ease)}.btn-primary,button.primary{background:var(--brand)!important;color:oklch(.99 .005 230)!important;border:1px solid var(--brand)!important}.btn-primary:hover,button.primary:hover{background:var(--brand-lo)!important;transform:translateY(-1px);box-shadow:var(--el-2)}.container{max-width:1180px!important;margin:0 auto!important;padding:0 20px!important}main,main.container{padding-top:24px!important;padding-bottom:64px!important}.loading{font-family:var(--sans);color:var(--ink-3);font-size:14px;padding:24px;text-align:center;letter-spacing:.02em}.loading::after{content:'';display:inline-block;width:14px;height:14px;margin-left:8px;border:2px solid var(--line);border-top-color:var(--brand);border-radius:50%;vertical-align:middle;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.location-modal-overlay{background:oklch(.16 .018 240 / .55)!important;backdrop-filter:blur(4px)}.location-modal-content{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-lg)!important;box-shadow:var(--el-3)!important}.location-modal-title{font-family:var(--serif)!important;color:var(--ink)!important}.location-modal-btn-confirm{background:var(--brand)!important;color:oklch(.99 .005 230)!important;border:1px solid var(--brand)!important}.location-modal-btn-cancel{background:0 0!important;color:var(--ink-2)!important;border:1px solid var(--line)!important}@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:0s!important;animation-iteration-count:1!important;transition-duration:0s!important;scroll-behavior:auto!important}}@media (max-width:640px){body{font-size:15px}.intro-section{padding:28px 0 20px!important}.current-weather,.weather-card-modern{padding:22px!important}.daily-item,.day-card{grid-template-columns:72px 28px 1fr auto auto;gap:10px}.hour-card,.hourly-item{min-width:72px;padding:8px 14px!important}.city-context h2{font-size:22px!important;margin-top:28px!important}.city-seo-section{padding:40px 0 48px!important}.main-footer{padding:40px 0 24px!important}}@media print{.canton-link,.city-faq,.featured-news-section,.lang-selector-custom,.nav-menu-toggle,.weather-map-section,footer,header,ins.adsbygoogle,script{display:none!important}body{background:#fff!important;color:#000!important}.current-weather,.weekly-forecast{box-shadow:none!important;border:1px solid #ccc!important}}.city-seo-section ul.nearby-cities-grid li{margin:0}:root{--brand-wash:oklch(0.985 0.012 230);--paper:oklch(0.995 0.003 230);--paper-2:oklch(0.985 0.006 230);--paper-3:oklch(0.97 0.008 230)}body{background:var(--paper)!important}.header-top,header,header .container{background:oklch(.998 .003 230 / .88)!important}.current-weather,.daily-forecast,.hourly-forecast,.weather-card-modern,.weather-section,.weekly-forecast{background:var(--paper)!important}.city-seo-section{background:var(--paper-2)!important}.city-search-full{background:var(--paper)!important}.detail-item,.stat-item,.weather-stat{background:var(--paper-2)!important}.main-footer,footer.main-footer{background:oklch(.18 .013 245)!important}body>.container:first-child{color:var(--ink)!important}@media (prefers-color-scheme:dark){body{background:var(--paper)!important}.header-top,header,header .container{background:oklch(.18 .018 240 / .88)!important}}.daily-item,.day-card,.forecast-day,.weekly-item,.weekly-item.has-rain,.weekly-item.has-snow,.weekly-item.has-storm,.weekly-item.is-cold,.weekly-item.is-hot{border-left:none!important;border-right:none!important;background:0 0!important;border-top:none!important;border-bottom:1px solid var(--line)!important;border-radius:0!important;padding:16px 12px!important;box-shadow:none!important}.daily-item:last-child,.day-card:last-child,.weekly-item:last-child{border-bottom:none!important}.weekly-item.has-rain .weekly-day::before{content:'';display:inline-block;width:6px;height:6px;margin-right:8px;background:var(--rain);border-radius:50%;vertical-align:middle}.weekly-item.has-snow .weekly-day::before{content:'';display:inline-block;width:6px;height:6px;margin-right:8px;background:var(--snow);border-radius:50%;vertical-align:middle}.weekly-item.has-storm .weekly-day::before{content:'';display:inline-block;width:6px;height:6px;margin-right:8px;background:var(--storm);border-radius:50%;vertical-align:middle}#weeklyForecast,.weekly-container{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-lg)!important;padding:12px 20px!important;box-shadow:var(--el-1)!important}.forecast-tabs,.hourly-tabs,.tab-group,[class*=tab-container]{display:inline-flex!important;gap:2px!important;background:var(--paper-2)!important;border:1px solid var(--line)!important;border-radius:var(--r-pill)!important;padding:4px!important}.forecast-tab,.hourly-tab,.tab-button,[class*=tab-btn]{background:0 0!important;border:none!important;border-radius:var(--r-pill)!important;padding:7px 16px!important;color:var(--ink-2)!important;font-size:13px!important;font-weight:500!important;cursor:pointer;transition:all var(--t-fast) var(--ease)}.forecast-tab:hover,.hourly-tab:hover{color:var(--ink)!important;background:var(--paper-3)!important}.forecast-tab.active,.forecast-tab[aria-selected=true],.hourly-tab.active,.hourly-tab[aria-selected=true],.tab-button.active,[class*=tab-btn].active{background:var(--ink)!important;color:var(--paper)!important;box-shadow:var(--el-1)}.unit-switch button,.unit-toggle button,[class*=unit-btn]{background:0 0!important;border:none!important;color:var(--ink-2)!important;padding:6px 14px!important;border-radius:var(--r-pill)!important}.unit-switch button.active,.unit-toggle button.active,[class*=unit-btn].active{background:var(--ink)!important;color:var(--paper)!important}.weekly-item.has-rain,.weekly-item.has-rain:hover,.weekly-item.has-snow,.weekly-item.has-snow:hover,.weekly-item.has-storm,.weekly-item.is-cold,.weekly-item.is-hot{background:0 0!important}.weekly-item:hover{background:var(--paper-2)!important}.cta-card,.editorial-card,.editorial-card *,.info-banner,.info-callout,.message-card,.tip-card,[class*=callout]:not(:has(*)){border-left:none!important;border-right:none!important}.editorial-card{background:var(--paper-2)!important;border:1px solid var(--line)!important;border-radius:var(--r-lg)!important;padding:24px 28px!important}body{background:radial-gradient(ellipse 130% 60% at 50% -20%,var(--sky-tint,oklch(.96 .025 230)),transparent 75%),var(--paper)!important;transition:background var(--t-slow) var(--ease)}body[data-tod=dawn]{--sky-tint:oklch(0.92 0.06 35)}body[data-tod=morning]{--sky-tint:oklch(0.94 0.05 70)}body[data-tod=noon]{--sky-tint:oklch(0.96 0.03 230)}body[data-tod=evening]{--sky-tint:oklch(0.85 0.09 35)}body[data-tod=night]{--sky-tint:oklch(0.32 0.06 260)}body[data-weather=clear]{--sky-tint:oklch(0.94 0.05 235)}body[data-weather=cloudy]{--sky-tint:oklch(0.94 0.012 230)}body[data-weather=rain]{--sky-tint:oklch(0.88 0.02 245)}body[data-weather=storm]{--sky-tint:oklch(0.75 0.025 270)}body[data-weather=snow]{--sky-tint:oklch(0.98 0.005 230)}.current-weather,.weather-card-modern,.weather-section[id*=current]{background:linear-gradient(180deg,oklch(1 0 0 / .6),oklch(1 0 0 / .92))!important;backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);border:1px solid oklch(1 0 0 / .5)!important;border-radius:24px!important;padding:48px!important;box-shadow:0 30px 80px -30px oklch(.5 .05 240 / .15)!important;position:relative;overflow:hidden}.current-weather::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 100% at 70% 0,var(--sky-tint,oklch(.96 .025 230 / .4)),transparent 70%);pointer-events:none;z-index:0}.current-weather>*{position:relative;z-index:1}.current-temp,.temp-current,.temperature,.weather-temp{font-size:clamp(96px, 18vw, 168px)!important;font-weight:200!important;line-height:.9!important;letter-spacing:-.05em!important;background:linear-gradient(180deg,var(--ink) 0,oklch(.32 .012 240) 100%);-webkit-background-clip:text;background-clip:text;color:var(--ink)!important}.condition-text,.weather-condition,.weather-description{font-family:var(--serif)!important;font-size:clamp(20px, 2.5vw, 28px)!important;font-weight:400;font-style:italic;letter-spacing:-.005em;color:var(--ink-2)!important}.stats-row,.weather-details,.weather-info-grid,.weather-stats{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))!important;gap:0!important;padding:24px 0 0!important;border-top:1px solid var(--line);margin-top:32px}.weather-details>*,.weather-info-grid>*,.weather-stats>*{background:0 0!important;border:none!important;border-right:1px solid var(--line)!important;border-radius:0!important;padding:16px 20px!important;display:flex!important;flex-direction:column!important;gap:4px!important;box-shadow:none!important}.weather-details>:last-child,.weather-stats>:last-child{border-right:none!important}.weather-info-grid .label,.weather-info-grid label,.weather-stats .label,.weather-stats .stat-label,.weather-stats label{font-size:11px!important;text-transform:uppercase!important;letter-spacing:.08em!important;color:var(--ink-3)!important;font-weight:600}.weather-info-grid .value,.weather-stats .stat-value,.weather-stats .value{font-size:22px!important;font-weight:500!important;font-variant-numeric:tabular-nums;font-feature-settings:'tnum';color:var(--ink)!important}.nearby-city-card .nearby-temp,.nearby-city-card [class*=temp],.same-canton-city-card .nearby-temp,.same-canton-city-card [class*=temp]{color:var(--ink)!important;font-weight:500!important;font-size:22px!important;font-variant-numeric:tabular-nums}.intro-section h1,section.intro-section h1{font-family:var(--serif)!important;font-size:clamp(48px, 8vw, 96px)!important;font-weight:300!important;letter-spacing:-.035em!important;line-height:1!important;color:var(--ink)!important;margin:0 0 20px!important}.intro-section .intro-text,.intro-section p{font-family:var(--serif)!important;font-size:clamp(18px, 2.2vw, 24px)!important;font-weight:400!important;font-style:italic!important;color:var(--ink-2)!important;max-width:50ch!important;line-height:1.45!important}.hourly-forecast>h2,.weather-section h2,.weather-section>h3,.weekly-forecast>h2,section h2:not(.city-context h2):not(.intro-section h2){font-family:var(--serif)!important;font-size:clamp(28px, 3.5vw, 40px)!important;font-weight:400!important;letter-spacing:-.015em!important;color:var(--ink)!important;margin-bottom:24px!important;position:relative;padding-left:0!important;border-left:none!important}.weather-section h2::before,section h2:not(.city-context h2):not(.intro-section h2)::before{display:none!important}.forecast-hourly,.hourly-forecast,.hourly-strip{padding:24px!important;background:linear-gradient(180deg,var(--paper) 0,var(--paper-2) 100%)!important}.cantons-static-grid ul li,section[id*=cantons] ul.nearby-cities-grid li{margin:0!important}body::after{content:'';position:fixed;inset:0;background-image:radial-gradient(circle at 1px 1px,oklch(.7 .015 230 / .05) 1px,transparent 0);background-size:24px 24px;pointer-events:none;z-index:0;mix-blend-mode:multiply}body>*{position:relative;z-index:1}.city-context>p:first-of-type::first-letter{font-family:var(--serif);font-size:4em;font-weight:600;float:left;line-height:.85;margin:4px 10px 0 0;color:var(--brand)}.main-footer{background:oklch(.14 .018 245)!important;padding:72px 0 36px!important}.main-footer h3,.main-footer h4{font-family:var(--serif)!important;font-size:14px!important;text-transform:uppercase;letter-spacing:.08em;color:oklch(.65 .02 230)!important;font-weight:500}body,html{color-scheme:light!important}:root,:root[data-theme=dark]{--ink:oklch(0.18 0.015 240)!important;--ink-2:oklch(0.38 0.015 235)!important;--ink-3:oklch(0.58 0.012 230)!important;--paper:oklch(0.995 0.003 230)!important;--paper-2:oklch(0.985 0.006 230)!important;--paper-3:oklch(0.97 0.008 230)!important;--line:oklch(0.88 0.008 230)!important;--brand-wash:oklch(0.985 0.012 230)!important;--bg-primary:var(--paper)!important;--bg-secondary:var(--paper-2)!important;--bg-tertiary:var(--paper-3)!important;--text-primary:var(--ink)!important;--text-secondary:var(--ink-2)!important;--text-tertiary:var(--ink-3)!important}@media (prefers-color-scheme:dark){:root{--ink:oklch(0.18 0.015 240)!important;--ink-2:oklch(0.38 0.015 235)!important;--ink-3:oklch(0.58 0.012 230)!important;--paper:oklch(0.995 0.003 230)!important;--paper-2:oklch(0.985 0.006 230)!important;--paper-3:oklch(0.97 0.008 230)!important;--line:oklch(0.88 0.008 230)!important;--bg-primary:var(--paper)!important;--bg-secondary:var(--paper-2)!important;--bg-tertiary:var(--paper-3)!important;--text-primary:var(--ink)!important;--text-secondary:var(--ink-2)!important;--text-tertiary:var(--ink-3)!important}body,html{background:var(--paper)!important;color:var(--ink)!important}.canton-banner-card,.canton-card,.city-context,.city-search-full,.city-seo-section,.current-weather,.daily-forecast,.detail-item,.hourly-forecast,.lang-dropdown,.nav-menu-dropdown,.search-results,.stat-item,.weather-card-modern,.weather-section,.weather-stat,.weekly-forecast,article,body,footer:not(.main-footer),header,main,section{background:var(--paper)!important;color:var(--ink)!important}h1,h2,h3,h4,h5,h6{color:var(--ink)!important}.main-footer{background:oklch(.15 .02 240)!important;color:oklch(.74 .012 230)!important}.main-footer h3,.main-footer h4{color:oklch(.95 .012 230)!important}}body{background:var(--paper)!important;color:var(--ink)!important}.site-logo{height:56px!important;width:auto!important;max-width:200px!important}.site-logo-link{display:inline-flex!important;align-items:center;gap:8px}@media (max-width:640px){.site-logo{height:44px!important}}header{background:oklch(1 0 0 / .96)!important;backdrop-filter:saturate(180%) blur(20px)!important;-webkit-backdrop-filter:saturate(180%) blur(20px)!important;border-bottom:1px solid var(--line)!important;box-shadow:0 1px 0 0 oklch(.88 .01 230 / .5)!important;z-index:100!important}header .container{background:0 0!important;padding-top:14px!important;padding-bottom:14px!important}.header-top{background:0 0!important;display:flex!important;align-items:center!important;justify-content:space-between!important;gap:16px!important;flex-wrap:wrap}.breadcrumb{font-family:var(--sans)!important;font-size:14px!important;color:var(--ink-2)!important;display:inline-flex!important;align-items:center;gap:6px}.breadcrumb a{color:var(--ink)!important;font-weight:600!important;text-decoration:none}.breadcrumb a:hover{color:var(--brand)!important;text-decoration:underline}.breadcrumb-separator{color:var(--ink-3)!important;margin:0 6px!important;font-weight:300}.breadcrumb-current .breadcrumb-text{color:var(--ink)!important;font-weight:600}.nav-menu-toggle{background:var(--paper)!important;border:1px solid var(--line)!important;color:var(--ink)!important;padding:10px 18px!important;border-radius:var(--r-pill)!important;font-size:14px!important;font-weight:600!important}.nav-menu-text{color:var(--ink)!important;font-weight:600}.nav-menu-toggle:hover{border-color:var(--ink)!important;background:var(--paper-2)!important}header{position:sticky;top:0;z-index:1000!important}.lang-dropdown,.nav-menu-dropdown{position:absolute!important;z-index:9999!important;background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:var(--r-md)!important;box-shadow:0 16px 40px -12px oklch(.2 .05 240 / .25)!important;min-width:220px;padding:6px!important;margin-top:8px!important}#citySearch,.city-search-full,.search-full-width,.search-results{z-index:5!important;position:relative!important}.search-results{z-index:8!important}.nav-menu-item{display:flex!important;align-items:center;gap:10px;color:var(--ink)!important;font-size:14px!important;font-weight:500!important;padding:10px 14px!important;border-radius:var(--r-sm)!important;text-decoration:none!important}.nav-menu-item:hover{background:var(--brand-wash)!important;color:var(--brand)!important}.nav-menu-icon-item{font-size:18px}.nav-menu-label{font-weight:500}.lang-selector-btn{background:var(--paper)!important;border:1px solid var(--line)!important;color:var(--ink)!important;font-weight:600!important;padding:10px 16px!important;border-radius:var(--r-pill)!important}.lang-current-name{color:var(--ink)!important;font-weight:600}.lang-option{display:flex!important;align-items:center;gap:10px;color:var(--ink)!important;font-weight:500;padding:10px 14px!important;border-radius:var(--r-sm)!important}.lang-option:hover{background:var(--brand-wash)!important;color:var(--brand)!important}.lang-option-name{font-weight:500}:root{--m-paper:oklch(0.985 0.006 80);--m-paper-2:oklch(0.96 0.008 80);--m-paper-3:oklch(0.93 0.01 80);--m-ink:oklch(0.18 0.012 250);--m-ink-2:oklch(0.40 0.015 250);--m-ink-3:oklch(0.62 0.012 250);--m-line:oklch(0.86 0.008 80);--m-line-strong:oklch(0.75 0.012 80);--m-cobalt:oklch(0.42 0.20 252);--m-cobalt-hi:oklch(0.52 0.22 252);--m-cobalt-wash:oklch(0.95 0.04 252);--m-vermilion:oklch(0.62 0.21 30);--m-vermilion-wash:oklch(0.96 0.05 30);--m-r-sm:6px;--m-r-md:12px;--m-r-lg:20px;--m-r-pill:999px;--m-el-1:0 1px 2px oklch(0.18 0.01 250 / 0.06);--m-el-2:0 8px 24px -8px oklch(0.18 0.05 250 / 0.12);--m-el-3:0 24px 48px -12px oklch(0.18 0.05 250 / 0.18);--m-serif:'Newsreader','Source Serif 4',Georgia,'Times New Roman',serif;--m-sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif}html{color-scheme:light!important}@media (prefers-color-scheme:dark){:root{--bg-primary:var(--m-paper)!important;--bg-secondary:var(--m-paper-2)!important;--bg-tertiary:var(--m-paper-3)!important;--text-primary:var(--m-ink)!important;--text-secondary:var(--m-ink-2)!important;--text-tertiary:var(--m-ink-3)!important}[data-theme=dark],body,body.dark,html.dark{background:var(--m-paper)!important;color:var(--m-ink)!important}body *,body.dark *,html.dark *{color-scheme:light!important}}body{font-family:var(--m-sans)!important;color:var(--m-ink)!important;background:var(--m-paper)!important;background-image:radial-gradient(circle at 1px 1px,oklch(.6 .02 80 / .06) 1px,transparent 0)!important;background-size:32px 32px!important;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3{font-family:var(--m-serif)!important;font-weight:500!important;letter-spacing:-.012em!important;color:var(--m-ink)!important;line-height:1.1!important}h4,h5,h6{font-family:var(--m-sans)!important}::selection{background:var(--m-cobalt);color:var(--m-paper)}#introSection,.intro-section{background:0 0!important;padding:0!important;margin:8px 0 24px!important;border:0!important}.intro-content{max-width:640px}#introTitle,.intro-section h1{font-family:var(--m-serif)!important;font-size:clamp(22px, 2.6vw, 30px)!important;font-weight:500!important;letter-spacing:-.01em!important;line-height:1.2!important;color:var(--m-ink)!important;margin:0 0 8px!important}#introText,.intro-section p,.intro-text{font-family:var(--m-sans)!important;font-size:14px!important;font-weight:400!important;line-height:1.55!important;color:var(--m-ink-2)!important;max-width:64ch!important}body[data-city] .intro-section{display:none!important}html[data-city] .intro-section{display:none!important}header{background:oklch(.985 .006 80 / .86)!important;backdrop-filter:saturate(180%) blur(18px)!important;-webkit-backdrop-filter:saturate(180%) blur(18px)!important;border-bottom:1px solid var(--m-line)!important;box-shadow:none!important;position:sticky;top:0;z-index:100}.site-logo{height:48px!important;max-width:180px!important}@media (max-width:640px){.site-logo{height:38px!important}}.breadcrumb{font-family:var(--m-sans)!important;font-size:14px!important;color:var(--m-ink-2)!important}.breadcrumb a{color:var(--m-ink)!important;font-weight:600!important}.breadcrumb a:hover{color:var(--m-cobalt)!important}.breadcrumb-separator{color:var(--m-ink-3)!important}.lang-selector-btn,.nav-menu-toggle{background:0 0!important;border:1px solid var(--m-line-strong)!important;color:var(--m-ink)!important;border-radius:var(--m-r-pill)!important;padding:9px 16px!important;font-weight:600!important;font-size:14px!important}.lang-selector-btn:hover,.nav-menu-toggle:hover{background:var(--m-paper-2)!important;border-color:var(--m-ink)!important}.lang-current-name,.nav-menu-text{color:var(--m-ink)!important}.lang-dropdown,.nav-menu-dropdown{background:var(--m-paper)!important;border:1px solid var(--m-line)!important;border-radius:var(--m-r-md)!important;box-shadow:var(--m-el-3)!important;padding:6px!important;z-index:9999!important}.lang-option,.nav-menu-item{color:var(--m-ink)!important;border-radius:var(--m-r-sm)!important;padding:10px 14px!important;font-size:14px!important;font-weight:500!important}.lang-option:hover,.nav-menu-item:hover{background:var(--m-cobalt-wash)!important;color:var(--m-cobalt)!important}#citySearch,.city-search-full{background:var(--m-paper)!important;border:1px solid var(--m-line-strong)!important;border-radius:var(--m-r-pill)!important;padding:13px 22px!important;font-family:var(--m-sans)!important;font-size:15px!important;color:var(--m-ink)!important;box-shadow:var(--m-el-1)!important}.city-search-full::placeholder{color:var(--m-ink-3)!important}.city-search-full:focus{outline:0!important;border-color:var(--m-cobalt)!important;box-shadow:0 0 0 4px oklch(.42 .2 252 / .12),var(--m-el-2)!important}.search-full-width{z-index:5!important;position:relative!important}.search-results{z-index:8!important}.cantons-section h2,.featured-news-section h2,.hourly-forecast h2,.weather-map-section h2,.weekly-forecast h2,main section>h2,main>section>h2{font-family:var(--m-serif)!important;font-size:clamp(22px, 2.5vw, 28px)!important;font-weight:500!important;color:var(--m-ink)!important;margin:0 0 20px!important;border-left:0!important;padding-left:0!important;display:flex!important;align-items:baseline!important;gap:12px!important}main section>h2::before,main>section>h2::before{display:none!important}.cantons-section h2::after,.hourly-forecast h2::after,.weekly-forecast h2::after,main section>h2::after{content:''!important;flex:1!important;height:1px!important;background:var(--m-line)!important;align-self:center!important;margin-left:4px!important;display:block!important}.forecast-tabs,.hourly-tabs,.tab-group,.weather-tabs{background:var(--m-paper-2)!important;border:1px solid var(--m-line)!important;border-radius:var(--m-r-pill)!important;padding:4px!important}.forecast-tab,.hourly-tab,.tab-button,.weather-tab{background:0 0!important;border:0!important;border-radius:var(--m-r-pill)!important;color:var(--m-ink-2)!important;font-weight:500!important;font-size:13px!important;padding:7px 16px!important}.forecast-tab.active,.forecast-tab[aria-selected=true],.hourly-tab.active,.hourly-tab[aria-selected=true],.tab-button.active{background:var(--m-ink)!important;color:var(--m-paper)!important;box-shadow:var(--m-el-1)!important}#tempUnitToggle,.temp-unit-toggle,.unit-switch,.unit-toggle{background:var(--m-paper-2)!important;border:1px solid var(--m-line)!important;border-radius:var(--m-r-pill)!important;padding:4px!important}.temp-unit-toggle button,.unit-switch button,.unit-toggle button{color:var(--m-ink-2)!important;border-radius:var(--m-r-pill)!important;padding:6px 14px!important;font-size:13px!important;font-weight:600!important}.temp-unit-toggle button.active,.unit-switch button.active,.unit-toggle button.active{background:var(--m-ink)!important;color:var(--m-paper)!important}.canton-banner-card,.canton-card{background:var(--m-paper)!important;border:1px solid var(--m-line)!important;border-radius:var(--m-r-pill)!important;color:var(--m-ink)!important;padding:10px 16px!important;box-shadow:none!important;font-weight:500!important}.canton-banner-card:hover,.canton-card:hover{border-color:var(--m-cobalt)!important;color:var(--m-cobalt)!important;transform:translateY(-1px);box-shadow:none!important}.canton-banner-card.active,.canton-card.active{background:var(--m-ink)!important;border-color:var(--m-ink)!important;color:var(--m-paper)!important}.daily-item,.day-card,.forecast-day,.weekly-item,.weekly-item.has-rain,.weekly-item.has-snow,.weekly-item.has-storm,.weekly-item.is-cold,.weekly-item.is-hot{border-left:0!important;border-right:0!important;border-top:0!important;border-bottom:1px solid var(--m-line)!important;background:0 0!important;border-radius:0!important;box-shadow:none!important;padding:14px 16px!important}.day-card:last-child,.weekly-item:last-child{border-bottom:0!important}.weekly-item:hover{background:var(--m-paper-2)!important}.weekly-item.today{background:var(--m-cobalt-wash)!important}.weekly-item.has-rain .weekly-day::before,.weekly-item.has-snow .weekly-day::before,.weekly-item.has-storm .weekly-day::before{content:'';display:inline-block;width:6px;height:6px;margin-right:10px;border-radius:50%;background:var(--m-cobalt);vertical-align:middle}#weeklyForecast,.daily-forecast,.weekly-container,.weekly-forecast{background:var(--m-paper)!important;border:1px solid var(--m-line)!important;border-radius:var(--m-r-md)!important;padding:0!important;box-shadow:var(--m-el-1)!important;overflow:hidden}.day-name,.weekly-day{color:var(--m-ink)!important;font-weight:500!important}.day-temp-low,.weekly-temp-min{color:var(--m-ink-3)!important;font-variant-numeric:tabular-nums;font-weight:500!important}.day-temp-high,.weekly-temp-max{color:var(--m-ink)!important;font-variant-numeric:tabular-nums;font-weight:600!important}.current-weather-main{background:var(--m-paper)!important;border:1px solid var(--m-line)!important;border-radius:var(--m-r-lg)!important;padding:32px 28px!important;box-shadow:var(--m-el-1)!important}.current-temp,.temp-current,.temp-value,.temperature,.weather-temp{font-family:var(--m-sans)!important;font-variant-numeric:tabular-nums!important;font-feature-settings:'tnum'!important;font-size:clamp(80px, 14vw, 144px)!important;font-weight:200!important;line-height:.9!important;letter-spacing:-.045em!important;color:var(--m-ink)!important}.condition-text,.weather-condition,.weather-description{font-family:var(--m-serif)!important;font-style:italic!important;font-size:clamp(18px, 2.5vw, 26px)!important;font-weight:400!important;color:var(--m-ink-2)!important}.nearby-city-card,.same-canton-city-card{background:var(--m-paper)!important;border:1px solid var(--m-line)!important;border-radius:var(--m-r-sm)!important;padding:16px!important;text-align:left!important;align-items:flex-start!important;box-shadow:none!important}.nearby-city-card:hover,.same-canton-city-card:hover{border-color:var(--m-cobalt)!important;transform:translateY(-1px);box-shadow:var(--m-el-2)!important}.nearby-city-card .nearby-temp,.nearby-city-card [class*=temp],.same-canton-city-card [class*=temp]{color:var(--m-ink)!important;font-variant-numeric:tabular-nums!important;font-weight:600!important;font-size:22px!important}.city-seo-section,.seo-content-section{background:var(--m-paper-2)!important;border-top:1px solid var(--m-line)!important;padding:56px 0 64px!important;margin-top:48px!important}.city-context,.seo-content{font-family:var(--m-sans)!important;color:var(--m-ink-2)!important;line-height:1.7!important;font-size:16px!important;max-width:760px!important;margin:0 auto!important}.city-context h2{font-family:var(--m-serif)!important;font-size:clamp(22px, 2.5vw, 28px)!important;font-weight:500!important;color:var(--m-ink)!important;margin:40px 0 12px!important;border-left:0!important;padding-left:0!important}.city-context h2:first-child{margin-top:0!important}.city-context h2::after{display:none!important}.city-context p{color:var(--m-ink-2)!important;margin:0 0 12px!important}.city-context p:first-of-type::first-letter{font-family:var(--m-serif);font-size:3.5em;line-height:.85;font-weight:500;float:left;margin:4px 10px 0 0;color:var(--m-cobalt)}.city-context em{background:var(--m-cobalt-wash)!important;color:var(--m-cobalt)!important;font-style:normal!important;padding:1px 6px!important;border-radius:4px!important;font-size:.92em!important;font-weight:500!important}.city-context strong{color:var(--m-ink)!important}.city-context ul.nearby-cities-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))!important;gap:8px!important;list-style:none!important;padding:0!important;margin:16px 0 24px!important}.city-context ul.nearby-cities-grid a{display:block!important;background:var(--m-paper)!important;border:1px solid var(--m-line)!important;border-radius:var(--m-r-sm)!important;padding:10px 14px!important;color:var(--m-ink)!important;font-weight:500!important;font-size:14px!important;text-decoration:none!important}.city-context ul.nearby-cities-grid a:hover{border-color:var(--m-cobalt)!important;color:var(--m-cobalt)!important}.canton-link a{display:inline-flex!important;align-items:center!important;gap:8px!important;background:var(--m-ink)!important;color:var(--m-paper)!important;padding:12px 22px!important;border-radius:var(--m-r-pill)!important;font-weight:500!important;font-size:15px!important;text-decoration:none!important}.canton-link a:hover{background:var(--m-cobalt)!important;color:var(--m-paper)!important;transform:translateY(-1px)}.city-faq{background:var(--m-paper)!important;border:1px solid var(--m-line)!important;border-radius:var(--m-r-md)!important;overflow:hidden;display:flex!important;flex-direction:column!important;gap:0!important}.city-faq details{background:0 0!important;border:0!important;border-bottom:1px solid var(--m-line)!important;padding:18px 22px!important;border-radius:0!important;box-shadow:none!important}.city-faq details:last-child{border-bottom:0!important}.city-faq details[open]{background:var(--m-paper-2)!important}.city-faq summary{font-family:var(--m-sans)!important;font-size:16px!important;font-weight:600!important;color:var(--m-ink)!important;cursor:pointer;list-style:none!important;display:flex!important;justify-content:space-between!important;align-items:center!important;gap:16px!important}.city-faq summary::-webkit-details-marker{display:none}.city-faq summary::after{content:'+';font-family:var(--m-serif);font-size:22px;color:var(--m-cobalt)}.city-faq details[open] summary::after{content:'−'}.city-faq details p{margin:14px 0 0!important;color:var(--m-ink-2)!important;font-size:15px!important}.cta-card,.editorial-card,.editorial-card *,.info-banner,.info-card,.message-card,.tip-card,[class*="-card"]:not([class*=weather]):not(.canton-card){border-left:none!important;border-right:none!important}#adBanner,.ad-banner,.ad-container,.ad-section{background:0 0!important;background-image:none!important}ins.adsbygoogle{background:0 0!important}ins.adsbygoogle[data-ad-status=unfilled]{display:none!important}.main-footer,footer.main-footer{background:oklch(.14 .02 250)!important;color:oklch(.72 .012 250)!important;padding:64px 0 28px!important;border:0!important}.main-footer h3,.main-footer h4{font-family:var(--m-sans)!important;font-size:12px!important;text-transform:uppercase!important;letter-spacing:.1em!important;color:oklch(.88 .012 250)!important;font-weight:600!important}.main-footer a{color:oklch(.72 .012 250)!important;font-size:14px!important}.main-footer a:hover{color:oklch(.95 .012 250)!important}.footer-bottom{border-top:1px solid oklch(.28 .02 250)!important;color:oklch(.58 .012 250)!important;font-size:12px!important}@media print{.canton-link,.city-faq,.featured-news-section,.lang-selector-custom,.nav-menu-toggle,.report-weather-section,.search-full-width,.share-section,.weather-map-section,footer,header,ins.adsbygoogle,script{display:none!important}body{background:#fff!important;color:#000!important;padding:20px}}@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:0s!important;animation-iteration-count:1!important;transition-duration:0s!important}}#currentWeather .weather-background-icon,.current-weather .weather-background-icon,.weather-background-icon{display:none!important}.weather-overlay{display:none!important}#currentWeather,.current-weather-enhanced{background:0 0!important;border:0!important;padding:0!important;margin-bottom:32px!important;position:relative!important;box-shadow:none!important;min-height:0!important}#currentWeather::after,#currentWeather::before{display:none!important}.current-weather-content{display:block!important}.current-weather-main{background:var(--m-paper)!important;border:1px solid var(--m-line)!important;border-radius:var(--m-r-lg)!important;padding:32px 28px!important;box-shadow:var(--m-el-1)!important;display:grid!important;grid-template-columns:1fr;gap:24px;align-items:center}@media (min-width:768px){.current-weather-main{grid-template-columns:1.2fr 1fr!important;gap:40px!important;padding:40px 48px!important}}.current-weather-left{display:flex!important;flex-direction:column!important;align-items:flex-start!important;gap:16px!important}.current-weather-icon-large{width:120px!important;height:120px!important}.current-weather-icon-large img{width:100%;height:100%;object-fit:contain}.current-weather-temp-section{width:100%}.current-temp-display{display:inline-flex!important;align-items:flex-start!important;gap:4px!important;line-height:1!important}.current-temp-value{font-family:var(--m-sans)!important;font-variant-numeric:tabular-nums!important;font-feature-settings:'tnum'!important;font-size:clamp(72px, 13vw, 128px)!important;font-weight:200!important;letter-spacing:-.045em!important;line-height:.9!important;color:var(--m-ink)!important}.current-temp-unit{font-family:var(--m-sans)!important;font-size:clamp(24px, 4vw, 36px)!important;font-weight:300!important;color:var(--m-ink-3)!important;margin-top:8px!important;letter-spacing:-.01em!important}#currentWeatherDescription,.current-condition-text,.current-weather-description,.weather-description-text{font-family:var(--m-serif)!important;font-style:italic!important;font-size:clamp(18px, 2.5vw, 24px)!important;font-weight:400!important;color:var(--m-ink-2)!important;margin-top:12px!important}.current-weather-right,.current-weather-stats{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:0!important;border-top:1px solid var(--m-line)!important}@media (min-width:768px){.current-weather-right,.current-weather-stats{border-top:0!important;border-left:1px solid var(--m-line)!important}}.current-weather-right>*,.current-weather-stats>*{padding:16px 20px!important;border-right:1px solid var(--m-line)!important;border-bottom:1px solid var(--m-line)!important;background:0 0!important;display:flex!important;flex-direction:column!important;gap:4px!important;border-radius:0!important}.current-weather-right>:nth-child(2n),.current-weather-stats>:nth-child(2n){border-right:0!important}.current-weather-right>:nth-last-child(-n+2),.current-weather-stats>:nth-last-child(-n+2){border-bottom:0!important}.stat-label-text,.weather-stat-label,[class*=stat-label]{font-family:var(--m-sans)!important;font-size:11px!important;font-weight:600!important;text-transform:uppercase!important;letter-spacing:.08em!important;color:var(--m-ink-3)!important}.stat-value-text,.weather-stat-value,[class*=stat-value]{font-family:var(--m-sans)!important;font-size:20px!important;font-weight:500!important;color:var(--m-ink)!important;font-variant-numeric:tabular-nums!important}.is-supporter #adBanner,.is-supporter .ad-container,.is-supporter .ad-section,.is-supporter .google-auto-placed,.is-supporter .is-supporter ins.adsbygoogle,.is-supporter .meteo-adblock-banner,.is-supporter .meteo-affiliate-panel,.is-supporter [data-google-query-id],.is-supporter iframe[src*=doubleclick],.is-supporter iframe[src*=googlesyndication],.is-supporter ins.adsbygoogle{display:none!important}.meteo-adblock-banner{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);max-width:480px;width:calc(100% - 32px);background:oklch(.985 .006 80);border:1px solid oklch(.86 .008 80);border-radius:16px;box-shadow:0 16px 40px -12px oklch(.18 .05 250 / .25);padding:14px 18px;display:flex;align-items:center;gap:12px;z-index:9000;font-family:Inter,system-ui,sans-serif}.mab-icon{font-size:22px;line-height:1}.mab-text{flex:1;font-size:13.5px;line-height:1.5;color:oklch(.3 .012 250)}.mab-link{color:oklch(.42 .2 252);font-weight:600}.mab-close{background:0 0;border:0;font-size:22px;color:oklch(.58 .012 250);cursor:pointer;padding:0 6px;line-height:1;flex-shrink:0}.mab-close:hover{color:oklch(.18 .012 250)}.meteo-affiliate-panel{max-width:1100px;margin:48px auto 16px;padding:0 24px;font-family:Inter,system-ui,sans-serif}.map-cards{display:grid;grid-template-columns:1fr;gap:12px}@media (min-width:640px){.map-cards{grid-template-columns:repeat(2,1fr)}}.map-card{background:oklch(.985 .006 80);border:1px solid oklch(.86 .008 80);border-radius:16px;padding:20px 22px;display:flex;align-items:flex-start;gap:14px;text-decoration:none;color:inherit;transition:all .2s cubic-bezier(.22,1,.36,1)}.map-card:hover{border-color:oklch(.42 .2 252);transform:translateY(-2px);box-shadow:0 12px 30px -10px oklch(.18 .05 250 / .15)}.map-card-icon{font-size:32px;line-height:1;flex-shrink:0}.map-card-body{flex:1}.map-card h3{font-family:Newsreader,Georgia,serif;font-size:18px;font-weight:500;margin:0 0 4px;color:oklch(.18 .012 250)}.map-card p{font-size:13.5px;color:oklch(.4 .015 250);margin:0 0 8px;line-height:1.5}.map-card-cta{display:inline-block;font-size:13px;font-weight:600;color:oklch(.42 .2 252)}.map-card:hover .map-card-cta{color:oklch(.52 .22 252)}.map-disclosure{font-size:11px;color:oklch(.58 .012 250);margin:14px 0 0;text-align:center}.meteo-newsletter{max-width:1100px;margin:32px auto;padding:28px;background:linear-gradient(135deg,oklch(.95 .04 252),oklch(.985 .006 80));border:1px solid oklch(.86 .008 80);border-radius:20px;display:flex;align-items:center;gap:16px;position:relative;font-family:Inter,system-ui,sans-serif}.mn-content{flex:1}.mn-content h3{font-family:Newsreader,Georgia,serif;font-size:22px;font-weight:500;margin:0 0 6px;letter-spacing:-.01em}.mn-content p{font-size:14px;color:oklch(.4 .015 250);margin:0 0 14px;line-height:1.5}.mn-form{display:flex;gap:8px;max-width:460px}.mn-form input{flex:1;padding:12px 18px;border:1px solid oklch(.86 .008 80);border-radius:999px;font-size:14px;background:#fff;color:oklch(.18 .012 250);font-family:inherit}.mn-form input:focus{outline:0;border-color:oklch(.42 .2 252);box-shadow:0 0 0 4px oklch(.42 .2 252 / .12)}.mn-form button{padding:12px 22px;border:0;border-radius:999px;background:oklch(.18 .012 250);color:#fff;font-weight:600;font-size:14px;font-family:inherit;cursor:pointer;transition:all .15s;white-space:nowrap}.mn-form button:hover{background:oklch(.42 .2 252);transform:translateY(-1px)}.mn-close{position:absolute;top:12px;right:14px;background:0 0;border:0;font-size:20px;color:oklch(.58 .012 250);cursor:pointer;line-height:1}.mn-close:hover{color:oklch(.18 .012 250)}.mn-success{padding:24px;text-align:center;font-family:Newsreader,Georgia,serif;font-size:18px;color:oklch(.42 .2 252)}@media (max-width:640px){.meteo-newsletter{flex-direction:column;align-items:stretch;padding:22px}.mn-form{flex-direction:column}.mn-form button{width:100%}}.meteo-push-bar{position:fixed;bottom:16px;left:16px;right:16px;max-width:480px;margin:0 auto;background:oklch(.18 .012 250);color:oklch(.985 .006 80);padding:14px 16px;border-radius:16px;box-shadow:0 16px 40px -12px oklch(.18 .05 250 / .5);display:flex;align-items:center;gap:12px;z-index:9001;font-family:Inter,system-ui,sans-serif;animation:meteoPushIn .32s cubic-bezier(.22,1,.36,1)}@keyframes meteoPushIn{from{transform:translateY(120%);opacity:0}to{transform:translateY(0);opacity:1}}.mpb-icon{font-size:24px;line-height:1}.mpb-text{flex:1;display:flex;flex-direction:column}.mpb-text strong{font-size:14px;font-weight:600}.mpb-text span{font-size:12.5px;opacity:.78;margin-top:2px;line-height:1.4}.mpb-no,.mpb-yes{background:0 0;border:1px solid oklch(.58 .012 250 / .5);color:oklch(.985 .006 80);padding:7px 14px;border-radius:999px;font-weight:600;font-size:12.5px;font-family:inherit;cursor:pointer;transition:all .15s;white-space:nowrap}.mpb-yes{background:oklch(.42 .2 252);border-color:oklch(.42 .2 252)}.mpb-yes:hover{background:oklch(.52 .22 252);transform:translateY(-1px)}.mpb-no:hover{color:oklch(.985 .006 80);border-color:oklch(.985 .006 80)}@media (max-width:480px){.meteo-push-bar{flex-wrap:wrap}.mpb-text{flex:1 1 100%;order:-1}}#adBanner,.ad-banner,.ad-container,.ad-section{display:block!important;background:0 0!important;background-image:none!important;visibility:visible!important}ins.adsbygoogle{display:block!important;background:0 0!important}ins.adsbygoogle[data-ad-status=unfilled]{display:none!important}.google-auto-placed,[id^=google_ads_iframe_],iframe[src*=doubleclick],iframe[src*=googlesyndication]{display:block!important;visibility:visible!important}.is-supporter #adBanner,.is-supporter .ad-container,.is-supporter .ad-section,.is-supporter .google-auto-placed,.is-supporter .is-supporter ins.adsbygoogle,.is-supporter .meteo-affiliate-panel,.is-supporter iframe[src*=doubleclick],.is-supporter iframe[src*=googlesyndication],.is-supporter ins.adsbygoogle{display:none!important}#weatherAlertBanner,.weather-alert-banner{position:static!important;top:auto!important;z-index:auto!important;background:oklch(.72 .18 50)!important;background-image:none!important;border:2px solid oklch(.55 .22 40)!important;border-left-width:6px!important;border-bottom-width:2px!important;border-right-width:2px!important;border-top-width:2px!important;border-radius:12px!important;padding:16px 20px!important;margin:14px 0 18px!important;color:oklch(.18 .05 40)!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;box-shadow:0 4px 12px oklch(.55 .22 40 / .25)!important}#weatherAlertBanner .alert-banner-content,.weather-alert-banner .alert-banner-content{display:flex!important;align-items:center!important;gap:14px!important;color:inherit!important}#weatherAlertBanner .alert-banner-icon,.weather-alert-banner .alert-banner-icon{font-size:22px!important;flex-shrink:0;filter:drop-shadow(0 1px 2px oklch(.62 .2 40 / .3))}#weatherAlertBanner .alert-banner-text,.weather-alert-banner .alert-banner-text{color:oklch(.18 .05 40)!important;flex:1;min-width:0}#weatherAlertBanner #alertBannerTitle,.weather-alert-banner #alertBannerTitle{display:block!important;font-family:var(--m-sans)!important;font-weight:800!important;font-size:14px!important;text-transform:uppercase!important;letter-spacing:.08em!important;color:oklch(.18 .05 40)!important;margin-bottom:8px!important;text-shadow:0 1px 0 oklch(1 0 0 / .3)!important}#weatherAlertBanner .alert-cities-scroll,.weather-alert-banner .alert-cities-scroll{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none}#weatherAlertBanner .alert-city-item,.weather-alert-banner .alert-city-item{background:oklch(.99 .005 80)!important;border:1.5px solid oklch(.55 .22 40)!important;color:oklch(.18 .05 40)!important;padding:7px 14px!important;border-radius:999px!important;font-size:13px!important;font-weight:600!important;white-space:nowrap;flex-shrink:0;backdrop-filter:none!important;box-shadow:0 1px 2px oklch(0 0 0 / .08)!important}#weatherAlertBanner .alert-city-temp,.weather-alert-banner .alert-city-temp{color:oklch(.45 .22 40)!important;font-weight:800!important}.header-left .site-logo,.site-logo,.site-logo-link .site-logo,header .site-logo,img.site-logo{height:176px!important;max-width:480px!important;min-height:176px!important;width:auto!important;object-fit:contain!important;pointer-events:none!important;display:block!important}@media (max-width:640px){.site-logo,header .site-logo,img.site-logo{height:120px!important;min-height:120px!important;max-width:320px!important}}.header-left .site-logo-link,.site-logo-link,a.site-logo-link{position:relative!important;z-index:50!important;display:inline-flex!important;pointer-events:auto!important;cursor:pointer!important}.header-left,.header-top,header,header .container{overflow:visible!important}.ad-slot{min-height:0!important;margin:8px auto!important}.ad-slot:not(:has(iframe)){min-height:0!important;margin:0 auto!important}.ad-slot ins.adsbygoogle[data-ad-status=unfilled]{display:none!important}#introSection,.intro-section{padding:0!important;margin:12px 0 20px!important;background:0 0!important;border:0!important}.intro-content{max-width:680px}#introTitle,.intro-section h1{font-family:var(--m-serif)!important;font-size:clamp(20px, 2.2vw, 26px)!important;font-weight:500!important;letter-spacing:-.012em!important;line-height:1.25!important;color:var(--m-ink)!important;margin:0 0 4px!important}#introText,.intro-section p,.intro-text{font-family:var(--m-sans)!important;font-size:13.5px!important;line-height:1.5!important;color:var(--m-ink-2)!important;margin:0!important;max-width:60ch!important}body[data-city] .intro-section{display:none!important}html[data-city] .intro-section{display:none!important}main.container{padding-top:8px!important}