*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:var(--text-primary, #1a1a1a);background-color:var(--bg-secondary, #f5f5f5);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=dark]{color-scheme:dark}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{color:#2196f3;text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.3}p{margin:0 0 1rem}p:last-child{margin-bottom:0}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.current-banner{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:center;gap:1rem;padding:.5rem 1rem;background:var(--card-bg, #ffffff);border-bottom:1px solid var(--border-color, #e0e0e0);box-shadow:0 2px 4px #00000014;min-height:50px;flex-wrap:wrap}.current-banner-spacer{height:50px;min-height:50px}.current-banner--loading,.current-banner--error{justify-content:center}.banner-loading-text,.banner-error-text{font-size:.875rem;color:var(--text-muted, #666)}.banner-error-text{color:var(--error-color, #dc3545)}.banner-item{display:flex;align-items:center;gap:.25rem}.banner-divider{width:1px;height:24px;background:var(--border-color, #e0e0e0)}.banner-location-name{font-weight:600;font-size:.9rem;color:var(--text-color, #333);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.banner-temp-value{font-size:1.25rem;font-weight:700}.banner-conditions-text{font-size:.875rem;color:var(--text-muted, #666);white-space:nowrap}.banner-label{font-size:.75rem;color:var(--text-muted, #888);text-transform:uppercase;letter-spacing:.02em}.banner-feels-value,.banner-precip-value,.banner-wind-value{font-size:.9rem;font-weight:600}.banner-sun-icon{font-size:1rem;margin-right:.25rem}.banner-sun-times{font-size:.8rem;color:var(--text-muted, #666);white-space:nowrap}.banner-clock{gap:.35rem}.banner-clock-icon{font-size:.9rem}.banner-clock-times{display:flex;flex-direction:column;align-items:flex-start;gap:0;line-height:1.1}.banner-local-time{font-size:.85rem;font-weight:600;color:var(--text-color, #333)}.banner-utc-time{font-size:.7rem;color:var(--text-muted, #888);font-family:SF Mono,Monaco,Inconsolata,monospace}.banner-theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border-color, #ddd);border-radius:50%;background:var(--bg-secondary, #f5f5f5);cursor:pointer;font-size:1.1rem;transition:all .2s ease;margin-left:.5rem}.banner-theme-toggle:hover{background:var(--accent-bg, #e3f2fd);border-color:var(--accent-border, #90caf9);transform:scale(1.1)}.banner-theme-toggle:active{transform:scale(.95)}.banner-spacer{flex:1;min-width:1rem}.banner-forecast-time{display:flex;align-items:center;gap:0;position:relative}.banner-forecast-display{background:var(--accent-bg, #e3f2fd);padding:.25rem .75rem;border:1px solid var(--accent-border, #90caf9);display:flex;align-items:center;gap:.25rem;cursor:pointer;transition:background-color .15s;font-family:inherit}.banner-forecast-display:hover{background:var(--accent-hover, #bbdefb)}.banner-forecast-chevron{font-size:.6rem;margin-left:.25rem;color:var(--accent-color, #1976d2)}.banner-time-nav{display:flex;align-items:center;justify-content:center;width:28px;height:32px;border:1px solid var(--accent-border, #90caf9);background:var(--accent-bg, #e3f2fd);color:var(--accent-color, #1976d2);cursor:pointer;font-size:.7rem;transition:background-color .15s,color .15s}.banner-time-back{border-radius:4px 0 0 4px;border-right:none}.banner-time-forward{border-radius:0 4px 4px 0;border-left:none}.banner-time-nav:hover{background:var(--accent-color, #1976d2);color:#fff}.banner-time-nav:active{transform:scale(.95)}.banner-forecast-label{font-size:.7rem;color:var(--text-muted, #666);text-transform:uppercase;letter-spacing:.02em;margin-right:.35rem}.banner-forecast-value{font-size:.85rem;font-weight:600;color:var(--accent-color, #1976d2);white-space:nowrap}.banner-datetime-picker{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;box-shadow:0 4px 12px #00000026;padding:1rem;z-index:200;min-width:240px}.picker-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary, #666);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.02em}.picker-input{width:100%;padding:.5rem;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:.9rem;font-family:inherit;background:var(--bg-primary, #fff);color:var(--text-primary, #333)}.picker-input:focus{outline:none;border-color:var(--primary-color, #2196f3);box-shadow:0 0 0 2px #2196f333}.picker-quick-buttons{display:flex;gap:.5rem;margin-top:.75rem}.picker-quick-btn{flex:1;padding:.4rem .75rem;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--bg-secondary, #f5f5f5);color:var(--text-primary, #333);font-size:.8rem;font-family:inherit;cursor:pointer;transition:all .15s}.picker-quick-btn:hover{background:var(--primary-color, #2196f3);color:#fff;border-color:var(--primary-color, #2196f3)}.banner-mobile{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;flex-direction:column;padding:.4rem .75rem;background:var(--card-bg, #ffffff);border-bottom:1px solid var(--border-color, #e0e0e0);box-shadow:0 2px 4px #00000014}.banner-row-main{display:flex;align-items:center;justify-content:space-between;gap:.5rem;height:32px}.banner-location-short{font-weight:600;font-size:.85rem;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-color, #333)}.banner-temp-compact{font-size:1.1rem;font-weight:700}.banner-condition-icon{font-size:1.2rem;line-height:1}.banner-expand-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--bg-secondary, #f5f5f5);cursor:pointer;font-size:.75rem;color:var(--text-muted, #666);transition:all .15s ease}.banner-expand-btn:hover{background:var(--accent-bg, #e3f2fd);border-color:var(--accent-border, #90caf9)}.banner-expand-btn:active{transform:scale(.95)}.banner-theme-toggle-mobile{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border-color, #ddd);border-radius:50%;background:var(--bg-secondary, #f5f5f5);cursor:pointer;font-size:.9rem;transition:all .15s ease}.banner-theme-toggle-mobile:hover{background:var(--accent-bg, #e3f2fd);border-color:var(--accent-border, #90caf9)}.banner-row-time{display:flex;align-items:center;justify-content:center;gap:.5rem;height:28px;margin-top:.25rem;position:relative}.banner-time-nav-mobile{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:1px solid var(--accent-border, #90caf9);border-radius:4px;background:var(--accent-bg, #e3f2fd);color:var(--accent-color, #1976d2);cursor:pointer;font-size:.65rem;transition:all .15s ease}.banner-time-nav-mobile:hover{background:var(--accent-color, #1976d2);color:#fff}.banner-time-nav-mobile:active{transform:scale(.95)}.banner-forecast-btn-mobile{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.8rem;font-weight:600;font-family:inherit;border-radius:4px;background:var(--accent-bg, #e3f2fd);border:1px solid var(--accent-border, #90caf9);color:var(--accent-color, #1976d2);cursor:pointer;transition:all .15s ease;white-space:nowrap}.banner-forecast-btn-mobile:hover{background:var(--accent-hover, #bbdefb)}.banner-forecast-chevron-mobile{font-size:.55rem;margin-left:.15rem}.banner-utc-mobile{font-size:.7rem;font-family:SF Mono,Monaco,Inconsolata,monospace;color:var(--text-muted, #888);margin-left:.25rem}.banner-details{animation:slideDown .2s ease-out;border-top:1px solid var(--border-color, #e0e0e0);margin-top:.5rem;padding-top:.5rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.banner-row-stats{display:flex;justify-content:center;gap:1rem;font-size:.8rem}.banner-stat-item{display:flex;align-items:center;gap:.25rem}.banner-stat-label{font-size:.7rem;color:var(--text-muted, #888);text-transform:uppercase;letter-spacing:.02em}.banner-stat-value{font-size:.85rem;font-weight:600}.banner-row-sun{display:flex;justify-content:center;align-items:center;gap:.35rem;font-size:.8rem;margin-top:.35rem;color:var(--text-muted, #666)}.banner-sun-icon-mobile{font-size:.9rem}.banner-sun-times-mobile{font-size:.8rem}.banner-datetime-picker-mobile{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:.5rem;min-width:260px}@media(max-width:600px){.current-banner-spacer{height:70px;min-height:70px;transition:height .2s ease}.current-banner-spacer.expanded{height:130px;min-height:130px}.current-banner{display:none}}@media(min-width:601px){.banner-mobile{display:none}}[data-theme=dark] .banner-mobile{background:var(--card-bg, #1e1e1e);border-bottom-color:var(--border-color, #333);box-shadow:0 2px 4px #0000004d}[data-theme=dark] .banner-location-short{color:var(--text-color, #e0e0e0)}[data-theme=dark] .banner-expand-btn{background:var(--bg-secondary, #2a2a2a);border-color:var(--border-color, #444);color:var(--text-muted, #999)}[data-theme=dark] .banner-expand-btn:hover{background:var(--accent-bg, #1a3a5c);border-color:var(--accent-border, #2d5a87)}[data-theme=dark] .banner-theme-toggle-mobile{background:var(--bg-secondary, #2a2a2a);border-color:var(--border-color, #444)}[data-theme=dark] .banner-theme-toggle-mobile:hover{background:var(--accent-bg, #1a3a5c);border-color:var(--accent-border, #2d5a87)}[data-theme=dark] .banner-time-nav-mobile{background:var(--accent-bg, #1a3a5c);border-color:var(--accent-border, #2d5a87);color:var(--accent-color, #64b5f6)}[data-theme=dark] .banner-time-nav-mobile:hover{background:var(--accent-color, #64b5f6);color:#1a3a5c}[data-theme=dark] .banner-forecast-btn-mobile{background:var(--accent-bg, #1a3a5c);border-color:var(--accent-border, #2d5a87);color:var(--accent-color, #64b5f6)}[data-theme=dark] .banner-forecast-btn-mobile:hover{background:var(--accent-hover, #254a6f)}[data-theme=dark] .banner-utc-mobile{color:var(--text-muted, #999)}[data-theme=dark] .banner-details{border-top-color:var(--border-color, #333)}[data-theme=dark] .banner-stat-label,[data-theme=dark] .banner-row-sun{color:var(--text-muted, #999)}[data-theme=dark] .current-banner{background:var(--card-bg, #1e1e1e);border-bottom-color:var(--border-color, #333);box-shadow:0 2px 4px #0000004d}[data-theme=dark] .banner-forecast-display{background:var(--accent-bg, #1a3a5c);border-color:var(--accent-border, #2d5a87)}[data-theme=dark] .banner-time-nav{background:var(--accent-bg, #1a3a5c);border-color:var(--accent-border, #2d5a87);color:var(--accent-color, #64b5f6)}[data-theme=dark] .banner-time-nav:hover{background:var(--accent-color, #64b5f6);color:#1a3a5c}[data-theme=dark] .banner-forecast-value{color:var(--accent-color, #64b5f6)}[data-theme=dark] .banner-forecast-display:hover{background:var(--accent-hover, #254a6f)}[data-theme=dark] .banner-forecast-chevron{color:var(--accent-color, #64b5f6)}[data-theme=dark] .banner-datetime-picker{background:var(--card-bg, #1e1e1e);border-color:var(--border-color, #333);box-shadow:0 4px 12px #0006}[data-theme=dark] .picker-input,[data-theme=dark] .picker-quick-btn{background:var(--bg-secondary, #2a2a2a);border-color:var(--border-color, #444);color:var(--text-primary, #e0e0e0)}[data-theme=dark] .picker-quick-btn:hover{background:var(--primary-color, #2196f3);color:#fff;border-color:var(--primary-color, #2196f3)}[data-theme=dark] .banner-local-time{color:var(--text-color, #e0e0e0)}[data-theme=dark] .banner-utc-time{color:var(--text-muted, #999)}[data-theme=dark] .banner-theme-toggle{background:var(--bg-secondary, #2a2a2a);border-color:var(--border-color, #444)}[data-theme=dark] .banner-theme-toggle:hover{background:var(--accent-bg, #1a3a5c);border-color:var(--accent-border, #2d5a87)}.blend-status-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#9c27b014;border:1px solid rgba(156,39,176,.25);border-radius:var(--border-radius, 8px);margin-bottom:1rem;font-size:.9rem;transition:opacity .3s ease,transform .3s ease}.blend-status-banner.dismissed{opacity:0;transform:translateY(-10px);pointer-events:none;height:0;padding:0;margin:0;overflow:hidden}.blend-status-banner .banner-icon{font-size:1.2rem;color:#9c27b0;flex-shrink:0}.blend-status-banner .banner-content{flex:1;color:var(--text-secondary, #666);line-height:1.4}.blend-status-banner strong{color:#9c27b0}.blend-status-banner .affected-models{white-space:nowrap}.blend-status-banner .model-name{font-weight:600}.blend-status-banner .banner-dismiss{background:none;border:none;color:var(--text-secondary, #666);font-size:1.2rem;cursor:pointer;padding:.25rem;line-height:1;opacity:.6;transition:opacity .2s ease;flex-shrink:0}.blend-status-banner .banner-dismiss:hover{opacity:1}[data-theme=dark] .blend-status-banner{background:#9c27b01f;border-color:#9c27b059}[data-theme=dark] .blend-status-banner .banner-content,[data-theme=dark] .blend-status-banner .banner-dismiss{color:var(--text-secondary, #aaa)}@media(max-width:768px){.blend-status-banner{padding:.5rem .75rem;font-size:.8rem;gap:.5rem}.blend-status-banner .banner-icon{font-size:1rem}.blend-status-banner .affected-models{white-space:normal}}.mobile-nav-modern{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1000;padding:.5rem .75rem;padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0px))}@media(max-width:768px){.mobile-nav-modern{display:block}}.mobile-nav-inner{display:flex;align-items:center;position:relative;background:#ffffffd9;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:20px;padding:.375rem;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d,inset 0 1px #fff9;border:1px solid rgba(255,255,255,.3)}:root[data-theme=dark] .mobile-nav-inner{background:#1e1e1ed9;box-shadow:0 4px 24px #0000004d,0 1px 3px #0003,inset 0 1px #ffffff0d;border:1px solid rgba(255,255,255,.08)}.nav-indicator{position:absolute;top:.375rem;left:.375rem;width:calc(25% - .1875rem);height:calc(100% - .75rem);background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:16px;transition:transform .35s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 8px #3b82f666,0 0 0 1px #3b82f61a;z-index:0}:root[data-theme=dark] .nav-indicator{background:linear-gradient(135deg,#60a5fa,#3b82f6);box-shadow:0 2px 12px #60a5fa80,0 0 0 1px #60a5fa33}.mobile-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.625rem .5rem;background:transparent;border:none;cursor:pointer;position:relative;z-index:1;overflow:hidden;border-radius:16px;transition:transform .2s ease;-webkit-tap-highlight-color:transparent}.mobile-nav-btn:active{transform:scale(.95)}.nav-icon-wrapper{display:flex;align-items:center;justify-content:center;width:28px;height:28px;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.nav-icon-svg{display:flex;align-items:center;justify-content:center}.nav-icon-svg svg{width:22px;height:22px;stroke:var(--text-secondary, #666);transition:stroke .3s ease,transform .3s ease}.mobile-nav-btn.active .nav-icon-svg svg{stroke:#fff}.mobile-nav-btn.active .nav-icon-wrapper{transform:translateY(-1px)}.mobile-nav-btn:not(.active):hover .nav-icon-svg svg{stroke:var(--primary-color, #3b82f6)}.mobile-nav-btn .nav-label{font-size:.65rem;font-weight:600;letter-spacing:.02em;color:var(--text-secondary, #666);transition:color .3s ease,transform .3s ease;text-transform:uppercase}.mobile-nav-btn.active .nav-label{color:#fff;transform:translateY(-1px)}.mobile-nav-btn:not(.active):hover .nav-label{color:var(--primary-color, #3b82f6)}.nav-ripple{position:absolute;width:100px;height:100px;background:#3b82f64d;border-radius:50%;transform:translate(-50%,-50%) scale(0);animation:ripple-expand .5s ease-out forwards;pointer-events:none}.mobile-nav-btn.active .nav-ripple{background:#ffffff4d}@keyframes ripple-expand{0%{transform:translate(-50%,-50%) scale(0);opacity:1}to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}@media(max-width:380px){.mobile-nav-modern{padding:.375rem .5rem}.mobile-nav-inner{border-radius:16px;padding:.25rem}.nav-indicator{border-radius:14px}.mobile-nav-btn{padding:.5rem .25rem;border-radius:14px}.nav-icon-svg svg{width:20px;height:20px}.mobile-nav-btn .nav-label{font-size:.6rem}}@media(max-height:500px)and (orientation:landscape){.mobile-nav-modern{padding:.25rem 1rem}.mobile-nav-inner{max-width:400px;margin:0 auto}.mobile-nav-btn{flex-direction:row;gap:.5rem;padding:.5rem .75rem}.nav-icon-wrapper{width:24px;height:24px}.nav-icon-svg svg{width:18px;height:18px}}@media(prefers-reduced-motion:reduce){.nav-indicator{transition:none}.mobile-nav-btn,.nav-icon-wrapper,.nav-icon-svg svg,.mobile-nav-btn .nav-label{transition:none}.nav-ripple{animation:none}}@media(max-width:768px){.mobile-nav{display:none!important}}:root{--primary-color: #2196f3;--secondary-color: #4caf50;--warning-color: #ff9800;--error-color: #f44336;--text-primary: #1a1a1a;--text-secondary: #666;--text-muted: #999;--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e0e0e0;--border-color: #ddd;--border-radius: 8px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .12);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .15);--transition-fast: .15s ease;--transition-normal: .25s ease;--header-gradient-start: #2196f3;--header-gradient-end: #1976d2;--focus-ring: 0 0 0 3px rgba(33, 150, 243, .4)}*:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}button:focus-visible,input:focus-visible,select:focus-visible,a:focus-visible{box-shadow:var(--focus-ring)}.skip-to-content{position:absolute;top:-40px;left:0;padding:.75rem 1rem;background:var(--primary-color);color:#fff;z-index:1000;transition:top var(--transition-fast)}.skip-to-content:focus{top:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root[data-theme=dark]{--focus-ring: 0 0 0 3px rgba(100, 181, 246, .4);--primary-color: #64b5f6;--secondary-color: #81c784;--warning-color: #ffb74d;--error-color: #ef5350;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-muted: #808080;--bg-primary: #1e1e1e;--bg-secondary: #2d2d2d;--bg-tertiary: #3d3d3d;--border-color: #444;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px rgba(0, 0, 0, .35);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .5);--header-gradient-start: #1565c0;--header-gradient-end: #0d47a1}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-secondary)}.app-main{flex:1;max-width:1400px;margin:0 auto;padding:1.5rem;width:100%;box-sizing:border-box}.app-header{background:linear-gradient(135deg,var(--header-gradient-start),var(--header-gradient-end));color:#fff;padding:1rem 1.5rem;box-shadow:var(--shadow-md)}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.header-title h1{margin:0;font-size:1.75rem;font-weight:600}.header-subtitle{margin:.25rem 0 0;opacity:.9;font-size:.9rem}.header-info{text-align:right}.current-time{font-size:.85rem}.time-label{opacity:.8;margin-right:.5rem}.header-actions{display:flex;align-items:center;gap:1rem}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#ffffff26;border:2px solid rgba(255,255,255,.3);border-radius:50%;color:#fff;font-size:1.25rem;cursor:pointer;transition:all var(--transition-fast)}.theme-toggle:hover{background:#ffffff40;border-color:#ffffff80;transform:scale(1.05)}.theme-toggle:active{transform:scale(.95)}.app-footer{background:var(--bg-primary);padding:1rem 1.5rem;text-align:center;border-top:1px solid var(--border-color);font-size:.85rem;color:var(--text-secondary)}.app-footer a{color:var(--primary-color);text-decoration:none}.app-footer a:hover{text-decoration:underline}.footer-disclaimer{margin-top:.5rem;font-size:.8rem;color:var(--text-muted)}.section{background:var(--bg-primary);border-radius:var(--border-radius);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.section-title{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.collapsible-section{padding:0;overflow:hidden}.collapsible-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1rem 1.5rem;background:transparent;border:none;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.collapsible-header:hover{background:var(--bg-secondary)}.collapsible-header .section-title{margin:0}.collapse-indicator{font-size:.85rem;color:var(--text-muted);transition:transform var(--transition-fast)}.collapsible-content{padding:0 1.5rem 1.5rem}.collapsible-section.collapsed .collapsible-header{padding-bottom:1rem}.time-display-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;background:var(--bg-primary);padding:1rem 1.5rem;border-radius:var(--border-radius);border-left:4px solid var(--primary-color);box-shadow:var(--shadow-sm)}.time-display-row .time-display{background:none;padding:0;margin-bottom:0;border-left:none;box-shadow:none}.time-display{background:var(--bg-primary);padding:1rem 1.5rem;margin-bottom:1.5rem;border-radius:var(--border-radius);border-left:4px solid var(--primary-color);box-shadow:var(--shadow-sm)}.time-display .time-label{color:var(--text-secondary);margin-right:.5rem}.time-display .time-value{font-weight:600;color:var(--text-primary)}.confidence-section{margin-bottom:1.5rem}.confidence-section .confidence-score{box-shadow:var(--shadow-sm);border-radius:var(--border-radius)}@media(max-width:768px){.time-display-row{flex-direction:column;align-items:flex-start;gap:.75rem}}.control-panel{display:flex;flex-direction:column;gap:1.5rem}.control-section{display:flex;flex-direction:column;gap:.75rem}.location-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.or-divider{color:var(--text-muted);font-style:italic}.selected-location{padding:.75rem 1rem;background:var(--bg-secondary);border-radius:var(--border-radius);display:flex;align-items:center;gap:.5rem}.location-name{font-weight:600}.location-coords{color:var(--text-secondary);font-size:.9rem}.location-search{position:relative;flex:1;min-width:250px;max-width:400px}.search-input-wrapper{position:relative}.search-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:1rem;transition:border-color var(--transition-fast);box-sizing:border-box}.search-input:focus{outline:none;border-color:var(--primary-color)}.search-spinner,.search-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}.search-clear{background:none;border:none;font-size:1.25rem;color:var(--text-muted);cursor:pointer;padding:.25rem;line-height:1}.search-clear:hover{color:var(--text-primary)}.mini-spinner{width:20px;height:20px;border:2px solid var(--bg-tertiary);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.search-results{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);margin-top:.25rem;max-height:300px;overflow-y:auto;z-index:100;list-style:none;padding:0;margin-left:0}.search-result-item{display:flex;align-items:center;padding:.75rem 1rem;cursor:pointer;transition:background var(--transition-fast)}.search-result-item:hover,.search-result-item.highlighted{background:var(--bg-secondary)}.result-main{flex:1;min-width:0}.result-name{font-weight:500}.result-details{font-size:.85rem;color:var(--text-secondary)}.result-population{margin-left:.5rem;opacity:.7}.result-favorite-btn{flex-shrink:0;background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;color:var(--warning-color);transition:transform var(--transition-fast),opacity var(--transition-fast)}.result-favorite-btn:hover:not(:disabled){transform:scale(1.2)}.result-favorite-btn:disabled{opacity:.5;cursor:not-allowed}.search-error{color:var(--error-color);font-size:.85rem;margin-top:.25rem}.search-with-geo{display:flex;gap:.5rem;align-items:stretch}.search-with-geo .search-input-wrapper{flex:1}.geolocation-btn{display:flex;align-items:center;justify-content:center;width:44px;min-width:44px;padding:0;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--border-radius);color:var(--primary-color);cursor:pointer;transition:all var(--transition-fast)}.geolocation-btn:hover:not(:disabled){background:var(--primary-color);border-color:var(--primary-color);color:#fff}.geolocation-btn:disabled{opacity:.6;cursor:not-allowed}.geolocation-btn:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #2196f333}.geo-spinner{width:16px;height:16px;border:2px solid var(--bg-tertiary);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.geo-error{display:flex;align-items:center;gap:.25rem}.geo-error:before{content:"u26A0"}.location-selector{display:flex;align-items:center;gap:.5rem}.selector-label{font-size:.9rem;color:var(--text-secondary);white-space:nowrap}.location-dropdown{padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:1rem;background:var(--bg-primary);cursor:pointer;min-width:180px}.location-dropdown:focus{outline:none;border-color:var(--primary-color)}.datetime-selector{display:flex;flex-direction:column;gap:.75rem}.datetime-selects{display:flex;gap:1rem;flex-wrap:wrap}.date-select-wrapper,.hour-select-wrapper{display:flex;align-items:center;gap:.5rem}.date-select,.hour-select{padding:.5rem 1rem;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:.95rem;background:var(--bg-primary);cursor:pointer}.date-select:focus,.hour-select:focus{outline:none;border-color:var(--primary-color)}.hour-stepper{display:flex;align-items:center;gap:.25rem}.step-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary)}.step-btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.step-btn:active{transform:scale(.95)}.quick-times{display:flex;gap:.5rem;flex-wrap:wrap}.quick-time-btn{padding:.4rem .8rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.quick-time-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.selected-time-display{padding:.5rem;background:var(--bg-secondary);border-radius:var(--border-radius);font-size:.9rem;font-family:monospace}.model-selector{display:flex;flex-direction:column;gap:1rem}.model-checkboxes{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.model-checkbox{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:var(--bg-secondary);border:2px solid transparent;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-fast)}.model-checkbox:hover{background:var(--bg-tertiary)}.model-checkbox.checked{background:var(--model-color);color:#fff}.model-checkbox.checked .model-name{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.model-checkbox input{display:none}.model-color-dot{width:12px;height:12px;border-radius:50%}.model-name{font-weight:500;color:var(--text-primary)}.select-all-btn{padding:.4rem .8rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:.85rem;cursor:pointer}.select-all-btn:hover{background:var(--bg-tertiary)}.additional-options{display:flex;gap:1.5rem;flex-wrap:wrap}.option-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer}.option-checkbox input{width:18px;height:18px;accent-color:var(--primary-color)}.option-label{font-size:.95rem;color:var(--text-primary)}.model-controls-section{margin-bottom:1rem}.model-controls-panel{background:var(--bg-primary);border-radius:var(--border-radius);padding:1rem 1.25rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem}.model-grid{margin-top:1rem}.model-cards{display:grid;gap:1rem}.model-cards.grid-1{grid-template-columns:1fr;max-width:400px}.model-cards.grid-2{grid-template-columns:repeat(2,1fr)}.model-cards.grid-3{grid-template-columns:repeat(3,1fr)}.model-cards.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1200px){.model-cards.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.model-cards.grid-2,.model-cards.grid-3,.model-cards.grid-4{grid-template-columns:1fr}}.model-card{border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-sm);background:var(--bg-primary)}.model-card-header{padding:.75rem 1rem;color:#fff;display:flex;justify-content:space-between;align-items:center}.model-card-header h3{margin:0;font-size:1.1rem;font-weight:600}.model-resolution{font-size:.8rem;opacity:.9}.model-header-actions{display:flex;align-items:center;gap:.5rem}.run-history-btn{background:#fff3;border:none;border-radius:4px;padding:.2rem .5rem;cursor:pointer;font-size:.75rem;font-weight:500;color:#fff;transition:background .2s,transform .15s;white-space:nowrap}.run-history-btn:hover{background:#ffffff59;transform:scale(1.05)}.run-history-btn:active{transform:scale(.95)}.model-card-body{padding:1rem}.model-out-of-range{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;margin:-1rem -1rem 1rem;background:linear-gradient(135deg,#ff980026,#ffc1071a);border-bottom:1px solid rgba(255,152,0,.3)}.out-of-range-icon{font-size:1.25rem;color:var(--warning-color, #ff9800)}.out-of-range-message{display:flex;flex-direction:column;font-size:.85rem;font-weight:500;color:var(--warning-color, #ff9800)}.out-of-range-detail{font-size:.75rem;font-weight:400;color:var(--text-muted, #888);margin-top:.15rem}.model-value-row{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid var(--bg-secondary)}.model-value-row:last-child{border-bottom:none}.value-label{color:var(--text-secondary);font-size:.9rem}.value-data{font-weight:600;font-family:monospace;color:var(--text-primary)}.model-card-footer{padding:.5rem 1rem;background:var(--bg-secondary);display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted)}.forecast-table-section{margin-top:.75rem;padding-top:.75rem;border-top:1px dashed var(--border-color)}.forecast-table-header{font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.forecast-table{display:flex;flex-direction:column;gap:.25rem}.forecast-table-head{display:grid;grid-template-columns:50px repeat(4,1fr);gap:.25rem;margin-bottom:.25rem;padding-bottom:.25rem;border-bottom:1px solid var(--border-color)}.forecast-col-header{display:flex;flex-direction:column;align-items:center;text-align:center}.forecast-period{font-size:.7rem;font-weight:600;color:var(--text-muted)}.forecast-time{font-size:.6rem;color:var(--text-muted);opacity:.8;white-space:nowrap}.forecast-row{display:grid;grid-template-columns:50px repeat(4,1fr);gap:.25rem;align-items:center}.forecast-row-label{font-size:.75rem;font-weight:500;color:var(--text-secondary)}.forecast-cell{display:flex;justify-content:center;padding:.25rem;background:var(--bg-secondary);border-radius:4px}.forecast-value{font-size:.85rem;font-weight:600;font-family:monospace}.wind-arrow{display:inline-flex;align-items:center;gap:4px}.wind-arrow-label{font-weight:600;font-size:.9rem}.wind-arrow-speed{font-family:monospace;font-size:.85rem}.wind-arrow-gusts{font-size:.8rem;opacity:.85}.wind-display-arrow{vertical-align:middle}.precip-with-type{display:flex;align-items:center;gap:6px}.precip-icon{display:inline-flex;align-items:center;gap:4px}.precip-icon-svg{display:inline-flex;align-items:center;justify-content:center}.precip-type-label{font-size:.8rem;font-weight:500}.precip-type-indicator{font-size:.75rem;font-weight:500;text-transform:uppercase;padding:1px 4px;border-radius:3px;background:var(--bg-secondary)}.pressure-trend{font-size:1.1em;font-weight:700;margin-left:4px}.snow-totals-section{margin-top:.75rem;padding-top:.75rem;border-top:1px dashed var(--border-color);background:linear-gradient(180deg,rgba(144,202,249,.05) 0%,transparent 100%);border-radius:4px;padding:.75rem;margin:.75rem -.5rem 0}.snow-totals-header{font-size:.8rem;font-weight:600;color:#1e88e5;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:.35rem}.snow-icon{font-size:1rem}.snow-totals-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.snow-total-item{display:flex;flex-direction:column;align-items:center;padding:.4rem;background:#90caf91a;border-radius:4px}.snow-period{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.snow-value{font-size:.9rem;font-weight:600;font-family:monospace}.rain-totals-section{margin-top:.75rem;padding-top:.75rem;border-top:1px dashed var(--border-color);background:linear-gradient(180deg,rgba(33,150,243,.05) 0%,transparent 100%);border-radius:4px;padding:.75rem;margin:.75rem -.5rem 0}.rain-totals-header{font-size:.8rem;font-weight:600;color:#1976d2;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:.35rem}.rain-icon{font-size:1rem}.rain-totals-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.rain-total-item{display:flex;flex-direction:column;align-items:center;padding:.4rem;background:#2196f31a;border-radius:4px}.rain-period{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.rain-value{font-size:.9rem;font-weight:600;font-family:monospace}.run-history-section{margin-top:.75rem;padding-top:.75rem;border-top:1px dashed var(--border-color)}.run-history-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem;background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:.85rem;color:var(--text-secondary);transition:background-color .2s,border-color .2s}.run-history-toggle:hover{background:var(--bg-secondary);border-color:var(--text-muted)}.run-history-section.expanded .run-history-toggle{border-bottom-left-radius:0;border-bottom-right-radius:0;background:var(--bg-secondary)}.toggle-icon{font-size:.7rem;color:var(--text-muted)}.toggle-label{font-weight:500}.toggle-summary{margin-left:auto;font-size:.8rem;font-weight:600;font-family:monospace}.toggle-summary.up{color:#f44336}.toggle-summary.down{color:#2196f3}.toggle-summary.unchanged{color:var(--text-muted)}.run-history-content{padding:.75rem;border:1px solid var(--border-color);border-top:none;border-radius:0 0 4px 4px;background:var(--bg-secondary)}.run-history-loading{display:flex;justify-content:center;padding:1rem}.run-history-error{padding:.5rem;color:#f44336;font-size:.85rem;text-align:center}.run-history-empty{padding:.5rem;color:var(--text-muted);font-size:.85rem;text-align:center;font-style:italic}.run-history-chart{height:100px}.run-history-chart.empty{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.85rem}.run-history-summary{margin-top:.5rem;text-align:center}.summary-change{font-size:.85rem;font-weight:600}.summary-change.up{color:#f44336}.summary-change.down{color:#2196f3}.summary-change.unchanged{color:var(--text-muted)}.run-history-tooltip{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;padding:.5rem;box-shadow:0 2px 8px #00000026}.run-history-tooltip .tooltip-run{font-size:.8rem;color:var(--text-secondary);margin-bottom:.25rem}.run-history-tooltip .tooltip-temp{font-size:1rem;font-weight:600;font-family:monospace}.run-history-tooltip .tooltip-precip{font-size:.9rem;font-weight:500;font-family:monospace;color:#64b5f6}.run-history-summary{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.summary-change.precip{padding-left:.5rem;border-left:1px solid var(--border-color)}.summary-note{font-size:.75rem;color:var(--text-muted);font-style:italic}.model-card-empty .model-card-body{padding:2rem;text-align:center}.no-data{color:var(--text-muted);font-style:italic}.comparison-table-container{overflow-x:auto}.comparison-table{width:100%;border-collapse:collapse;font-size:.95rem}.comparison-table th,.comparison-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}.comparison-table th{background:var(--bg-secondary);font-weight:600;white-space:nowrap}.model-col{border-top:3px solid;text-align:center}.model-name-header{font-weight:600}.param-col{min-width:150px}.param-cell{display:flex;flex-direction:column;gap:.25rem;min-height:2.5rem;justify-content:center;position:relative}.param-cell.no-unit{justify-content:flex-start}.param-cell.no-unit .param-name{position:absolute;top:50%;transform:translateY(-50%)}.param-cell.no-unit .param-unit{visibility:hidden}.param-name{font-weight:500}.param-unit{font-size:.8rem;color:var(--text-muted)}.value-cell{text-align:center;font-family:monospace;font-weight:500;border-left:3px solid}.spread-col,.historical-col,.spread-cell{text-align:center}.spread-value{font-weight:600}.spread-range{display:block;font-size:.8rem;color:var(--text-muted)}.historical-cell{text-align:center;color:var(--text-secondary)}.comparison-table-empty{padding:2rem;text-align:center;color:var(--text-muted)}.ensemble-spread{padding:1rem}.ensemble-title{margin:0 0 1rem;font-size:1.1rem;font-weight:600}.ensemble-models{display:flex;flex-direction:column;gap:1.5rem}.ensemble-model-section{background:var(--bg-secondary);border-radius:var(--border-radius);overflow:hidden}.ensemble-model-header{padding:.75rem 1rem;border-left:4px solid;background:var(--bg-primary);display:flex;justify-content:space-between;align-items:center}.member-count{font-size:.85rem;color:var(--text-muted)}.ensemble-params{padding:1rem}.ensemble-param-row{margin-bottom:1rem}.ensemble-param-row:last-child{margin-bottom:0}.ensemble-param-row .param-label{font-weight:500;margin-bottom:.5rem}.ensemble-stats{display:flex;flex-direction:column;gap:.5rem}.stats-text{display:flex;gap:.5rem;font-family:monospace}.stats-text .mean{color:var(--text-secondary)}.stats-bar-container{height:24px;background:var(--bg-tertiary);border-radius:var(--border-radius);overflow:hidden}.stats-bar{height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:500;min-width:60px}.percentiles{display:flex;gap:1rem;font-size:.8rem;color:var(--text-secondary)}.ensemble-legend{display:flex;gap:1.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.legend-color{width:16px;height:16px;border-radius:4px}.ensemble-spread-loading,.ensemble-spread-empty{padding:2rem;text-align:center;color:var(--text-muted)}.historical-comparison{padding:1rem}.historical-header{margin-bottom:1rem}.historical-header h3{margin:0;font-size:1.1rem;font-weight:600}.historical-subtitle{margin:.25rem 0 0;font-size:.9rem;color:var(--text-secondary)}.historical-params{display:flex;flex-direction:column;gap:1rem}.historical-param-row{padding:1rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.param-header{margin-bottom:.75rem}.param-header .param-name{font-weight:600;font-size:1rem}.historical-values{display:flex;flex-direction:column;gap:.5rem}.historical-avg,.historical-extremes,.forecast-comparison{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.9rem}.historical-avg .label,.forecast-comparison .label{color:var(--text-secondary)}.historical-avg .value{font-weight:600}.historical-avg .range{color:var(--text-muted);font-size:.85rem}.historical-extremes{font-size:.85rem;color:var(--text-muted)}.comparison-value{font-weight:600}.comparison-value.above{color:var(--warning-color)}.comparison-value.below{color:var(--primary-color)}.comparison-value.normal{color:var(--secondary-color)}.historical-note{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);font-size:.85rem;color:var(--text-muted)}.historical-loading,.historical-empty{padding:2rem;text-align:center;color:var(--text-muted)}.external-charts{padding:1rem}.charts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.charts-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.region-selector{display:flex;align-items:center;gap:.5rem}.region-dropdown{padding:.4rem .75rem;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:.9rem;background:var(--bg-primary)}.charts-links{display:flex;flex-direction:column;gap:1rem}.model-links{display:flex;flex-wrap:wrap;gap:.75rem}.pivotal-link,.ensemble-link,.pivotal-home-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border-radius:var(--border-radius);text-decoration:none;color:var(--text-primary);font-size:.9rem;transition:all var(--transition-fast)}.pivotal-link:hover,.ensemble-link:hover,.pivotal-home-link:hover{background:var(--bg-tertiary);transform:translateY(-1px)}.model-indicator{width:10px;height:10px;border-radius:50%}.external-icon{opacity:.5}.additional-links{display:flex;gap:.75rem;flex-wrap:wrap}.charts-note{margin-top:.75rem;font-size:.8rem;color:var(--text-muted)}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;padding:2rem;gap:1rem}.loading-spinner{position:relative}.loading-spinner.spinner-small{width:24px;height:24px}.loading-spinner.spinner-medium{width:40px;height:40px}.loading-spinner.spinner-large{width:60px;height:60px}.spinner-ring{position:absolute;top:0;left:0;width:100%;height:100%;border:3px solid var(--bg-tertiary);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.spinner-ring:nth-child(2){animation-delay:-.3s;opacity:.6}.spinner-ring:nth-child(3){animation-delay:-.6s;opacity:.3}.loading-message{color:var(--text-secondary);font-size:.95rem}.error-message{padding:2rem;text-align:center;max-width:500px;margin:0 auto}.error-icon{color:var(--error-color);margin-bottom:1rem}.error-title{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-primary)}.error-text{color:var(--text-secondary);margin-bottom:1rem}.error-details{text-align:left;background:var(--bg-secondary);border-radius:var(--border-radius);padding:.75rem;margin-bottom:1rem}.error-details summary{cursor:pointer;font-weight:500}.error-details pre{margin:.5rem 0 0;font-size:.85rem;overflow-x:auto;white-space:pre-wrap}.error-retry-btn{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);font-size:1rem;cursor:pointer;transition:background var(--transition-fast)}.error-retry-btn:hover{background:#1976d2}@media(max-width:768px){.app-main,.section{padding:1rem}.header-content{flex-direction:column;text-align:center}.header-info{text-align:center}.location-controls{flex-direction:column;align-items:stretch}.location-search{max-width:none}.or-divider{text-align:center}.datetime-selects{flex-direction:column}.model-checkboxes{justify-content:center}.comparison-table{font-size:.85rem}.comparison-table th,.comparison-table td{padding:.5rem}button,.search-input,select,input[type=text],.model-checkbox,.collapsible-header{min-height:44px}.model-card{transition:max-height .3s ease,opacity .2s ease}.model-card.collapsed .model-card-body,.model-card.collapsed .model-card-footer{display:none}.model-card-header{cursor:pointer;position:relative;min-height:48px;display:flex;align-items:center;justify-content:space-between;padding-right:2.5rem}.model-card-header:after{content:"u25BC";position:absolute;right:.75rem;font-size:.75rem;transition:transform .2s ease;opacity:.7}.model-card.collapsed .model-card-header:after{transform:rotate(-90deg)}.search-input,.location-dropdown,.date-select,.hour-select{font-size:16px;padding:.75rem 1rem}.model-value-row{padding:.6rem 0}.model-checkboxes{gap:.5rem}.model-checkbox{padding:.6rem 1rem}.theme-toggle{width:44px;height:44px}.geolocation-btn{width:48px;min-width:48px}.result-favorite-btn{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.pull-to-refresh-indicator{position:fixed;top:0;left:50%;transform:translate(-50%);background:var(--primary-color);color:#fff;padding:.5rem 1rem;border-radius:0 0 var(--border-radius) var(--border-radius);z-index:1000;display:none}.pull-to-refresh-indicator.active{display:block}}.current-conditions{background:var(--bg-primary);border-radius:var(--border-radius);box-shadow:var(--shadow-md);padding:1.25rem;margin-bottom:1.5rem;border-left:4px solid #00897B}.current-conditions-header{margin-bottom:.5rem}.current-conditions-title-row{display:flex;align-items:center;justify-content:space-between}.current-conditions-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.current-conditions-location{font-size:.95rem;font-weight:500;color:var(--text-secondary);margin-top:.25rem}.observation-badge{background:#00897b;color:#fff;font-size:.65rem;font-weight:700;padding:.25rem .5rem;border-radius:4px;letter-spacing:.5px}.current-conditions-time{font-size:.85rem;color:var(--text-muted);margin-bottom:1rem}.current-conditions-main{display:flex;flex-direction:column;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.current-temp-display{display:flex;flex-direction:column;align-items:center;margin-bottom:.5rem}.current-temp-value{font-size:3rem;font-weight:700;line-height:1}.current-weather-desc{font-size:1.1rem;color:var(--text-secondary);margin-top:.25rem}.current-feels-like{font-size:.95rem;color:var(--text-secondary)}.current-conditions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.current-condition-item{display:flex;flex-direction:column;align-items:center;text-align:center}.current-condition-item .condition-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.current-condition-item .condition-value{font-size:1.1rem;font-weight:600;font-family:monospace;color:var(--text-primary)}.current-condition-item .condition-detail{font-size:.8rem;color:var(--text-secondary);margin-top:.15rem}.current-conditions-loading,.current-conditions-error{text-align:center;padding:2rem}.current-conditions-error .error-text{color:var(--error-color)}@media(max-width:600px){.current-conditions-grid{grid-template-columns:repeat(2,1fr)}.current-temp-value{font-size:2.5rem}}.sunrise-sunset{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.sun-times{display:flex;justify-content:center;gap:2rem;margin-bottom:.75rem}.sun-time-item{display:flex;align-items:center;gap:.5rem}.sun-icon{font-size:1.5rem}.sun-time-info{display:flex;flex-direction:column}.sun-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.sun-value{font-size:1rem;font-weight:600;font-family:monospace;color:var(--text-primary)}.daylight-info{display:flex;justify-content:center;gap:1.5rem;font-size:.85rem;color:var(--text-secondary)}.daylight-duration{font-weight:500}.time-until{font-style:italic;color:var(--text-muted)}@media(max-width:600px){.sun-times{gap:1rem}.daylight-info{flex-direction:column;align-items:center;gap:.25rem}}.air-quality{background:var(--bg-primary);border-radius:var(--border-radius);padding:1.25rem;box-shadow:var(--shadow-sm);border-left:4px solid #9C27B0}.air-quality-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.air-quality-title{margin:0;font-size:1.1rem;color:var(--text-primary)}.aqi-time{font-size:.85rem;color:var(--text-muted)}.aqi-main{margin-bottom:1rem}.aqi-value-display{display:flex;align-items:center;gap:1rem}.aqi-value{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;font-size:1.5rem;font-weight:700;color:#fff}.aqi-category-info{display:flex;flex-direction:column}.aqi-category{font-size:1.1rem;font-weight:600}.aqi-description{font-size:.85rem;color:var(--text-secondary);margin-top:.25rem}.pollutants-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.pollutant-item{display:flex;flex-direction:column;align-items:center;text-align:center}.pollutant-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.pollutant-value{font-size:.85rem;font-weight:600;font-family:monospace;color:var(--text-primary)}.aqi-scale{margin-top:.75rem}.scale-bar{display:flex;height:8px;border-radius:4px;overflow:hidden}.scale-segment{flex:1}.scale-segment.good{background:#4caf50}.scale-segment.moderate{background:#ffeb3b}.scale-segment.unhealthy-sensitive{background:#ff9800}.scale-segment.unhealthy{background:#f44336}.scale-segment.very-unhealthy{background:#9c27b0}.scale-segment.hazardous{background:#7b1fa2}.scale-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted);margin-top:.25rem}.air-quality-loading,.air-quality-error{text-align:center;padding:1.5rem}.air-quality-error .error-text{color:var(--error-color)}@media(max-width:600px){.pollutants-grid{grid-template-columns:repeat(2,1fr)}}.weather-highlights{background:var(--bg-primary);border-radius:var(--border-radius);padding:1rem;box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.highlights-title{margin:0 0 .75rem;font-size:1rem;color:var(--text-primary)}.highlights-list{display:flex;flex-direction:column;gap:.75rem}.highlight-item{padding:.75rem 1rem;background:var(--bg-secondary);border-radius:var(--border-radius);border-left:4px solid}.highlight-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.highlight-icon{font-size:1.1rem}.highlight-title{font-weight:600;color:var(--text-primary);flex:1}.highlight-badge{font-size:.65rem;font-weight:700;padding:.15rem .4rem;border-radius:3px;color:#fff;text-transform:uppercase;letter-spacing:.5px}.highlight-message{margin:0;font-size:.9rem;color:var(--text-secondary);padding-left:1.6rem}.highlight-warning{background:#f4433614}.highlight-advisory{background:#ff980014}.highlight-info{background:#2196f314}:root[data-theme=dark] .highlight-warning{background:#f4433626}:root[data-theme=dark] .highlight-advisory{background:#ff980026}:root[data-theme=dark] .highlight-info{background:#2196f326}.alert-banner{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.alert-item{border-radius:var(--border-radius);border-left:4px solid;overflow:hidden;box-shadow:var(--shadow-sm)}.alert-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.75rem 1rem;background:transparent;border:none;cursor:pointer;text-align:left}.alert-header-content{display:flex;align-items:center;gap:.75rem}.alert-icon{font-size:1.25rem}.alert-title-section{display:flex;flex-direction:column}.alert-event{font-weight:600;color:var(--text-primary);font-size:1rem}.alert-timing{font-size:.8rem;color:var(--text-secondary)}.alert-toggle{font-size:.8rem;color:var(--text-muted)}.alert-details{padding:0 1rem 1rem;border-top:1px solid var(--border-color)}.alert-headline{font-weight:600;color:var(--text-primary);margin:.75rem 0}.alert-description,.alert-instruction{margin:.75rem 0}.alert-description h4,.alert-instruction h4{margin:0 0 .25rem;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.alert-description p,.alert-instruction p{margin:0;font-size:.9rem;color:var(--text-primary);white-space:pre-line;line-height:1.5}.alert-meta{display:flex;flex-direction:column;gap:.25rem;margin-top:.75rem;padding-top:.75rem;border-top:1px dashed var(--border-color);font-size:.8rem;color:var(--text-muted)}.alert-extreme{background:#b71c1c1f}.alert-severe{background:#f443361a}.alert-moderate{background:#ff98001a}.alert-minor{background:#ffc1071a}:root[data-theme=dark] .alert-extreme{background:#b71c1c33}:root[data-theme=dark] .alert-severe{background:#f4433626}:root[data-theme=dark] .alert-moderate{background:#ff980026}:root[data-theme=dark] .alert-minor{background:#ffc10726}.location-map-container{width:100%;border-radius:var(--border-radius);overflow:hidden;background:var(--bg-secondary);border:1px solid var(--border-color)}.location-map{width:100%;height:300px;z-index:1}.location-map-placeholder{height:300px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9rem}.leaflet-popup-content-wrapper{border-radius:var(--border-radius);background:var(--bg-primary);color:var(--text-primary)}.leaflet-popup-content{margin:.75rem;line-height:1.4}.leaflet-popup-tip{background:var(--bg-primary)}:root[data-theme=dark] .leaflet-control-zoom a{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color)}:root[data-theme=dark] .leaflet-control-zoom a:hover{background:var(--bg-tertiary)}:root[data-theme=dark] .leaflet-control-attribution{background:#1e1e1ecc;color:var(--text-muted)}:root[data-theme=dark] .leaflet-control-attribution a{color:var(--primary-color)}.map-section{margin-top:1rem}.map-section .section-title{margin-bottom:.75rem}.radar-viewer{width:100%}.radar-placeholder,.radar-loading,.radar-error{height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-muted);background:var(--bg-secondary);border-radius:var(--border-radius)}.radar-error{color:var(--error-color)}.radar-controls{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;padding:.75rem;background:var(--bg-secondary);border-radius:var(--border-radius) var(--border-radius) 0 0;border:1px solid var(--border-color);border-bottom:none}.radar-mode-toggle{display:flex;gap:.25rem}.mode-btn{padding:.4rem .8rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.mode-btn:first-child{border-radius:var(--border-radius) 0 0 var(--border-radius)}.mode-btn:last-child{border-radius:0 var(--border-radius) var(--border-radius) 0}.mode-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.mode-btn:hover:not(.active){background:var(--bg-tertiary)}.radar-playback{display:flex;align-items:center;gap:.75rem;flex:1;min-width:250px}.play-pause-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--primary-color);color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.play-pause-btn:hover{transform:scale(1.05);box-shadow:var(--shadow-sm)}.frame-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:var(--bg-tertiary);border-radius:3px;cursor:pointer}.frame-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary-color);cursor:pointer}.frame-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--primary-color);border:none;cursor:pointer}.frame-time{font-size:.85rem;color:var(--text-secondary);white-space:nowrap;display:flex;align-items:center;gap:.5rem}.frame-type{font-size:.7rem;padding:.15rem .4rem;border-radius:4px;text-transform:uppercase;font-weight:500}.frame-type.past{background:var(--bg-tertiary);color:var(--text-secondary)}.frame-type.forecast{background:#2196f326;color:var(--primary-color)}.radar-opacity{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.opacity-slider{width:60px;height:4px;-webkit-appearance:none;appearance:none;background:var(--bg-tertiary);border-radius:2px}.opacity-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--text-secondary);cursor:pointer}.radar-map-container{width:100%;height:400px;border:1px solid var(--border-color);border-top:none}.radar-map{width:100%;height:100%;z-index:1}.radar-legend{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:0 0 var(--border-radius) var(--border-radius);border:1px solid var(--border-color);border-top:none;font-size:.85rem}.legend-title{color:var(--text-secondary)}.legend-scale{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.75rem}.scale-gradient{width:100px;height:8px;border-radius:4px}.radar-gradient{background:linear-gradient(to right,#00f,#0f0,#ff0,#f90,red,#f0f)}.satellite-gradient{background:linear-gradient(to right,#f60,#fc0,#fff,#0cf,#06f)}.radar-controls-row{display:flex;align-items:center;gap:1rem;width:100%;flex-wrap:wrap}.radar-speed-control{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.speed-select{padding:.35rem .6rem;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--bg-primary);color:var(--text-primary);font-size:.8rem;cursor:pointer}.opacity-value{font-size:.75rem;min-width:35px;text-align:right}.step-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.step-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.timeline-container{flex:1;position:relative;min-width:150px}.timeline-markers{position:absolute;bottom:-4px;left:0;right:0;height:3px;display:flex;border-radius:2px;overflow:hidden}.timeline-past{background:var(--text-muted);opacity:.5}.timeline-forecast{background:var(--primary-color);opacity:.5}.frame-info{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem;min-width:80px}.timeline-summary{display:flex;justify-content:space-between;align-items:center;width:100%;padding-top:.5rem;border-top:1px solid var(--border-color);margin-top:.5rem;font-size:.75rem;color:var(--text-muted)}.timeline-range,.frame-counter{font-family:monospace}@media(max-width:768px){.radar-controls{flex-direction:column;align-items:stretch;gap:.75rem}.radar-controls-row{justify-content:center;gap:.75rem}.radar-playback{width:100%;flex-wrap:wrap;justify-content:center}.timeline-container{width:100%;order:10;margin-top:.5rem}.frame-info{flex-direction:row;align-items:center;gap:.5rem;min-width:auto}.radar-opacity{justify-content:center}.timeline-summary{flex-direction:column;gap:.25rem;text-align:center}.radar-legend{flex-direction:column;text-align:center}}.fire-weather{background:var(--bg-secondary);border-radius:var(--border-radius);padding:1rem;border:1px solid var(--border-color)}.fire-weather-header{margin-bottom:1rem}.fire-weather-title{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.75rem}.red-flag-badge{background:#8b0000;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.fire-weather-content{display:flex;flex-direction:column;gap:1rem}.fire-risk-meter{width:100%}.risk-gauge{height:12px;background:linear-gradient(to right,#32cd32,gold,orange,#ff4500,#8b0000);border-radius:6px;position:relative;overflow:hidden}.risk-fill{height:100%;border-radius:6px 0 0 6px;transition:width .5s ease;opacity:.3}.risk-indicator{position:absolute;top:-3px;width:4px;height:18px;background:var(--text-primary);border-radius:2px;transform:translate(-50%);transition:left .5s ease}.risk-labels{display:flex;justify-content:space-between;margin-top:.35rem;font-size:.7rem;color:var(--text-muted)}.fire-risk-level{display:flex;flex-direction:column;align-items:center;gap:.25rem}.fire-risk-level .risk-value{font-size:2rem;font-weight:700;line-height:1}.fire-risk-level .risk-label{font-size:.9rem;font-weight:600}.fire-factors{display:flex;justify-content:space-around;gap:1rem;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--border-radius)}.factor-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.factor-label{font-size:.75rem;color:var(--text-muted)}.factor-value{font-size:.9rem;font-weight:600;color:var(--text-primary)}.factor-value.warning{color:#ff4500}.red-flag-warning{background:#8b00001a;border:1px solid #8B0000;border-radius:var(--border-radius);padding:.75rem;color:var(--text-primary);font-size:.85rem}.red-flag-warning strong{color:#8b0000}.red-flag-warning ul{margin:.5rem 0 0;padding-left:1.25rem}.red-flag-warning li{margin:.25rem 0}@media(max-width:768px){.fire-factors{flex-wrap:wrap}.factor-item{flex:1 1 30%}}.model-accuracy{width:100%}.accuracy-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.accuracy-header .section-title{margin:0}.accuracy-controls{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary)}.days-select{padding:.4rem .75rem;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;cursor:pointer}.accuracy-loading,.accuracy-error,.accuracy-empty{padding:2rem;text-align:center;color:var(--text-muted);background:var(--bg-secondary);border-radius:var(--border-radius)}.accuracy-error{color:var(--error-color)}.accuracy-hint{font-size:.85rem;margin-top:.5rem}.accuracy-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.accuracy-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem}.accuracy-card.no-data{opacity:.6}.accuracy-model-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.accuracy-model-name{font-weight:600;color:var(--text-primary)}.accuracy-sample-size{font-size:.8rem;color:var(--text-muted)}.accuracy-no-data{text-align:center;padding:1rem;color:var(--text-muted);font-size:.9rem}.accuracy-overall{text-align:center;margin-bottom:1rem}.accuracy-score{font-size:2rem;font-weight:700;line-height:1.2}.accuracy-score.high{color:var(--secondary-color)}.accuracy-score.medium{color:var(--warning-color)}.accuracy-score.low{color:var(--error-color)}.accuracy-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.accuracy-breakdown{display:flex;flex-direction:column;gap:.5rem}.accuracy-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;padding:.4rem 0}.accuracy-row:not(:last-child){border-bottom:1px dashed var(--border-color)}.accuracy-row-label{color:var(--text-secondary)}.accuracy-row-values{display:flex;gap:.75rem;align-items:center}.accuracy-row-rate{font-weight:600;min-width:3rem;text-align:right}.accuracy-row-rate.high{color:var(--secondary-color)}.accuracy-row-rate.medium{color:var(--warning-color)}.accuracy-row-rate.low{color:var(--error-color)}.accuracy-row-mae{font-size:.8rem;color:var(--text-muted);min-width:4rem;text-align:right}.accuracy-disclaimer{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border-color);text-align:center;color:var(--text-muted)}@media(max-width:600px){.accuracy-grid{grid-template-columns:1fr}.accuracy-header{flex-direction:column;align-items:stretch}.accuracy-controls{justify-content:flex-end}}.model-bias{width:100%}.bias-header{margin-bottom:1rem}.bias-intro{margin:0;font-size:.9rem;color:var(--text-secondary)}.bias-empty{text-align:center;color:var(--text-muted);font-style:italic;padding:2rem}.bias-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.bias-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden;transition:all var(--transition-fast)}.bias-card.expanded{box-shadow:var(--shadow-md)}.bias-card-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-tertiary);border-left:4px solid;cursor:pointer;transition:background var(--transition-fast)}.bias-card-header:hover{background:var(--bg-hover)}.bias-model-name{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.expand-icon{font-size:1.25rem;font-weight:300;color:var(--text-muted);width:24px;height:24px;display:flex;align-items:center;justify-content:center}.bias-summary{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.bias-tag{display:flex;gap:.35rem;font-size:.8rem;padding:.25rem .5rem;background:var(--bg-tertiary);border-radius:4px}.bias-param{color:var(--text-muted);text-transform:capitalize}.bias-tendency{font-weight:600;text-transform:capitalize}.bias-details{padding:0 1rem 1rem;border-top:1px solid var(--border-color)}.bias-section{margin-top:1rem}.bias-section-title{margin:0 0 .5rem;font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.bias-section-title.strengths{color:#4caf50}.bias-section-title.weaknesses{color:#f44336}.bias-list{margin:0;padding-left:0;list-style:none}.bias-list li{position:relative;padding:.35rem 0 .35rem 1.25rem;font-size:.85rem;color:var(--text-secondary)}.bias-list li:before{content:"•";position:absolute;left:.25rem;color:var(--text-muted)}.strengths-list li:before{color:#4caf50}.weaknesses-list li:before{color:#f44336}.bias-item{display:flex;align-items:flex-start;gap:.5rem;padding:.35rem 0!important;padding-left:0!important}.bias-item:before{display:none!important}.bias-indicator{width:8px;height:8px;border-radius:50%;margin-top:.35rem;flex-shrink:0}.bias-description{flex:1}.bias-none{margin:0;font-size:.85rem;color:var(--text-muted);font-style:italic}.bias-disclaimer{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border-color);text-align:center;color:var(--text-muted)}@media(max-width:600px){.bias-grid{grid-template-columns:1fr}}.install-prompt{position:fixed;bottom:1rem;left:1rem;right:1rem;max-width:400px;margin:0 auto;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);padding:1rem;z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.install-prompt-content{display:flex;gap:.75rem;align-items:flex-start;margin-bottom:1rem}.install-prompt-icon{flex-shrink:0;width:40px;height:40px;background:var(--primary-color);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center}.install-prompt-text{display:flex;flex-direction:column;gap:.25rem}.install-prompt-text strong{color:var(--text-primary);font-size:1rem}.install-prompt-text span{color:var(--text-secondary);font-size:.85rem}.install-prompt-actions{display:flex;gap:.75rem;justify-content:flex-end}.install-btn{padding:.5rem 1rem;border-radius:var(--border-radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.install-btn.dismiss{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.install-btn.dismiss:hover{background:var(--bg-secondary)}.install-btn.primary{background:var(--primary-color);border:1px solid var(--primary-color);color:#fff}.install-btn.primary:hover{filter:brightness(1.1)}.offline-indicator{position:fixed;top:0;left:0;right:0;background:var(--warning-color);color:#fff;text-align:center;padding:.5rem;font-size:.85rem;z-index:1001}.offline-indicator.hidden{display:none}.wind-arrow{display:inline-flex;align-items:center;gap:.35rem}.wind-arrow--empty{color:var(--text-muted)}.wind-arrow-svg{flex-shrink:0}.wind-arrow-label{font-weight:600;font-size:.9em}.wind-arrow-speed{font-family:monospace;font-weight:500}.wind-arrow-gusts{font-family:monospace;font-size:.85em;opacity:.8}.wind-display{display:inline-flex;align-items:center;font-family:monospace}.wind-display-arrow{flex-shrink:0}.pressure-trend{font-weight:700;font-size:1.1em;margin-left:.25rem;cursor:help}.precip-icon{display:inline-flex;align-items:center;gap:.25rem}.precip-icon-svg{width:16px;height:16px}.precip-type-label{font-size:.75rem;font-weight:500}.feels-like-wrapper{position:relative;display:inline-block;cursor:help}.feels-like-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:.5rem .75rem;font-size:.8rem;white-space:nowrap;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:10;margin-bottom:.5rem}.feels-like-wrapper:hover .feels-like-tooltip{opacity:1;visibility:visible}.feels-like-type{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.feels-like-factors{color:var(--text-secondary);font-size:.75rem}.feels-like-warning{color:var(--error-color);font-size:.75rem;margin-top:.25rem}.model-run-info{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--text-muted)}.model-run-info.stale{color:var(--warning-color)}.model-run-info.stale .model-run-badge{background:#ff980026;border:1px solid var(--warning-color)}.model-run-info.stale:before{content:"u26A0";font-size:.85rem;margin-right:2px}.model-run-badge{padding:.15rem .4rem;background:var(--bg-tertiary);border-radius:4px;font-family:monospace;font-weight:600;letter-spacing:.5px}.model-run-age{opacity:.9;font-style:italic}.model-next-run{opacity:.8;font-size:.7rem;color:var(--primary-color);margin-left:.25rem;white-space:nowrap}.model-run-info.stale .model-next-run{color:var(--secondary-color);font-weight:500}.model-run-info:not(.stale) .model-run-badge{background:#4caf501a;border:1px solid rgba(76,175,80,.3);color:var(--secondary-color)}.model-fallback-notice{font-size:.7rem;color:var(--text-muted, #888);font-style:italic;margin-left:.5rem}.fallback-indicator{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .4rem;background:#9c27b01a;border:1px solid rgba(156,39,176,.3);border-radius:4px;font-size:.7rem;color:#9c27b0;margin-left:.5rem;vertical-align:middle}.fallback-indicator .fallback-icon{font-size:.8rem}.fallback-indicator .fallback-text{font-weight:500}[data-theme=dark] .fallback-indicator{background:#9c27b026;border-color:#9c27b066;color:#ce93d8}.daily-forecast{margin-top:1rem}.daily-forecast-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.daily-forecast-title{margin:0;font-size:1.1rem;color:var(--text-primary)}.daily-forecast-controls{display:flex;gap:.5rem}.daily-days-select{padding:.4rem .75rem;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:.85rem;background:var(--bg-primary)}.daily-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.daily-card{background:var(--bg-secondary);border-radius:var(--border-radius);padding:.75rem;text-align:center;transition:transform var(--transition-fast)}.daily-card:hover{transform:translateY(-2px)}.daily-card.today{border:2px solid var(--primary-color);background:#2196f314}.daily-day-name{font-weight:600;color:var(--text-primary);font-size:.9rem}.daily-date{font-size:.75rem;color:var(--text-muted);margin-bottom:.5rem}.daily-temps{display:flex;justify-content:center;gap:.5rem;margin-bottom:.5rem;font-family:monospace;font-weight:600}.daily-high{color:var(--error-color)}.daily-low{color:var(--primary-color)}.daily-precip{font-size:.8rem;color:var(--text-secondary)}.daily-precip-icon{margin-right:.25rem}.daily-wind{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}@media(max-width:768px){.daily-cards{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}.favorites-section{margin-bottom:1rem}.favorites-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.favorites-chips{display:flex;flex-wrap:wrap;gap:.5rem}.favorite-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:999px;font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.favorite-chip:hover{background:var(--bg-tertiary);border-color:var(--primary-color)}.favorite-chip.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.favorite-star{font-size:.75rem}.favorite-remove{display:none;font-size:.9rem;opacity:.7;margin-left:.25rem}.favorite-chip:hover .favorite-remove{display:inline}.add-favorite-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.4rem .75rem;background:transparent;border:1px dashed var(--border-color);border-radius:999px;font-size:.85rem;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.add-favorite-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.keyboard-help-trigger{position:fixed;bottom:1rem;right:1rem;width:36px;height:36px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:100}.keyboard-help-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.keyboard-help-content{background:var(--bg-primary);border-radius:var(--border-radius);padding:1.5rem;max-width:400px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.keyboard-help-title{margin:0 0 1rem;font-size:1.25rem;color:var(--text-primary)}.keyboard-shortcut-list{display:flex;flex-direction:column;gap:.5rem}.keyboard-shortcut-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.keyboard-shortcut-item:last-child{border-bottom:none}.shortcut-key{display:inline-flex;padding:.25rem .5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;font-family:monospace;font-size:.85rem;font-weight:500}.shortcut-description{color:var(--text-secondary);font-size:.9rem}.keyboard-help-close{margin-top:1rem;width:100%;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;transition:background var(--transition-fast)}.keyboard-help-close:hover{background:var(--bg-tertiary)}.export-dropdown{position:relative}.export-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.export-btn:hover{background:var(--bg-tertiary)}.export-menu{position:absolute;top:100%;right:0;margin-top:.25rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);min-width:160px;z-index:100}.export-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;text-align:left;font-size:.9rem;cursor:pointer;transition:background var(--transition-fast)}.export-menu-item:hover{background:var(--bg-secondary)}.export-menu-item:first-child{border-radius:var(--border-radius) var(--border-radius) 0 0}.export-menu-item:last-child{border-radius:0 0 var(--border-radius) var(--border-radius)}.astronomy-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.moon-phase-display{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:.75rem}.moon-icon{font-size:2rem}.moon-info{display:flex;flex-direction:column}.moon-phase-name{font-weight:600;color:var(--text-primary)}.moon-illumination{font-size:.85rem;color:var(--text-secondary)}@media(max-width:768px){.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary);border-top:1px solid var(--border-color);box-shadow:0 -2px 10px #0000001a;z-index:100;padding:.5rem;padding-bottom:calc(.5rem + env(safe-area-inset-bottom))}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;background:transparent;border:none;color:var(--text-muted);font-size:.7rem;cursor:pointer;transition:color var(--transition-fast)}.mobile-nav-item.active{color:var(--primary-color)}.mobile-nav-item .nav-icon{font-size:1.25rem}.app-main{padding-bottom:80px}}@media(min-width:769px){.mobile-nav{display:none}}.notification-settings{padding:1rem}.notification-toggle{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.toggle-switch{position:relative;width:48px;height:24px;background:var(--bg-tertiary);border-radius:24px;cursor:pointer;transition:background var(--transition-fast)}.toggle-switch.enabled{background:var(--primary-color)}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--transition-fast)}.toggle-switch.enabled:after{transform:translate(24px)}.threshold-settings{display:flex;flex-direction:column;gap:1rem}.threshold-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.threshold-label{font-size:.9rem;color:var(--text-primary)}.threshold-input{width:80px;padding:.4rem;border:1px solid var(--border-color);border-radius:var(--border-radius);text-align:center;font-family:monospace}.confidence-export-row{display:flex;align-items:center;gap:1rem}.keyboard-help-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.keyboard-help-modal{background:var(--bg-primary);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);padding:1.5rem;max-width:400px;width:90%;position:relative}.keyboard-help-modal h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.25rem}.keyboard-help-modal .close-btn{position:absolute;top:.75rem;right:.75rem;background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;line-height:1;padding:.25rem}.keyboard-help-modal .close-btn:hover{color:var(--text-primary)}.shortcuts-list{display:flex;flex-direction:column;gap:.75rem}.shortcut-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.shortcut-item kbd{display:inline-block;padding:.25rem .5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;font-family:monospace;font-size:.85rem;min-width:1.5rem;text-align:center}.shortcut-item span:last-child{flex:1;color:var(--text-secondary);font-size:.9rem}.keyboard-help-trigger{position:fixed;bottom:5rem;right:1rem;width:36px;height:36px;border-radius:50%;background:var(--bg-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-md);font-size:1rem;font-weight:700;color:var(--text-secondary);cursor:pointer;z-index:100;transition:all var(--transition-fast)}.keyboard-help-trigger:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}@media(max-width:768px){.keyboard-help-trigger{bottom:5rem}.confidence-export-row{flex-direction:column;align-items:flex-start;gap:.5rem}}.loading-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:var(--bg-secondary);border-radius:var(--border-radius);color:var(--text-muted);font-size:.9rem}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.model-comparison{width:100%}.comparison-empty{text-align:center;padding:2rem;color:var(--text-muted);background:var(--bg-secondary);border-radius:var(--border-radius)}.comparison-selectors{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.selector-group{display:flex;flex-direction:column;gap:.35rem}.selector-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.model-select{padding:.6rem 1rem;border:2px solid var(--border-color);border-radius:var(--border-radius);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem;font-weight:500;cursor:pointer;min-width:150px;transition:all var(--transition-fast)}.model-select:hover{border-color:var(--primary-color)}.model-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2196f326}.vs-badge{font-size:1rem;font-weight:700;color:var(--text-muted);background:var(--bg-tertiary);padding:.5rem .75rem;border-radius:var(--border-radius)}.comparison-table-container{overflow-x:auto;border-radius:var(--border-radius);border:1px solid var(--border-color)}.comparison-table{width:100%;border-collapse:collapse;font-size:.9rem}.comparison-table th,.comparison-table td{padding:.75rem 1rem;text-align:center;border-bottom:1px solid var(--border-color)}.comparison-table thead{background:var(--bg-secondary)}.comparison-table th{font-weight:600;color:var(--text-primary)}.param-header{text-align:left!important;width:25%}.model-header{border-bottom:3px solid!important;min-width:100px}.delta-header{min-width:100px;color:var(--text-secondary)}.comparison-table tbody tr:hover{background:var(--bg-hover)}.param-cell{text-align:left!important;font-weight:500;color:var(--text-primary)}.param-cell .param-name{display:block}.param-cell .param-unit{display:block;font-size:.85em;color:var(--text-secondary);min-height:1.2em}.value-cell{font-family:monospace;font-weight:500}.value-cell.model-a{background:#2196f30d}.value-cell.model-b{background:#4caf500d}.delta-cell{font-family:monospace;font-weight:600}.comparison-summary{margin-top:1rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.summary-stat{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.stat-label{color:var(--text-secondary)}.stat-value{font-weight:600;color:var(--text-primary)}.comparison-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:1rem;padding-top:.75rem;font-size:.8rem;color:var(--text-muted)}.legend-item{display:flex;align-items:center;gap:.35rem}.legend-color{width:12px;height:12px;border-radius:3px}@media(max-width:768px){.comparison-selectors{flex-direction:column;gap:.75rem}.vs-badge{padding:.35rem .5rem;font-size:.9rem}.model-select{min-width:100%}.comparison-table{font-size:.8rem}.comparison-table th,.comparison-table td{padding:.5rem .6rem}.comparison-legend{flex-wrap:wrap;gap:.75rem}}.dashboard-settings-btn{position:fixed;bottom:5rem;left:1rem;width:40px;height:40px;border-radius:50%;background:var(--bg-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-md);font-size:1.25rem;color:var(--text-secondary);cursor:pointer;z-index:100;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.dashboard-settings-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:rotate(45deg)}.dashboard-settings-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dashboard-settings-modal{background:var(--bg-primary);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);max-width:450px;width:90%;max-height:80vh;display:flex;flex-direction:column;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.settings-header h3{margin:0;font-size:1.15rem;color:var(--text-primary)}.settings-close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:.25rem;line-height:1}.settings-close-btn:hover{color:var(--text-primary)}.settings-actions{display:flex;gap:.5rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.action-btn{flex:1;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.action-btn:hover{background:var(--bg-tertiary)}.action-btn.reset{background:transparent;color:var(--text-muted);border-color:transparent}.action-btn.reset:hover{color:var(--error-color)}.settings-summary{margin:0;padding:.5rem 1.25rem;font-size:.85rem;color:var(--text-muted);text-align:center}.sections-list{flex:1;overflow-y:auto;padding:.5rem 0}.section-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1.25rem;transition:background var(--transition-fast)}.section-item:hover{background:var(--bg-hover)}.section-item.fixed{opacity:.6}.section-item.hidden .section-name{color:var(--text-muted);text-decoration:line-through}.section-info{display:flex;align-items:center;gap:.75rem;flex:1}.section-toggle{position:relative;display:flex;align-items:center;cursor:pointer}.section-toggle input{position:absolute;opacity:0;width:0;height:0}.toggle-checkmark{width:18px;height:18px;border:2px solid var(--border-color);border-radius:4px;background:var(--bg-primary);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.section-toggle input:checked+.toggle-checkmark{background:var(--primary-color);border-color:var(--primary-color)}.toggle-checkmark:after{content:"";width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg) translate(-1px,-1px);opacity:0;transition:opacity var(--transition-fast)}.section-toggle input:checked+.toggle-checkmark:after{opacity:1}.section-toggle input:disabled+.toggle-checkmark{opacity:.5;cursor:not-allowed}.section-name{font-size:.9rem;color:var(--text-primary)}.fixed-badge{font-size:.7rem;padding:.15rem .4rem;background:var(--bg-tertiary);color:var(--text-muted);border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.section-reorder{display:flex;gap:.25rem}.reorder-btn{width:26px;height:26px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.reorder-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.reorder-btn:disabled{opacity:.3;cursor:not-allowed}.settings-footer{padding:.75rem 1.25rem;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.settings-hint{margin:0;font-size:.8rem;color:var(--text-muted);text-align:center}@media(max-width:768px){.dashboard-settings-btn{bottom:5.5rem}.dashboard-settings-modal{max-width:none;width:100%;height:100%;max-height:none;border-radius:0}.sections-list{padding-bottom:2rem}.model-checkbox label{padding:.75rem 1rem;gap:.75rem;min-height:48px;border:1px solid var(--border-color);border-radius:var(--border-radius);margin-bottom:.25rem}.model-checkbox .model-color{width:16px;height:16px}.additional-options{flex-direction:column;gap:.5rem}.option-checkbox{width:100%;padding:.75rem}}@supports (padding: env(safe-area-inset-bottom)){.app-main{padding-bottom:calc(80px + env(safe-area-inset-bottom))}.dashboard-settings-btn,.keyboard-help-trigger{bottom:calc(5rem + env(safe-area-inset-bottom))}}@media(max-width:600px){.comparison-table thead{display:none}.comparison-table-container{border:none}.comparison-table,.comparison-table tbody{display:block}.comparison-table tbody tr{display:block;margin-bottom:1rem;border:1px solid var(--border-color);border-radius:var(--border-radius);padding:.75rem;background:var(--bg-primary)}.comparison-table tbody tr:hover{background:var(--bg-primary)}.comparison-table .param-cell{display:block;font-weight:600;font-size:1rem;margin-bottom:.75rem;border-bottom:1px solid var(--border-color);padding:0 0 .5rem;border-left:none;text-align:left}.comparison-table .param-cell .param-name{display:block;margin-bottom:.15rem}.comparison-table .param-cell .param-unit{font-size:.8rem;font-weight:400;color:var(--text-secondary)}.comparison-table .value-cell{display:inline-flex;align-items:center;padding:.35rem .6rem;margin:.2rem;border-radius:4px;background:var(--bg-secondary);border-left:3px solid var(--model-color, var(--border-color));font-size:.9rem}.comparison-table .value-cell:before{content:attr(data-model) ": ";font-size:.75rem;font-weight:500;color:var(--text-secondary);margin-right:.35rem}.comparison-table .spread-cell{display:block;margin-top:.75rem;padding:.5rem;border-radius:var(--border-radius);text-align:center;font-size:.85rem}.comparison-table .spread-cell .spread-value{font-weight:600}.comparison-table .spread-cell .spread-range{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.comparison-table .historical-cell{display:block;margin-top:.5rem;padding:.35rem .5rem;font-size:.8rem;color:var(--text-secondary);text-align:center}.comparison-table .historical-cell:before{content:"Historical: ";font-weight:500}}@media(max-width:480px){.app-main{padding:.5rem;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.section{padding:.75rem;margin-bottom:1rem}.header-title h1{font-size:1.1rem}.header-subtitle{font-size:.8rem}.app-header{padding:.75rem 1rem}.header-content{gap:.75rem}.current-temp-value{font-size:2rem}.model-checkboxes{flex-direction:column;gap:.5rem;align-items:stretch}.model-checkbox{padding:.75rem;min-height:48px;width:100%}.model-checkbox label{width:100%;justify-content:flex-start}.chart-container{margin-bottom:1rem}.section-title{font-size:1.1rem;margin-bottom:.75rem}.collapsible-header{padding:.75rem 1rem}.collapsible-content{padding:0 1rem 1rem}.model-card .forecast-table{font-size:.75rem}.model-card .forecast-table th,.model-card .forecast-table td{padding:.35rem .25rem}.time-display{padding:.75rem 1rem;margin-bottom:1rem}.time-display-row{padding:.75rem 1rem;margin-bottom:1rem;gap:.5rem}.location-search{min-width:200px}.search-input{padding:.6rem 2.25rem .6rem .75rem;font-size:.9rem}.control-panel{gap:1rem}.control-section{gap:.5rem}.btn-primary,.btn-secondary{padding:.6rem 1rem;font-size:.85rem}.comparison-table .value-cell{padding:.3rem .5rem;margin:.15rem;font-size:.85rem}.comparison-table .value-cell:before{font-size:.7rem}.current-conditions-grid{gap:.5rem}.current-condition-item{padding:.5rem}.current-condition-item .condition-value{font-size:1rem}.air-quality{padding:1rem}.aqi-value{width:56px;height:56px;font-size:1.25rem}.weather-highlights{padding:.75rem}.highlight-item{padding:.6rem .75rem}.highlight-message{font-size:.85rem;padding-left:1.4rem}.confidence-score{padding:.75rem}.confidence-export-row{gap:.5rem}}
