:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;letter-spacing:-.011em;color-scheme:light;--bg-primary: hsla(48, 20%, 100%, .65);--bg-secondary: hsla(48, 15%, 100%, .55);--bg-tertiary: hsla(48, 25%, 98%, .75);--text-primary: hsl(40, 52%, 15%);--text-secondary: hsl(40, 41%, 32%);--text-tertiary: hsl(40, 30%, 48%);--border-color: hsla(48, 30%, 50%, .15);--border-hover: hsla(48, 35%, 40%, .25);--accent-color: hsl(48, 85%, 42%);--accent-hover: hsl(48, 90%, 35%);--warning-bg: hsl(48, 55%, 90%);--warning-border: hsl(38, 70%, 65%);--warning-text: hsl(28, 70%, 32%);--chart-red: hsl(37, 90%, 51%);--chart-blue: hsl(204, 70%, 53%);--chart-red-light: hsl(37, 80%, 88%);--chart-blue-light: hsl(204, 55%, 90%);--chart-neutral: hsl(40, 15%, 48%);--temp-above: hsl(6, 78%, 57%);--temp-below: hsl(204, 70%, 53%);--error-bg: hsl(0, 45%, 92%);--error-border: hsl(0, 55%, 75%);--error-text: hsl(0, 65%, 40%);--highlight-hot-bg: hsl(37, 50%, 90%);--highlight-hot-border: hsl(37, 45%, 78%);--highlight-hot-text: hsl(37, 75%, 30%);--highlight-cold-bg: hsl(282, 35%, 91%);--highlight-cold-border: hsl(282, 30%, 80%);--highlight-cold-text: hsl(282, 45%, 45%);--highlight-wet-bg: hsl(204, 45%, 90%);--highlight-wet-border: hsl(204, 40%, 78%);--highlight-wet-text: hsl(204, 55%, 35%);--trend-warming-bg: hsl(6, 50%, 91%);--trend-warming-border: hsl(6, 55%, 70%);--trend-warming-text: hsl(6, 65%, 38%);--trend-cooling-bg: hsl(204, 50%, 91%);--trend-cooling-border: hsl(204, 55%, 68%);--trend-cooling-text: hsl(204, 60%, 35%);--deviation-much-warmer: #e74c3c;--deviation-warmer: #f39c12;--deviation-average: #f1c40f;--deviation-cooler: #3498db;--deviation-much-colder: #9b59b6;--deviation-hottest: #e74c3c;--deviation-coldest: #9b59b6;--deviation-wettest: #3498db;--pattern-heat-wave: #e74c3c;--pattern-cold-snap: #3498db;--pattern-dry-spell: #f39c12;--pattern-wet-period: #3498db;--pattern-default: hsl(0, 0%, 40%);--skeleton-base: hsl(48, 22%, 90%);--skeleton-highlight: hsl(48, 28%, 85%);--text-xs: .5rem;--text-sm: .625rem;--text-base: .75rem;--text-md: .8125rem;--text-lg: .875rem;--text-xl: 1rem;--text-2xl: 1.125rem;--text-3xl: 1.25rem;--text-4xl: 1.375rem;--text-5xl: 1.5rem;--text-6xl: 1.625rem;--text-7xl: 1.75rem;color:var(--text-primary);background-color:transparent;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"kern" 1,"liga" 1}.tabular-nums{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}@media(max-width:768px){:root{--text-xs: .6875rem;--text-sm: .75rem;--text-base: .8125rem;--text-md: .875rem;--text-lg: .9375rem;--text-xl: 1rem;--text-2xl: 1.125rem;--text-3xl: 1.25rem;--text-4xl: 1.375rem;--text-5xl: 1.5rem;--text-6xl: 1.625rem;--text-7xl: 1.75rem;line-height:1.65}}@media(max-width:480px){:root{--text-xs: .6875rem;--text-sm: .75rem;--text-base: .8125rem;--text-md: .875rem;--text-lg: .9375rem;--text-xl: 1rem;--text-2xl: 1.0625rem;--text-3xl: 1.125rem;--text-4xl: 1.25rem;--text-5xl: 1.375rem;--text-6xl: 1.5rem;--text-7xl: 1.625rem;line-height:1.65}}@media(max-width:375px){:root{--text-xs: .6875rem;--text-sm: .75rem;--text-base: .8125rem;--text-md: .8125rem;--text-lg: .875rem;--text-xl: .9375rem;--text-2xl: 1rem;--text-3xl: 1.0625rem;--text-4xl: 1.125rem;--text-5xl: 1.25rem;--text-6xl: 1.375rem;--text-7xl: 1.5rem;line-height:1.6}}[data-theme=dark]{color-scheme:dark;--bg-primary: hsla(40, 12%, 18%, .55);--bg-secondary: hsla(40, 10%, 22%, .45);--bg-tertiary: hsla(40, 15%, 24%, .65);--text-primary: hsl(35, 6%, 93%);--text-secondary: hsl(35, 9%, 68%);--text-tertiary: hsl(35, 10%, 52%);--border-color: hsla(40, 18%, 50%, .18);--border-hover: hsla(40, 22%, 60%, .28);--accent-color: hsl(40, 55%, 55%);--accent-hover: hsl(40, 61%, 48%);--warning-bg: hsl(40, 15%, 10%);--warning-border: hsl(40, 55%, 55%);--warning-text: hsl(40, 44%, 70%);--chart-red: hsl(25, 65%, 58%);--chart-blue: hsl(210, 55%, 58%);--chart-red-light: hsl(25, 55%, 62%);--chart-blue-light: hsl(210, 48%, 62%);--chart-neutral: hsl(35, 10%, 55%);--temp-above: hsl(5, 60%, 65%);--temp-below: hsl(200, 60%, 60%);--error-bg: hsl(0, 30%, 12%);--error-border: hsl(0, 72%, 65%);--error-text: hsl(0, 72%, 65%);--highlight-hot-bg: hsl(32, 30%, 10%);--highlight-hot-border: hsl(32, 35%, 20%);--highlight-hot-text: hsl(28, 55%, 60%);--highlight-cold-bg: hsl(260, 20%, 12%);--highlight-cold-border: hsl(260, 15%, 20%);--highlight-cold-text: hsl(282, 50%, 65%);--highlight-wet-bg: hsl(215, 25%, 12%);--highlight-wet-border: hsl(215, 25%, 22%);--highlight-wet-text: hsl(200, 55%, 65%);--trend-warming-bg: hsl(0, 30%, 12%);--trend-warming-border: hsl(5, 60%, 65%);--trend-warming-text: hsl(5, 60%, 65%);--trend-cooling-bg: hsl(210, 30%, 14%);--trend-cooling-border: hsl(200, 60%, 60%);--trend-cooling-text: hsl(200, 60%, 60%);--deviation-much-warmer: #ef5f50;--deviation-warmer: #f5a623;--deviation-average: #f5d020;--deviation-cooler: #5dade2;--deviation-much-colder: #af7ac5;--deviation-hottest: #ef5f50;--deviation-coldest: #af7ac5;--deviation-wettest: #5dade2;--pattern-heat-wave: #ef5f50;--pattern-cold-snap: #5dade2;--pattern-dry-spell: #f5a623;--pattern-wet-period: #5dade2;--pattern-default: hsl(0, 0%, 55%);--skeleton-base: hsl(0, 0%, 17%);--skeleton-highlight: hsl(0, 0%, 23%);color:var(--text-primary);background-color:transparent}*{box-sizing:border-box}*,*:before,*:after{transition-property:background-color,border-color,color,box-shadow,fill,stroke;transition-duration:.5s;transition-timing-function:cubic-bezier(.4,0,.2,1)}button,input,select,textarea,a,[role=button],[tabindex="0"]{transition-property:background-color,border-color,color,box-shadow,transform,opacity;transition-duration:.15s;transition-timing-function:ease-out}.no-transition,.no-transition *,.no-transition *:before,.no-transition *:after{transition:none!important}*:focus{outline:none}*:focus-visible{outline:2px solid var(--text-primary);outline-offset:2px}button:focus,select:focus,input:focus{outline:none}button:focus-visible,select:focus-visible,input:focus-visible{outline:2px solid var(--text-primary);outline-offset:2px}html{overflow-x:clip;width:100%;max-width:100vw}body{margin:0;min-width:320px;min-height:100vh;min-height:-webkit-fill-available;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-overflow-scrolling:touch;-webkit-text-size-adjust:100%;overflow-x:clip;width:100%;max-width:100vw;padding-top:env(safe-area-inset-top,0);padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0)}#root{width:100%;min-height:100vh;max-width:100vw;overflow-x:clip}.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}.select-wrapper{position:relative;display:inline-block;width:100%}.select-with-icon{width:100%;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:none!important;padding-right:2rem}.select-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-secondary);width:12px;height:12px;flex-shrink:0}.select-with-icon:focus+.select-icon{color:var(--text-primary)}.select-wrapper{display:inline-flex;align-items:center}.snow-container{position:fixed;inset:0;pointer-events:none;z-index:1001;overflow:hidden}.snowflake{position:absolute;background:#ffffffe6;border-radius:50%;animation:snowfall linear infinite;animation-fill-mode:both;opacity:.9;box-shadow:0 0 2px #fffc;will-change:transform;animation-play-state:running;transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden}.snowflake:nth-child(3n){width:calc(var(--size, 4px) * .8)!important;height:calc(var(--size, 4px) * .8)!important}.snowflake:nth-child(5n){width:calc(var(--size, 4px) * 1.2)!important;height:calc(var(--size, 4px) * 1.2)!important}[data-theme=dark] .snowflake{background:#ffffffb3;opacity:.8;box-shadow:0 0 3px #ffffffe6}@keyframes snowfall{0%{transform:translateY(0) translate(0);opacity:.9}50%{transform:translate(calc(var(--drift, 0) * 1px));opacity:.8}to{transform:translateY(calc(100dvh + 150px)) translate(calc(var(--drift, 20) * 1px));opacity:.3}}.snowflake:nth-child(odd){--drift: 20;animation-name:snowfall-drift-left}.snowflake:nth-child(2n){--drift: -20;animation-name:snowfall-drift-right}@keyframes snowfall-drift-left{0%{transform:translateY(0) translate(0);opacity:.9}50%{transform:translate(20px);opacity:.8}to{transform:translateY(calc(100dvh + 150px)) translate(20px);opacity:.3}}@keyframes snowfall-drift-right{0%{transform:translateY(0) translate(0);opacity:.9}50%{transform:translate(-20px);opacity:.8}to{transform:translateY(calc(100dvh + 150px)) translate(-20px);opacity:.3}}:root{--header-height: calc(4rem + 60px) ;--app-main-padding-top: 1.5rem;--sticky-top-offset: calc(var(--header-height) + var(--app-main-padding-top));--dynamic-bg-light: linear-gradient( to bottom, hsl(48, 75%, 85%) 0%, hsl(48, 65%, 88%) 25%, hsl(48, 52%, 91%) 50%, hsl(48, 38%, 94%) 75%, hsl(48, 28%, 96%) 100% );--dynamic-bg-dark: linear-gradient( to top, hsl(48, 35%, 4%) 0%, hsl(48, 30%, 5.5%) 25%, hsl(48, 25%, 7%) 50%, hsl(48, 20%, 8.5%) 75%, hsl(48, 15%, 10%) 100% )}.app{min-height:100vh;background:transparent;display:flex;flex-direction:column;overflow-x:clip;overflow-y:visible;width:100%;max-width:100vw;position:relative}.app:before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:var(--dynamic-bg-light);transition:background .6s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .app:before{background:var(--dynamic-bg-dark)}.app-header{color:var(--text-primary);padding:1rem 5%;background:transparent;width:100%;max-width:100vw;overflow-x:clip;box-sizing:border-box;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-content{display:grid;grid-template-columns:auto 1fr auto;align-items:center;max-width:1760px;margin:0 auto;gap:1.5rem;background:var(--bg-secondary);border-radius:12px;padding:1rem 1.5rem;box-shadow:0 1px 3px #0000000d;width:100%;box-sizing:border-box;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5);transform:translateZ(0);will-change:background,box-shadow,backdrop-filter}[data-theme=dark] .header-content{box-shadow:0 1px 3px #0003;-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}.header-logo{display:flex;align-items:center;justify-content:flex-start}@media(min-width:769px){.header-logo h1{font-size:var(--text-4xl);margin:0;font-weight:600;letter-spacing:-.015em;line-height:1.3;color:var(--text-primary)}}.header-search{display:flex;justify-content:center;align-items:center;position:relative;width:100%;max-width:800px;margin:0 auto}.header-search .inline-controls{width:100%;max-width:100%}.header-search .control-button{padding:.625rem 1rem;font-size:var(--text-md)}.header-search .dropdown-wrapper{min-width:120px;max-width:200px;flex:0 1 auto;min-width:0}.header-controls{display:flex;gap:.75rem;align-items:center;justify-content:flex-end}.header-center-buttons{display:flex;gap:.5rem;align-items:center;justify-content:center}.header-center-controls{display:flex;align-items:center;justify-content:center;flex:1;min-width:0}.header-center-controls .inline-controls{gap:.5rem}.header-center-controls .control-button{height:38px}.header-center-controls .control-button:not(.dropdown-button){width:38px;min-width:38px;max-width:38px;height:38px}.header-center-controls .dropdown-wrapper.dropdown-date{width:115px}.header-center-controls .dropdown-wrapper.dropdown-location{width:135px}.header-center-controls .dropdown-wrapper.dropdown-year{width:72px}.header-center-controls .dropdown-button{height:44px}.header-right{display:flex;align-items:center;justify-content:flex-end}.settings-menu-trigger{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:color .2s ease,background .2s ease}.settings-menu-trigger:hover{color:var(--text-primary);background:var(--bg-tertiary)}[data-theme=dark] .settings-menu-trigger:hover{background:var(--bg-secondary)}.settings-menu-trigger svg{width:18px;height:18px}.settings-menu-content{min-width:220px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:.5rem;box-shadow:0 10px 38px -10px #00000040,0 10px 20px -15px #00000026;animation:slideDownAndFade .2s ease-out;z-index:10002;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5);touch-action:manipulation}[data-theme=dark] .settings-menu-content{box-shadow:0 10px 38px -10px #00000080,0 10px 20px -15px #00000059;-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}@keyframes slideDownAndFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.settings-menu-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;cursor:pointer;outline:none;transition:background .15s ease;font-size:var(--text-sm);color:var(--text-primary);touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.settings-menu-item:hover,.settings-menu-item:focus{background:var(--bg-tertiary)}.settings-menu-item:active{background:var(--bg-tertiary);transform:scale(.98)}.settings-menu-item[data-highlighted]{background:var(--bg-tertiary)}.settings-menu-icon{font-size:1.125rem;width:1.5rem;text-align:center;flex-shrink:0}.settings-menu-label{flex:1;font-weight:500}.settings-menu-value{font-size:var(--text-xs);color:var(--text-tertiary);padding:.25rem .5rem;background:var(--bg-primary);border-radius:4px}.settings-menu-separator{height:1px;background:var(--border-color);margin:.5rem 0}.settings-menu-arrow{fill:var(--bg-secondary)}.header-btn{padding:.5rem;border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:9999px;cursor:pointer;font-size:1.125rem;color:var(--text-primary);transition:all .2s ease;font-family:inherit;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;line-height:1;touch-action:manipulation;-webkit-tap-highlight-color:transparent}[data-theme=dark] .header-btn{background:var(--bg-tertiary)}.header-btn:hover{background:var(--bg-tertiary);border-color:var(--border-hover);transform:scale(1.05)}[data-theme=dark] .header-btn:hover{background:var(--bg-secondary)}.header-btn:active{transform:scale(.95)}.header-info-btn{margin-left:auto}.header-dropdown-wrapper{position:relative;display:none}.header-dropdown-btn.active{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .header-dropdown-btn.active{background:var(--bg-tertiary)}.header-dropdown{position:absolute;top:calc(100% + .5rem);left:50%;transform:translate(-50%);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 38px -10px #00000040,0 10px 20px -15px #00000026;z-index:1000;min-width:180px;max-width:280px;max-height:300px;overflow:hidden;display:flex;flex-direction:column;animation:slideDown .2s ease;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}[data-theme=dark] .header-dropdown{box-shadow:0 10px 38px -10px #00000080,0 10px 20px -15px #00000059;-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}[data-theme=dark] .header-dropdown{-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}.header-dropdown-search{padding:.5rem;border-bottom:1px solid var(--border-color)}.header-dropdown-input{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:6px;font-size:.8125rem;font-family:inherit}.header-dropdown-input:focus{outline:none;border-color:var(--border-hover)}.header-dropdown-list{max-height:250px;overflow-y:auto;padding:.25rem}.header-dropdown-item{width:100%;padding:.5rem .75rem;border:none;background:transparent;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:6px;font-size:.8125rem;font-family:inherit;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.header-dropdown-item:active{transform:scale(.98);transition:transform .1s ease}.header-dropdown-item:hover{background:var(--bg-tertiary)}[data-theme=dark] .header-dropdown-item:hover{background:var(--bg-secondary)}.header-dropdown-item.active{background:var(--bg-secondary);color:var(--text-primary)}[data-theme=dark] .header-dropdown-item.active{background:var(--bg-tertiary)}.header-dropdown-item.disabled{color:var(--text-secondary);cursor:default;padding:.75rem;text-align:center}.header-dropdown-item.disabled:hover{background:transparent}.header-mobile-menu{position:relative;display:none;z-index:1001}.header-mobile-menu-button{padding:.5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:9999px;font-size:var(--text-3xl);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);width:40px;height:40px;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);touch-action:manipulation;-webkit-tap-highlight-color:transparent;font-family:inherit;flex-shrink:0;box-sizing:border-box}.header-mobile-menu-button:hover{background:var(--bg-secondary);border-color:var(--border-hover);transform:scale(1.02)}.header-mobile-menu-button:active{transform:scale(.98);transition:transform .15s cubic-bezier(.4,0,.2,1)}.header-mobile-menu-button[aria-expanded=true]{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.header-mobile-menu-dropdown{position:fixed;min-width:180px;max-width:min(280px,calc(100vw - 2rem));background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 38px -10px #00000040,0 10px 20px -15px #00000026;padding:.5rem;z-index:10002;display:flex;flex-direction:column;gap:.5rem;animation:dropdownFadeIn .2s cubic-bezier(.4,0,.2,1);box-sizing:border-box;overflow:hidden;white-space:nowrap;visibility:visible;opacity:1;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}@media(max-width:480px){.header-mobile-menu-dropdown{right:0;max-width:min(260px,calc(100vw - 1rem));left:auto;transform-origin:top right}}@media(max-width:375px){.header-mobile-menu-dropdown{right:0;max-width:min(240px,calc(100vw - .75rem));min-width:160px}}[data-theme=dark] .header-mobile-menu-dropdown{box-shadow:0 10px 38px -10px #00000080,0 10px 20px -15px #00000059;background:var(--bg-secondary);-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.header-mobile-menu-item{display:flex;align-items:center;justify-content:space-between;padding:.625rem .75rem;border-radius:6px;transition:background .2s cubic-bezier(.4,0,.2,1);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;width:100%;border:none;background:transparent;color:inherit;font-family:inherit;font-size:inherit;text-align:left}.header-mobile-menu-item:hover{background:var(--bg-tertiary)}[data-theme=dark] .header-mobile-menu-item:hover{background:var(--bg-secondary)}.header-mobile-menu-label{font-size:var(--text-md);font-weight:500;color:var(--text-secondary);margin:0;flex-shrink:0}.header-mobile-info{display:none;flex-direction:column;align-items:flex-end;gap:.125rem;flex:0 0 auto;background:none;border:none;padding:.25rem .5rem;border-radius:6px;cursor:pointer;transition:all .2s ease;font-family:inherit;-webkit-tap-highlight-color:transparent}.header-mobile-info:hover{background:var(--bg-tertiary)}[data-theme=dark] .header-mobile-info:hover{background:var(--bg-secondary)}.header-mobile-info:active{transform:scale(.95);transition:transform .1s ease}.mobile-location{font-size:var(--text-base);font-weight:600;color:var(--text-primary);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.mobile-date{font-size:var(--text-base);color:var(--text-secondary);line-height:1.2;white-space:nowrap}@media(max-width:480px){.mobile-location{font-size:.8125rem;max-width:100px}.mobile-date{font-size:.75rem}}@media(min-width:768px)and (max-width:1024px){.app{padding:1rem}.app-header{padding:1rem 3%}.app-main{padding:1.25rem 3%}}@media(max-width:768px){.app{padding:.75rem .75rem 5rem}.app-header{padding:0;margin-bottom:1.75rem;background:transparent;position:-webkit-sticky;position:sticky;top:.75rem;z-index:1000}.header-content{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:.75rem;padding:.625rem 1rem;width:100%;box-sizing:border-box;background:transparent;border-radius:12px;box-shadow:none!important;-webkit-backdrop-filter:none;backdrop-filter:none;transition:background .3s ease,box-shadow .3s ease,backdrop-filter .3s ease;transform:translateZ(0);will-change:background,box-shadow,backdrop-filter}.header-content.scrolled{background:var(--bg-secondary);box-shadow:0 1px 3px #0000000d!important;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}[data-theme=dark] .header-content.scrolled{box-shadow:0 1px 3px #0003!important}.header-logo{order:1;width:auto;justify-content:flex-start;flex:0 0 auto;min-width:0;overflow:hidden;margin-right:.5rem}.header-logo h1{font-size:1.375rem!important;font-weight:700;letter-spacing:-.02em}.header-controls,.header-search,.header-center-buttons,.header-center-controls{display:none}.header-right{display:flex;order:3;margin-left:auto}.header-dropdown-wrapper,.header-mobile-info,.header-mobile-menu{display:none}}@media(max-width:640px){.app{padding:.625rem .625rem 5rem}.header-content{padding:.5rem .875rem;gap:.5rem;border-radius:10px}.header-logo h1{font-size:1.375rem!important}}@media(max-width:480px){.app{padding:.5rem .5rem 5rem}.header-content{padding:.4375rem .75rem;gap:.4375rem;border-radius:10px}.header-logo h1{font-size:1.375rem!important;letter-spacing:-.01em}}@media(max-width:375px){.app{padding:.375rem .375rem 5rem}.header-content{padding:.375rem .625rem;gap:.375rem;border-radius:8px}.header-logo h1{font-size:1.375rem!important}}.app-main{flex:1;width:100%;padding:1.5rem 5%;background:transparent;overflow-x:clip;overflow-y:visible;max-width:100%;color:#d8d7d4}.main-content{max-width:1760px;margin:0 auto;width:100%;overflow-x:clip;overflow-y:visible}.pull-to-refresh-indicator{position:fixed;top:0;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1rem;z-index:999;pointer-events:none;transition:opacity .2s ease}.pull-to-refresh-spinner{font-size:1.5rem;color:var(--text-primary);opacity:.8;transition:transform .2s ease}.pull-to-refresh-indicator.refreshing .pull-to-refresh-spinner{animation:spin 1s linear infinite}.pull-to-refresh-text{font-size:.875rem;color:var(--text-secondary);font-weight:500}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.content-heading{display:none}@media(max-width:768px){.app-main{padding:0;overflow-x:clip;width:100%;max-width:100vw;box-sizing:border-box}.main-content{padding:0}.content-heading{display:flex;flex-direction:row;align-items:baseline;gap:.375rem;margin:0 0 1.25rem;padding:0 0 0 .5rem;background:transparent;border:none;cursor:pointer;transition:opacity .2s ease;-webkit-tap-highlight-color:transparent}.content-heading:hover{opacity:.7}.content-heading:active{opacity:.5}.content-heading-title{margin:0;font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);letter-spacing:-.01em;line-height:1.3;display:flex;align-items:baseline;flex-wrap:wrap;gap:.375rem}.content-heading-date{font-weight:600;color:var(--text-primary)}.content-heading-separator{display:none}.content-heading-location{font-weight:600;color:var(--text-secondary)}.content-heading-years{font-size:var(--text-2xl);font-weight:600;color:var(--text-tertiary);background:transparent;padding:0;border-radius:4px;letter-spacing:.01em;opacity:.7}.header-search .inline-controls{justify-content:flex-start;padding-bottom:.5rem}.weather-comparison h2{font-size:var(--text-3xl)}.comparison-layout{flex-direction:column;gap:1.25rem;margin-top:0;margin-bottom:0;width:100%;max-width:100%;align-items:stretch;box-sizing:border-box;overflow-x:clip;overflow-y:visible}.emoji-text-section{width:100%;max-width:100%;min-width:0;position:-webkit-sticky;position:sticky;top:var(--sticky-top-offset);z-index:999;box-sizing:border-box;order:1}.results-card{order:2;width:100%;max-width:100%;box-sizing:border-box;overflow-x:clip;overflow-y:visible;position:relative}.insights-card{grid-template-columns:1fr;gap:.875rem}.insights-section .weather-stats{grid-template-columns:1fr}.emoji-text-content{min-height:80px;padding:0;background:transparent;border-radius:0;border:none}.emoji-text{font-size:.875rem;line-height:1.6;word-break:break-word;letter-spacing:-.01em}.results-content{min-height:280px}.comparison-header{display:none}.comparison-header h2{font-size:1.125rem;margin-bottom:0}.results-controls{flex-direction:column;align-items:stretch;gap:.5rem;padding:0;background:transparent;border-radius:0;border:none;margin-bottom:1.25rem}.results-controls .weather-stats{width:100%;gap:.375rem;display:grid;grid-template-columns:repeat(2,1fr)}.results-controls .controls-group{width:100%;justify-content:stretch;flex-direction:column;gap:.5rem}.results-controls .view-toggle{width:100%}.results-controls .share-button{width:100%;justify-content:center}.weather-stats{grid-template-columns:repeat(2,1fr);gap:.375rem}.stat-card{padding:.4375rem .5rem;min-height:auto;max-height:2.2em;border-radius:9999px;background:transparent;border:none;gap:.3125rem}.stat-icon{font-size:.9375rem}.stat-value{font-size:.8125rem;line-height:1.35;max-height:2.5em;letter-spacing:-.01em}.stat-year{font-size:.75rem;line-height:1.35}.stat-label{font-size:.75rem}.weather-cards-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.weather-card{padding:.5rem;border-radius:8px}.temp-value{font-size:1rem}.temp-separator,.temp-diff{font-size:.6875rem}.temp-value-large{font-size:1.5rem}.temp-value-small{font-size:.9375rem}.emoji-text-header,.results-header{flex-direction:column;align-items:flex-start;gap:.625rem}.view-toggle{width:100%;justify-content:stretch;border-radius:8px}.view-btn{min-height:44px;padding:.625rem .875rem;font-size:.8125rem;font-weight:600}.share-button{min-width:100%;min-height:44px;border-radius:8px;font-size:.9375rem}}@media(max-width:640px){.app{padding:.625rem .625rem 5rem}.app-header{top:.625rem;margin-bottom:1.5rem}.header-content{padding:.5rem .875rem;gap:.5rem;border-radius:10px}.header-logo h1{font-size:1.375rem}.app-main{padding:0}.content-heading{margin-bottom:1.25rem}.content-heading-title,.content-heading-years{font-size:var(--text-xl)}.comparison-layout{gap:1.25rem;margin-top:0;margin-bottom:0}.emoji-text-content{padding:0;min-height:70px;background:transparent;border:none;border-radius:0}.emoji-text{font-size:.8125rem;line-height:1.55;letter-spacing:-.01em}.results-controls{padding:0;gap:.5rem;margin-bottom:1.25rem;background:transparent;border:none;border-radius:0}.results-controls .weather-stats{gap:.375rem;grid-template-columns:repeat(2,1fr)}.stat-card{padding:.4375rem .5rem;min-height:auto;max-height:2.2em;border-radius:9999px;background:transparent;border:none;gap:.3125rem}.stat-icon{font-size:.9375rem}.stat-value{font-size:.8125rem;line-height:1.35;max-height:2.5em;letter-spacing:-.01em}.results-controls .controls-group{gap:.4375rem}.weather-cards-grid{grid-template-columns:repeat(3,1fr);gap:.375rem}.weather-card{padding:.4375rem;border-radius:8px}.temp-value{font-size:.9375rem}.temp-separator,.temp-diff{font-size:.6875rem}.temp-value-large{font-size:1.375rem}.temp-value-small{font-size:.9375rem}}@media(max-width:480px){.app{padding:.5rem .5rem 5rem}.app-header{top:.5rem;margin-bottom:1.5rem}.header-content{padding:.4375rem .75rem;gap:.4375rem;border-radius:10px}.header-logo h1{font-size:1.375rem!important;letter-spacing:-.01em}.app-main{padding:0;overflow-x:clip;width:100%;max-width:100vw;box-sizing:border-box}.main-content{width:100%;overflow-x:clip;max-width:100%;box-sizing:border-box;padding:0}.content-heading{margin-bottom:1.25rem}.content-heading-title,.content-heading-years{font-size:var(--text-lg)}.header-search .inline-controls{gap:.375rem}.weather-comparison{width:100%;max-width:100%;overflow-x:clip}.comparison-layout{gap:1.25rem;margin-top:0;margin-bottom:0}.emoji-text{font-size:.8125rem;line-height:1.5;letter-spacing:-.01em}.emoji-text-content{padding:0;min-height:60px;background:transparent;border:none;border-radius:0}.results-controls{padding:0;gap:.375rem;margin-bottom:1.25rem;background:transparent;border:none;border-radius:0}.results-controls .weather-stats{gap:.3125rem;grid-template-columns:repeat(2,1fr)}.stat-card{padding:.4375rem .5rem;min-height:auto;max-height:2.2em;border-radius:9999px;background:transparent;border:none;gap:.3125rem}.stat-icon{font-size:.875rem}.stat-value{font-size:.8125rem;line-height:1.3;max-height:2.4em;letter-spacing:-.01em}.stat-year{font-size:.6875rem;line-height:1.3}.results-controls .controls-group{gap:.375rem}.weather-cards-grid{grid-template-columns:repeat(3,1fr);gap:.3125rem}.weather-card{padding:.375rem;border-radius:6px}.temp-value{font-size:.9375rem}.temp-separator,.temp-diff{font-size:.6875rem}.temp-diffs{gap:.25rem}.temp-value-large{font-size:1.25rem}.temp-value-small{font-size:.875rem}.temp-diff-inline,.temp-diff-small,.weather-card-header h3{font-size:.6875rem}.deviation-emoji-header{font-size:.875rem}.year-with-emoji{gap:.3125rem}.weather-condition,.condition-icon-small{font-size:.6875rem}.weather-card-details{gap:.25rem;margin-top:.25rem}.temp-primary{gap:.25rem;line-height:1}.temp-secondary{gap:.1875rem;line-height:1;margin-top:.0625rem}.temp-diff-inline,.temp-diff-small{line-height:1;opacity:.85}.view-btn{min-height:42px;padding:.5rem .75rem;font-size:.8125rem}.share-button{min-height:42px;font-size:.875rem}.comparison-header{margin-bottom:.75rem;padding-bottom:.4375rem}.comparison-header h2{font-size:1rem}.weather-table{min-width:550px}.weather-table th{padding:.625rem .75rem;font-size:.75rem;letter-spacing:.01em}.weather-table td{padding:.625rem .75rem}.weather-table .year-cell,.weather-table .year-value,.weather-table .temp-cell,.weather-table .condition-cell,.weather-table .precip-cell{font-size:.8125rem;letter-spacing:-.01em}.weather-table .temp-value{font-size:.8125rem;min-width:2.75rem}.weather-table .temp-diff-inline{font-size:.6875rem}.weather-table .deviation-emoji-table,.weather-table .extreme-indicator{font-size:.9375rem}.weather-table tbody tr.row-hottest .temp-cell.high .temp-value,.weather-table tbody tr.row-coldest .temp-cell.low .temp-value,.weather-table tbody tr.row-wettest .precip-cell{font-size:.8125rem}.year-with-emoji-table{gap:.5rem}.temperature-chart{height:260px}.simplified-chart-wrapper{padding:.75rem .5rem .75rem .25rem}}@media(max-width:375px){.app{padding:.375rem .375rem 5rem}.app-header{top:.375rem;margin-bottom:1.5rem}.header-content{padding:.375rem .625rem;gap:.375rem;border-radius:8px}.header-logo h1{font-size:1.375rem}.app-main{padding:0}.content-heading{margin-bottom:1.25rem}.content-heading-title,.content-heading-years{font-size:var(--text-lg)}.comparison-layout{gap:1.25rem;margin-top:0;margin-bottom:0}.emoji-text-content{padding:0;min-height:55px;background:transparent;border:none;border-radius:0}.emoji-text{font-size:.75rem;line-height:1.5;letter-spacing:-.005em}.results-controls{padding:0;gap:.3125rem;margin-bottom:1.25rem;background:transparent;border:none;border-radius:0}.results-controls .weather-stats{gap:.25rem;grid-template-columns:repeat(2,1fr)}.stat-card{padding:.375rem .4375rem;min-height:auto;max-height:2.1em;border-radius:9999px;background:transparent;border:none;gap:.25rem}.stat-icon{font-size:.8125rem}.stat-value{font-size:.75rem;line-height:1.3;max-height:2.4em;letter-spacing:-.01em}.stat-year{font-size:.6875rem;line-height:1.3}.results-controls .controls-group{gap:.3125rem}.weather-cards-grid{grid-template-columns:repeat(3,1fr);gap:.25rem}.weather-card{padding:.3125rem;border-radius:6px}.temp-value{font-size:.875rem}.temp-separator,.temp-diff{font-size:.6875rem}.temp-diffs{gap:.1875rem}.temp-value-large{font-size:1.125rem}.temp-value-small{font-size:.8125rem}.weather-card-header h3{font-size:.6875rem}.deviation-emoji-header{font-size:.8125rem}.year-with-emoji{gap:.25rem}.weather-condition,.condition-icon-small{font-size:.6875rem}.weather-card-details{gap:.25rem;margin-top:.25rem}.temp-primary{gap:.25rem;line-height:1.15}.temp-secondary{gap:.1875rem;line-height:1.15;margin-top:.125rem}.temp-diff-inline,.temp-diff-small{line-height:1.15;opacity:.85;font-size:.6875rem}.view-btn{min-height:44px;padding:.5rem .75rem;font-size:.75rem}.share-button{min-height:44px;font-size:.875rem}.weather-table{min-width:520px}.weather-table th{padding:.5625rem .6875rem;font-size:.75rem;letter-spacing:.01em}.weather-table td{padding:.5625rem .6875rem}.weather-table .year-cell,.weather-table .year-value,.weather-table .temp-cell,.weather-table .condition-cell,.weather-table .precip-cell{font-size:.8125rem;letter-spacing:-.01em}.weather-table .temp-value{font-size:.8125rem;min-width:2.5rem}.weather-table .temp-diff-inline{font-size:.6875rem}.weather-table .deviation-emoji-table,.weather-table .extreme-indicator{font-size:.9375rem}.weather-table tbody tr.row-hottest .temp-cell.high .temp-value,.weather-table tbody tr.row-coldest .temp-cell.low .temp-value,.weather-table tbody tr.row-wettest .precip-cell{font-size:.8125rem}.temperature-chart{height:240px}.simplified-chart-wrapper{padding:.625rem .4375rem .625rem .25rem}.year-with-emoji-table{gap:.4375rem}.weather-table th.condition-col,.weather-table td.condition-cell{display:none}.weather-table{min-width:420px}}.icon-bar{width:64px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;transition:width .3s ease;position:relative;flex-shrink:0}.icon-bar.expanded{width:220px}.icon-bar-toggle{position:sticky;top:0;z-index:10;width:100%;padding:.5rem;background:var(--bg-primary);border:none;border-bottom:1px solid var(--border-color);cursor:pointer;font-size:.875rem;color:var(--text-secondary);transition:all .2s ease;font-family:inherit}.icon-bar-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:scale(1.05)}[data-theme=dark] .icon-bar-toggle:hover{background:var(--bg-secondary)}.icon-bar-toggle:active{transform:scale(.95);transition:transform .1s ease}.app-nav{display:flex;flex-direction:column;gap:0;padding:.5rem 0;flex:1}.nav-section{display:flex;flex-direction:column;margin-bottom:.75rem}.nav-section:last-child{margin-bottom:0}.nav-section-header{padding:.5rem .75rem .375rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);border-bottom:1px solid var(--border-color);margin-bottom:.25rem;transition:color .2s ease;white-space:nowrap;overflow:hidden}.nav-section:has(.nav-button.active) .nav-section-header{color:var(--text-primary)}.nav-button{width:100%;padding:.625rem .75rem;background:var(--bg-secondary);border:none;border-left:3px solid transparent;font-size:.75rem;font-weight:500;letter-spacing:-.005em;line-height:1.4;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-family:inherit;text-align:left;position:relative;border-radius:0 9999px 9999px 0;display:flex;align-items:center;gap:.75rem;min-height:44px}.nav-icon{font-size:1.125rem;flex-shrink:0;width:24px;text-align:center}.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-button:hover{background:var(--bg-primary);color:var(--text-primary);transform:translate(2px)}.nav-button.active{background:var(--bg-tertiary);color:var(--text-primary);border-left-color:var(--text-primary);font-weight:600;box-shadow:0 1px 3px #0000000d;transform:translate(2px)}.nav-button:active{transform:translate(0);transition:transform .1s ease}.nav-button.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--text-primary);border-radius:0 2px 2px 0}.icon-bar:not(.expanded) .nav-section-header{display:none}.icon-bar:not(.expanded) .nav-label{display:none}.icon-bar:not(.expanded) .nav-button{justify-content:center;padding:.625rem}.icon-bar:not(.expanded) .nav-section{margin-bottom:.5rem}.app-main{flex:1;width:100%;transition:opacity .2s ease}.app-main>*{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.controls{display:flex;flex-direction:column;gap:1rem;width:100%;align-items:center}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.controls-section{display:flex;flex-direction:column;gap:1rem;padding:.75rem;background:var(--bg-primary);border-radius:6px;border:1px solid var(--border-color);transition:all .2s ease;animation:fadeIn .3s ease-out backwards}.controls-section:nth-child(1){animation-delay:.05s}.controls-section:nth-child(2){animation-delay:.1s}.controls-section:nth-child(3){animation-delay:.15s}.controls-section:nth-child(n+4){animation-delay:.2s}.controls-section:hover{border-color:var(--border-hover)}.controls-section-header{font-size:var(--text-md);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:.25rem;padding-bottom:.25rem;border-bottom:1px solid var(--border-color)}.date-selector-section{display:flex;flex-direction:column;gap:.75rem}.date-selector{display:flex;flex-direction:column;gap:.375rem}.date-selector label{display:none}.date-inputs{display:flex;gap:.375rem}.month-select,.day-select{padding:.375rem .5rem;border:1px solid var(--border-hover);border-radius:9999px;font-size:.8125rem;font-family:inherit;background:var(--bg-secondary);cursor:pointer;transition:all .2s ease;flex:1;color:var(--text-primary)}.month-select,.day-select,.year-range-preset-select,.sort-select,.chart-type-select,.query-select,.season-select,.date-picker-select,.search-modal-inputs .date-picker-select,.multi-location-controls .sort-select,.skeleton-select,.select-with-icon{-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:none!important}[data-theme=dark] .month-select,[data-theme=dark] .day-select,[data-theme=dark] .year-range-preset-select,[data-theme=dark] .sort-select,[data-theme=dark] .chart-type-select,[data-theme=dark] .query-select,[data-theme=dark] .season-select,[data-theme=dark] .date-picker-select,[data-theme=dark] .search-modal-inputs .date-picker-select,[data-theme=dark] .multi-location-controls .sort-select,[data-theme=dark] .skeleton-select{-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}.month-select:hover,.day-select:hover{border-color:var(--text-primary)}.random-date-button{margin-top:.25rem;padding:.25rem .5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:9999px;font-size:.6875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-family:inherit;align-self:flex-start}.random-date-button:hover{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary);transform:translateY(-1px) rotate(5deg);box-shadow:0 2px 4px #0000001a}.random-date-button:active{transform:translateY(0) rotate(0);transition:transform .1s ease}.month-select:focus,.day-select:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .month-select:focus,[data-theme=dark] .day-select:focus{box-shadow:0 0 0 3px #ffffff1a}.year-range-selector{display:flex;flex-direction:column;gap:.375rem;margin-top:.75rem}.year-range-selector label{display:none}.year-range-preset-select{padding:.375rem .5rem;border:1px solid var(--border-hover);border-radius:9999px;font-size:.8125rem;font-family:inherit;background:var(--bg-secondary);cursor:pointer;transition:all .2s;color:var(--text-primary);width:100%}.year-range-preset-select:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .year-range-preset-select:focus{box-shadow:0 0 0 3px #ffffff1a}.custom-year-inputs{display:flex;align-items:center;gap:.375rem;margin-top:.375rem}.year-input{flex:1;padding:.375rem .5rem;border:1px solid var(--border-hover);border-radius:9999px;font-size:.75rem;font-family:inherit;background:var(--bg-secondary);transition:all .2s ease;color:var(--text-primary)}.year-input:hover{border-color:var(--text-primary)}.year-input:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .year-input:focus{box-shadow:0 0 0 3px #ffffff1a}.year-separator{font-size:.875rem;color:var(--text-secondary);font-weight:500}.year-range-warning{margin-top:.5rem;padding:.5rem .75rem;background:var(--warning-bg);border:1px solid var(--warning-border);border-radius:9999px;font-size:.6875rem;color:var(--warning-text);display:flex;align-items:center;gap:.375rem}.comparison-mode-toggle{display:flex;gap:0;background:var(--bg-tertiary);padding:.125rem;border-radius:9999px;border:1px solid var(--border-color);margin-bottom:.75rem}.mode-toggle-btn{flex:1;padding:.375rem .5rem;border:none;background:transparent;border-radius:3px;cursor:pointer;font-size:.6875rem;font-weight:500;color:var(--text-secondary);transition:all .2s;font-family:inherit}.mode-toggle-btn:hover{color:var(--text-primary)}.mode-toggle-btn.active{background:var(--accent-color);color:#fff;transform:scale(1.02)}.mode-toggle-btn:active{transform:scale(.98);transition:transform .1s ease}.location-input-section{display:flex;flex-direction:column}.location-input{display:flex;flex-direction:column;gap:.5rem}.location-input label{display:none}.location-input-group{display:flex;flex-direction:column;gap:0}.location-field{width:100%;padding:.375rem .5rem;border:1px solid var(--border-hover);border-radius:9999px;font-size:.75rem;font-family:inherit;transition:all .2s;color:var(--text-primary);background:var(--bg-secondary)}.location-field:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .location-field:focus{box-shadow:0 0 0 3px #ffffff1a}.submit-button{width:100%;padding:.75rem 1rem;background:var(--accent-color);color:#fff;border:none;border-radius:9999px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s;margin-top:.5rem;min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.submit-button:hover{background:var(--accent-hover)}.submit-button:active{background:var(--accent-hover);opacity:.9}.location-suggestions{margin-top:.5rem;display:flex;flex-direction:column;gap:.375rem}.suggestions-label{font-size:var(--text-md);font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.suggested-locations{display:flex;flex-wrap:wrap;gap:.25rem}.location-tag{padding:.25rem .5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:9999px;font-size:var(--text-md);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap}.location-tag:hover{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary);transform:translateY(-1px) scale(1.05);box-shadow:0 2px 4px #0000001a}.location-tag:active{transform:translateY(0) scale(1);transition:transform .1s ease}.random-button{padding:.25rem .5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:9999px;font-size:var(--text-md);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-family:inherit;align-self:flex-start}.random-button:hover{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary);transform:translateY(-1px) rotate(5deg);box-shadow:0 2px 4px #0000001a}.random-button:active{transform:translateY(0) rotate(0);transition:transform .1s ease}.location-count{font-size:.75rem;font-weight:400;color:var(--text-secondary);margin-left:.25rem}.selected-locations{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.5rem;padding:.375rem;background:var(--bg-primary);border-radius:3px;border:1px solid var(--border-color)}.selected-location-tag{display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem;background:var(--bg-secondary);border:1px solid var(--border-hover);border-radius:9999px;font-size:.6875rem;font-weight:500;color:var(--text-primary);animation:tagFadeIn .3s ease-out;transition:all .2s ease}@keyframes tagFadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.selected-location-tag:hover{transform:scale(1.05);box-shadow:0 2px 4px #0000001a}.remove-location-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem;line-height:1;padding:0;width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.remove-location-button:hover{background:#0000001a;color:var(--text-primary);transform:scale(1.2) rotate(90deg)}[data-theme=dark] .remove-location-button:hover{background:#ffffff1a}.remove-location-button:hover{background:var(--error-border);color:#fff;transform:scale(1.2) rotate(90deg)}.remove-location-button:active{transform:scale(1) rotate(90deg);transition:transform .1s ease}.location-tag:disabled{opacity:.5;cursor:not-allowed}.weather-comparison{padding:0;height:100%;width:100%;max-width:100%;overflow-x:clip;box-sizing:border-box}.comparison-layout{display:flex;flex-direction:row;gap:1.5rem;margin-bottom:1.5rem;margin-top:0;padding-top:0;animation:fadeIn .3s ease-out;overflow-x:clip;overflow-y:visible;align-items:flex-start;width:100%;max-width:100%}@media(max-width:1024px){.comparison-layout{flex-direction:column;gap:1.25rem;align-items:stretch;margin-top:0;margin-bottom:0}.emoji-text-section{width:100%;max-width:100%;min-width:0;position:-webkit-sticky;position:sticky;top:var(--sticky-top-offset);z-index:999;order:1}.results-card{order:2;width:100%;max-width:100%}.comparison-header{display:none}.results-controls{margin-bottom:1.25rem}}.insights-card,.results-card{display:flex;flex-direction:column;flex:1;min-width:0;width:100%;max-width:100%;overflow-x:hidden;overflow-y:visible;align-items:flex-start;margin-top:0;padding-top:0}.insights-card{display:flex;flex-direction:column}.emoji-text-section{display:flex;flex-direction:column;flex-shrink:0;min-width:200px;max-width:300px;align-self:flex-start;margin:0;padding:0;align-items:flex-start;justify-content:flex-start;position:-webkit-sticky;position:sticky;top:var(--sticky-top-offset);z-index:999}@media(max-width:767px){.emoji-text-section{width:100%;max-width:100%;min-width:0;position:static;top:auto}}.insights-section{display:flex;flex-direction:column}.insights-section .weather-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin:0}.insights-section .stat-card{flex:0 0 auto;min-width:0;max-width:100%}.emoji-text-content{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:0;margin:0;width:100%}.emoji-text{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:.875rem;font-weight:600;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;word-break:break-all;margin:0;padding:0;background:transparent;border:none;width:100%;text-align:left;display:block}.emoji-text-placeholder{color:var(--text-secondary);font-style:italic;margin:0}.results-controls{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap;width:100%;max-width:100%;min-width:0}.results-controls .weather-stats{display:flex;flex-direction:row;gap:.5rem;flex-wrap:wrap;flex:1;align-items:flex-end}.results-controls .weather-stats .stat-card{min-height:2.225rem}.results-controls .controls-group{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.results-content{flex:1;min-height:400px;display:block;width:100%}.comparison-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:0;flex-wrap:wrap;gap:1rem;animation:fadeIn .3s ease-out}.comparison-header h2{flex-shrink:0;margin:0}.comparison-header .weather-stats{flex:1;margin-bottom:0;min-width:0;max-width:100%}.comparison-header .controls-group{flex-shrink:0;display:flex;align-items:center;gap:.75rem;margin-left:auto}.weather-comparison h2{margin:0;color:var(--text-primary);font-size:1.25rem;font-weight:700;letter-spacing:-.015em;line-height:1.3}.controls-group{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.export-button{padding:.375rem .75rem;background:var(--bg-tertiary);border:none;border-radius:9999px;font-size:.75rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-family:inherit}.export-button:hover{background:var(--bg-primary);color:var(--text-primary)}.export-button:active{transform:translateY(0);transition:transform .1s ease}.export-button:focus{outline:none}.export-button:focus-visible{outline:2px solid var(--text-primary);outline-offset:2px}.share-button{padding:.5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:9999px;font-size:.8125rem;color:var(--text-primary);cursor:pointer;transition:all .2s;font-family:inherit;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.share-button:hover{background:var(--bg-secondary);border-color:var(--border-hover)}.share-button:active{transform:scale(.95);transition:transform .1s ease}@media(max-width:768px){.share-button:active{transform:scale(.92)}}.share-button:focus{outline:none}.share-button:focus-visible{outline:2px solid var(--text-primary);outline-offset:2px}.view-toggle{display:flex;gap:0;background:var(--bg-tertiary);padding:.125rem;border-radius:9999px;border:1px solid var(--border-color)}[data-theme=dark] .view-toggle{background:var(--bg-primary);border-color:var(--border-color)}.view-btn{padding:.5rem .625rem;border:none;background:transparent;border-radius:9999px;cursor:pointer;font-size:.8125rem;font-weight:500;color:var(--text-secondary);transition:all .2s ease;font-family:inherit}.view-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}[data-theme=dark] .view-btn:hover{background:var(--bg-tertiary)}.view-btn.active{background:var(--bg-secondary);color:var(--text-primary)}[data-theme=dark] .view-btn.active{background:var(--bg-tertiary)}.results-controls .view-btn.active{border:1px solid var(--border-color)}[data-theme=dark] .results-controls .view-btn.active{border-color:var(--border-hover)}.view-btn:active{transform:scale(.95);transition:transform .1s ease}@media(max-width:768px){.view-btn:active{transform:scale(.92)}}.view-btn:focus{outline:none;box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .view-btn:focus{box-shadow:0 0 0 3px #ffffff1a}.view-selector-bottom{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:999;display:none;padding:.25rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}[data-theme=dark] .view-selector-bottom{-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3);box-shadow:0 4px 12px #0006}.view-selector-bottom .view-toggle{padding:.125rem}.view-selector-bottom .view-btn{width:48px;height:48px;min-height:48px;font-size:1.25rem;padding:0;display:flex;align-items:center;justify-content:center}.view-selector-bottom .view-btn-label{display:none}@media(max-width:768px){.view-btn:active{transform:scale(.92)}.results-controls .view-toggle{display:none}.view-selector-bottom{display:block}}@media(max-width:640px){.view-selector-bottom{bottom:1.25rem;left:.875rem}.view-selector-bottom .view-btn{width:44px;height:44px;min-height:44px;font-size:1.125rem}}@media(max-width:480px){.view-selector-bottom{bottom:1rem;left:.75rem;padding:.1875rem}.view-selector-bottom .view-toggle{padding:.0625rem}.view-selector-bottom .view-btn{width:40px;height:40px;min-height:40px;font-size:1rem}}@media(max-width:375px){.view-selector-bottom{bottom:.875rem;left:.625rem;padding:.125rem}.view-selector-bottom .view-btn{width:44px;height:44px;min-height:44px;font-size:1rem}}.mobile-bottom-bar{position:fixed;bottom:0;left:0;right:0;z-index:998;display:none;justify-content:center;align-items:flex-end;gap:.75rem;padding:0 1rem;padding-bottom:max(env(safe-area-inset-bottom,0px) + .75rem,1.75rem);pointer-events:none;box-sizing:border-box;max-width:100vw;overflow:visible;flex-wrap:nowrap;animation:slideUpFadeIn .4s cubic-bezier(.34,1.56,.64,1);background:transparent}@keyframes slideUpFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mobile-bottom-group{display:flex;gap:.625rem;align-items:center;justify-content:center;pointer-events:auto;padding:.5rem .625rem;background:#ffffffa6;border:1px solid var(--border-color);border-radius:9999px;box-shadow:0 4px 20px #0000001f,0 2px 8px #00000014;isolation:isolate;-webkit-backdrop-filter:blur(20px) saturate(1.8);backdrop-filter:blur(20px) saturate(1.8);flex-shrink:1;flex-grow:0;box-sizing:border-box;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease;min-width:0;max-width:100%}[data-theme=dark] .mobile-bottom-group{box-shadow:0 4px 20px #0006,0 2px 8px #0000004d;background:#1e1e2099;border-color:#ffffff1a;-webkit-backdrop-filter:blur(24px) saturate(1.5);backdrop-filter:blur(24px) saturate(1.5)}.mobile-bottom-group:hover{background:#ffffffbf;border-color:var(--border-hover)}[data-theme=dark] .mobile-bottom-group:hover{background:#28282cb3;border-color:#ffffff26}.mobile-bottom-group-left{order:1;flex:0 1 auto;min-width:0}.mobile-bottom-group-right{order:2;flex:0 1 auto;min-width:0}.mobile-bottom-btn{width:48px;height:48px;min-width:48px;min-height:48px;padding:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:50%;font-size:1.25rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:var(--text-primary);touch-action:manipulation;-webkit-tap-highlight-color:transparent;box-shadow:none;flex-shrink:0;box-sizing:border-box;position:relative;overflow:hidden;line-height:1;vertical-align:middle;text-align:center;transform-origin:center center}.mobile-bottom-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:var(--text-primary);opacity:.1;transform:translate(-50%,-50%);transition:width .2s ease,height .2s ease,opacity .2s ease}.mobile-bottom-btn:active:before{width:100%;height:100%;opacity:.15}[data-theme=dark] .mobile-bottom-btn{background:var(--bg-tertiary);border-color:var(--border-color)}.mobile-bottom-btn:hover{background:var(--bg-tertiary);border-color:var(--border-hover);transform:translateY(-1px)}[data-theme=dark] .mobile-bottom-btn:hover{background:var(--bg-secondary);border-color:var(--border-hover)}.mobile-bottom-btn:active{transform:translateY(0) scale(.98);transform-origin:center center;transition:transform .1s ease}.mobile-bottom-btn.active{background:var(--highlight-cold-bg);border-color:var(--highlight-cold-border);color:var(--text-primary);box-shadow:0 0 0 2px var(--highlight-cold-border)}[data-theme=dark] .mobile-bottom-btn.active{background:var(--highlight-cold-bg);border-color:var(--highlight-cold-border);box-shadow:0 0 0 2px var(--highlight-cold-border)}@media(max-width:768px){.mobile-bottom-bar{display:flex;padding:0 .875rem;padding-bottom:max(env(safe-area-inset-bottom,0px) + .625rem,1.5rem);gap:.625rem;flex-wrap:nowrap}.mobile-bottom-group-left{animation:slideInLeft .5s cubic-bezier(.34,1.56,.64,1) .1s backwards}.mobile-bottom-group-right{animation:slideInRight .5s cubic-bezier(.34,1.56,.64,1) .15s backwards}.mobile-bottom-group-left .mobile-bottom-btn:nth-child(1){animation:buttonPopIn .4s cubic-bezier(.34,1.56,.64,1) .2s backwards}.mobile-bottom-group-left .mobile-bottom-btn:nth-child(2){animation:buttonPopIn .4s cubic-bezier(.34,1.56,.64,1) .25s backwards}.mobile-bottom-group-left .mobile-bottom-btn:nth-child(3){animation:buttonPopIn .4s cubic-bezier(.34,1.56,.64,1) .3s backwards}.mobile-bottom-group-right .mobile-bottom-btn{animation:buttonPopIn .4s cubic-bezier(.34,1.56,.64,1) .35s backwards}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes buttonPopIn{0%{opacity:0;transform:scale(.5) rotate(-10deg)}to{opacity:1;transform:scale(1) rotate(0)}}.results-controls .view-toggle,.results-controls .share-button,.view-selector-bottom{display:none!important}.app-main{padding-bottom:6rem}.mobile-bottom-group-right{display:flex}.mobile-bottom-group{padding:.4375rem .5rem;gap:.5rem}.mobile-bottom-btn{width:44px;height:44px;min-width:44px;min-height:44px;font-size:1.125rem}}@media(max-width:640px){.mobile-bottom-bar{padding:0 .75rem;padding-bottom:max(env(safe-area-inset-bottom,0px) + .5rem,1.375rem);gap:.5rem;flex-wrap:nowrap}.mobile-bottom-group{padding:.375rem .4375rem;gap:.4375rem;flex-shrink:1}.mobile-bottom-btn{width:42px;height:42px;min-width:42px;min-height:42px;font-size:1.0625rem}}@media(max-width:480px){.mobile-bottom-bar{padding:0 .625rem;padding-bottom:max(env(safe-area-inset-bottom,0px) + .375rem,1.25rem);gap:.375rem;flex-wrap:nowrap}.mobile-bottom-group{padding:.3125rem .375rem;gap:.375rem;flex-shrink:1}.mobile-bottom-btn{width:40px;height:40px;min-width:40px;min-height:40px;font-size:1rem}}@media(max-width:375px){.mobile-bottom-bar{padding:0 .5rem;padding-bottom:max(env(safe-area-inset-bottom,0px) + .25rem,1.125rem);gap:.25rem;flex-wrap:nowrap;justify-content:center}.mobile-bottom-group{padding:.25rem .3125rem;gap:.25rem;flex-shrink:1;min-width:0}.mobile-bottom-btn{width:44px;height:44px;min-width:44px;min-height:44px;font-size:1rem}.mobile-bottom-group-left{flex-shrink:1.2}.mobile-bottom-group-right{flex-shrink:.8}}.sort-select{padding:.25rem .5rem;border:1px solid var(--border-hover);border-radius:9999px;font-size:.6875rem;font-family:inherit;background:var(--bg-secondary);cursor:pointer;transition:all .2s;color:var(--text-primary)}.sort-select:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .sort-select:focus{box-shadow:0 0 0 3px #ffffff1a}.weather-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.375rem;margin:0;padding:0}@media(max-width:768px){.results-controls .weather-stats{display:flex;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding-bottom:.25rem;margin-bottom:-.25rem;scrollbar-width:none;-ms-overflow-style:none;mask-image:linear-gradient(to right,black 0,black calc(100% - 16px),transparent calc(100% - 4px));-webkit-mask-image:linear-gradient(to right,black 0,black calc(100% - 16px),transparent calc(100% - 4px))}.results-controls .weather-stats::-webkit-scrollbar{display:none}.results-controls .weather-stats.scrolled-left{mask-image:linear-gradient(to right,transparent 0,black 16px,black calc(100% - 16px),transparent calc(100% - 4px));-webkit-mask-image:linear-gradient(to right,transparent 0,black 16px,black calc(100% - 16px),transparent calc(100% - 4px))}.results-controls .weather-stats.scrolled-end{mask-image:linear-gradient(to right,transparent 0,black 16px,black 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,black 16px,black 100%)}.results-controls .weather-stats.scrolled-start{mask-image:none;-webkit-mask-image:none}.results-controls .weather-stats .stat-card{flex:0 0 auto;scroll-snap-align:start}}.comparison-header .weather-stats{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:0;flex:1;min-width:0}.comparison-header .stat-card{flex:0 1 auto;min-width:120px;max-width:180px}.stat-card{display:flex;align-items:center;gap:.375rem;padding:.4375rem .625rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:9999px;box-shadow:0 1px 2px #0000000a;transition:all .2s ease;animation:fadeIn .3s ease-out backwards;min-height:auto;max-height:calc(2.4em + .875rem);overflow:hidden}.stat-card:nth-child(1){animation-delay:.05s}.stat-card:nth-child(2){animation-delay:.1s}.stat-card:nth-child(3){animation-delay:.15s}.stat-card:nth-child(4){animation-delay:.2s}.stat-card:nth-child(n+5){animation-delay:.25s}.stat-card:hover{background:var(--bg-tertiary);border-color:var(--border-hover);box-shadow:0 2px 4px #00000014}.stat-card:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .stat-card:focus{box-shadow:0 0 0 3px #ffffff1a}.stat-icon{font-size:var(--text-lg);line-height:1;flex-shrink:0;opacity:.8}.stat-content{display:flex;flex-direction:column;gap:.0625rem;flex:1;min-width:0}.stat-label{color:var(--text-secondary);font-weight:500;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.3px;margin-bottom:0;line-height:1.2;margin-left:.25rem}.stat-value .stat-label{font-size:.75rem;font-weight:400;text-transform:none;letter-spacing:-.06px;color:var(--text-secondary);opacity:.8}.stat-value{font-weight:600;color:var(--text-primary);font-size:var(--text-md);font-variant-numeric:tabular-nums;line-height:1.2;letter-spacing:-.01em;display:inline-flex;align-items:baseline;gap:.1875rem;flex-wrap:wrap;flex:1;min-width:0;max-height:2.4em;overflow:hidden}.stat-year{font-weight:400;font-size:var(--text-base);color:var(--text-secondary);opacity:.8;letter-spacing:-.005em;font-variant-numeric:tabular-nums;line-height:1.2;white-space:nowrap;flex-shrink:0}.stat-card-hot.highlight-hot{background:var(--highlight-hot-bg);border:1px solid var(--highlight-hot-border)}.stat-card-cold.highlight-cold,.stat-card-snow.highlight-cold{background:var(--highlight-cold-bg);border:1px solid var(--highlight-cold-border)}.stat-card-wet.highlight-wet{background:var(--highlight-wet-bg);border:1px solid var(--highlight-wet-border)}.stat-card-trend.trend-stat.warming{background:var(--trend-warming-bg)}.stat-card-trend.trend-stat.warming .stat-value{color:var(--trend-warming-text)}.stat-card-trend.trend-stat.cooling{background:var(--trend-cooling-bg)}.stat-card-trend.trend-stat.cooling .stat-value{color:var(--trend-cooling-text)}.stat-card-trend.trend-stat.stable{background:var(--bg-tertiary)}.trend-confidence{font-size:.6875rem;font-weight:400;opacity:.7;margin-left:.125rem}[data-theme=dark] .trend-confidence{opacity:.8}.stat-item{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:var(--bg-tertiary);border-radius:9999px;border:none;font-size:.75rem;transition:all .2s ease;animation:fadeIn .3s ease-out backwards}.stat-item.highlight-hot{border-color:var(--highlight-hot-border);background:var(--highlight-hot-bg)}.stat-item.highlight-cold{border-color:var(--highlight-cold-border);background:var(--highlight-cold-bg)}.stat-item.highlight-wet{border-color:var(--highlight-wet-border);background:var(--highlight-wet-bg)}.stat-item.trend-stat{border-width:2px}.stat-item.trend-stat.warming{border-color:var(--trend-warming-border);background:var(--trend-warming-bg)}.stat-item.trend-stat.warming .stat-label,.stat-item.trend-stat.warming .stat-value{color:var(--trend-warming-text)}.stat-item.trend-stat.cooling{border-color:var(--trend-cooling-border);background:var(--trend-cooling-bg)}.stat-item.trend-stat.cooling .stat-label,.stat-item.trend-stat.cooling .stat-value{color:var(--trend-cooling-text)}.stat-item.trend-stat.stable{border-color:var(--text-secondary);background:var(--bg-tertiary)}.weather-comparison.loading,.weather-comparison.error,.weather-comparison.empty{text-align:center;padding:3rem;color:var(--text-secondary)}@media(max-width:768px){.weather-comparison.loading,.weather-comparison.error,.weather-comparison.empty{padding:2rem 1rem}}@media(max-width:480px){.weather-comparison.loading,.weather-comparison.error,.weather-comparison.empty{padding:1.5rem .75rem}}.weather-comparison.error{color:var(--error-text)}.error-content{display:flex;flex-direction:column;gap:.75rem;text-align:center;padding:1rem}.error-message{color:var(--text-secondary);font-size:.9375rem;line-height:1.6}.error-hint{color:var(--text-tertiary);font-size:.8125rem;margin-top:.5rem;line-height:1.5}@media(max-width:480px){.error-content{padding:.75rem}.error-message{font-size:.875rem}.error-hint{font-size:.75rem}}.retry-button{margin-top:1rem;padding:.75rem 1.5rem;background:var(--accent-color);color:#fff;border:none;border-radius:9999px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.retry-button:active{transform:scale(.97);transition:transform .1s ease}.retry-button:hover{background:var(--accent-hover)}.retry-button:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px;box-shadow:0 0 0 3px #3b82f633}[data-theme=dark] .retry-button:focus-visible{box-shadow:0 0 0 3px #60a5fa4d}.weather-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem;background:transparent;width:100%;max-width:100%;box-sizing:border-box;overflow:visible;grid-auto-flow:row;padding:.25rem}.weather-card{background:var(--bg-secondary);padding:.5rem .5rem .75rem;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 3px #0000000f;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease;animation:cardFadeIn .4s ease-out backwards;position:relative;display:flex;flex-direction:column;aspect-ratio:1;box-sizing:border-box;overflow:hidden;min-width:0;-webkit-user-select:none;user-select:none}@media(hover:none)and (pointer:coarse){.weather-card{cursor:pointer}}.weather-card:nth-child(1){animation-delay:.05s}.weather-card:nth-child(2){animation-delay:.1s}.weather-card:nth-child(3){animation-delay:.15s}.weather-card:nth-child(4){animation-delay:.2s}.weather-card:nth-child(5){animation-delay:.25s}.weather-card:nth-child(6){animation-delay:.3s}.weather-card:nth-child(7){animation-delay:.35s}.weather-card:nth-child(8){animation-delay:.4s}.weather-card:nth-child(n+9){animation-delay:.45s}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.weather-card:hover{background:var(--bg-tertiary);border-color:var(--border-hover);box-shadow:0 2px 8px #00000014}[data-theme=dark] .weather-card:hover{background:var(--bg-tertiary);box-shadow:0 2px 8px #0006}.weather-card:active{transform:scale(.98);transition:transform .1s ease}@media(max-width:768px){.weather-card:active{transform:scale(.96)}}.weather-card.hottest{border-color:var(--highlight-hot-border);border-width:1px;background:var(--highlight-hot-bg);box-shadow:0 1px 3px #0000000f}.weather-card.hottest:hover{background:var(--highlight-hot-bg);border-color:var(--highlight-hot-border);box-shadow:0 2px 8px #00000014;filter:brightness(.96)}[data-theme=dark] .weather-card.hottest:hover{filter:brightness(1.15)}.weather-card.coldest{border-color:var(--highlight-cold-border);border-width:1px;background:var(--highlight-cold-bg);box-shadow:0 1px 3px #0000000f}.weather-card.coldest:hover{background:var(--highlight-cold-bg);border-color:var(--highlight-cold-border);box-shadow:0 2px 8px #00000014;filter:brightness(.96)}[data-theme=dark] .weather-card.coldest:hover{filter:brightness(1.15)}.weather-card.wettest{border-color:var(--highlight-wet-border);border-width:1px;background:var(--highlight-wet-bg);box-shadow:0 1px 3px #0000000f}.weather-card.wettest:hover{background:var(--highlight-wet-bg);border-color:var(--highlight-wet-border);box-shadow:0 2px 8px #00000014;filter:brightness(.96)}[data-theme=dark] .weather-card.wettest:hover{filter:brightness(1.15)}.weather-card-header{display:flex;justify-content:space-between;align-items:center;white-space:nowrap;min-width:0;line-height:1;flex-shrink:0}.year-with-emoji{display:flex;align-items:center;gap:.375rem;flex-shrink:0;min-width:0}.deviation-emoji-header{font-size:var(--text-xl);line-height:1;display:inline-block;flex-shrink:0;white-space:nowrap}.weather-card-header h3{margin:0;font-size:var(--text-base);color:var(--text-secondary);font-weight:600;letter-spacing:.015em;font-variant-numeric:tabular-nums;line-height:1;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.extreme-badge{font-size:var(--text-lg);line-height:1;opacity:.9;flex-shrink:0;white-space:nowrap;display:inline-flex;align-items:center}.weather-card-body{display:flex;flex-direction:column;flex:1;justify-content:flex-end;position:relative}.temperature-display{display:flex;flex-direction:column;transition:transform .25s ease}.weather-card:hover .temperature-display,.weather-card.expanded .temperature-display{transform:translateY(-2.5rem)}.temp-row{display:flex;align-items:baseline;gap:.375rem}.temp-value{font-size:var(--text-2xl);font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1}.temp-value.high{color:var(--text-primary)}.temp-value.low{color:var(--text-tertiary)}.weather-card.hottest .temp-value.high{color:var(--highlight-hot-text);font-weight:700}.weather-card.coldest .temp-value.low{color:var(--highlight-cold-text);font-weight:700}.temp-separator{color:var(--text-tertiary);font-weight:400;font-size:var(--text-base);opacity:.4;margin:0 .0625rem}.weather-card-details{position:absolute;bottom:0;left:0;right:0;display:flex;flex-direction:column;gap:.5rem;opacity:0;transform:translateY(100%);transition:opacity .2s ease,transform .25s ease}.weather-card:hover .weather-card-details,.weather-card.expanded .weather-card-details{opacity:1;transform:translateY(0)}.temp-diffs{display:flex;align-items:baseline;gap:.375rem}.temp-diff{font-size:var(--text-sm);font-weight:600;line-height:1;font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--text-secondary)}.temp-diff.above{color:var(--temp-above)}.temp-diff.below{color:var(--temp-below)}.temp-diff-inline{font-size:var(--text-base);font-weight:600;line-height:1;font-variant-numeric:tabular-nums;white-space:nowrap;opacity:.85}.temp-diff-inline.above{color:var(--temp-above)}.temp-diff-inline.below{color:var(--temp-below)}.temp-diff-small{font-size:var(--text-sm);font-weight:600;line-height:1;font-variant-numeric:tabular-nums;white-space:nowrap;opacity:.85}.temp-diff-small.above{color:var(--temp-above)}.temp-diff-small.below{color:var(--temp-below)}.temp-value-large{font-size:var(--text-6xl);font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.03em;line-height:1}.temp-value-small{font-size:var(--text-xl);font-weight:600;color:var(--text-secondary);font-variant-numeric:tabular-nums;letter-spacing:-.015em;line-height:1}.temp-primary{display:flex;align-items:baseline;gap:.375rem}.temp-secondary{display:flex;align-items:baseline;gap:.25rem}.weather-condition{display:flex;align-items:center;gap:.25rem;font-size:var(--text-sm);color:var(--text-secondary);line-height:1}.condition-icon-small{font-size:var(--text-sm);line-height:1;opacity:.7}.condition-text{text-transform:capitalize;font-weight:500;opacity:.85;color:var(--text-secondary);letter-spacing:-.005em;line-height:1.4}.precipitation,.humidity{font-size:.75rem;color:var(--text-secondary);text-align:center;display:flex;justify-content:space-between;align-items:center;padding:.5rem .625rem;background:var(--bg-tertiary);border-radius:6px;border:none}.precip-label,.humidity-label{font-weight:600;color:var(--text-secondary);font-size:var(--text-base);text-transform:uppercase;letter-spacing:.05em;opacity:.8}.precip-value,.humidity-value{font-weight:700;color:var(--text-primary);font-size:var(--text-lg);font-variant-numeric:tabular-nums}.weather-table-container{overflow-x:auto;margin-top:.5rem;border:1px solid var(--border-color);border-radius:12px;overflow-y:hidden;background:transparent;box-shadow:0 2px 8px #0000000a}[data-theme=dark] .weather-table-container{box-shadow:0 2px 8px #00000040}.weather-table{width:100%;border-collapse:separate;border-spacing:0;background:transparent;font-size:var(--text-md)}.weather-table thead{background:transparent;border-bottom:1px solid var(--border-color)}.weather-table th{padding:.625rem .875rem;text-align:left;font-weight:700;font-size:var(--text-base);text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);white-space:nowrap;line-height:1;vertical-align:middle;position:sticky;top:0;z-index:10;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.weather-table th:first-child{padding-left:1rem}.weather-table th:last-child{padding-right:1rem}.weather-table th.temp-col,.weather-table th.precip-col{text-align:right}.weather-table td{padding:.625rem .875rem;border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);vertical-align:middle;line-height:1;font-variant-numeric:tabular-nums;height:2.5rem}.weather-table td:first-child{padding-left:1rem;font-weight:600}.weather-table td:last-child{padding-right:1rem;border-right:none}.weather-table th{border-right:1px solid var(--border-color)}.weather-table th:last-child{border-right:none}.weather-table tbody tr{transition:background-color .15s ease,border-color .15s ease;background-color:var(--bg-secondary)}.weather-table tbody tr:nth-child(odd){background-color:var(--bg-tertiary)}.weather-table tbody tr:hover{background-color:var(--bg-tertiary);filter:brightness(.98)}[data-theme=dark] .weather-table tbody tr:nth-child(odd){background-color:var(--bg-tertiary)}[data-theme=dark] .weather-table tbody tr:hover{background-color:var(--bg-tertiary);filter:brightness(1.1)}[data-theme=dark] .weather-table tbody tr:nth-child(odd):hover{background-color:var(--bg-tertiary);filter:brightness(1.1)}.weather-table tbody tr:last-child td{border-bottom:none}.weather-table .year-col{width:12%;min-width:90px}.weather-table .temp-col{width:20%;min-width:140px}.weather-table td.temp-cell.high{border-right:1px solid var(--border-color);padding-right:1rem;padding-left:1.25rem}.weather-table th.temp-col:first-of-type{border-right:1px solid var(--border-color)}.weather-table td.temp-cell.low{padding-left:1rem;padding-right:1.25rem}.weather-table .condition-col{width:32%;min-width:140px}.weather-table .precip-col{width:16%;min-width:100px}.weather-table tbody tr.row-hottest{background-color:var(--highlight-hot-bg);border-left:3px solid var(--highlight-hot-border);border-color:var(--highlight-hot-border)}.weather-table tbody tr.row-hottest:nth-child(odd){background-color:var(--highlight-hot-bg);border-color:var(--highlight-hot-border)}.weather-table tbody tr.row-hottest:hover{background-color:var(--highlight-hot-bg);border-color:var(--highlight-hot-border);filter:brightness(.96)}[data-theme=dark] .weather-table tbody tr.row-hottest:hover{filter:brightness(1.15)}.weather-table tbody tr.row-hottest .temp-cell.high .temp-value{color:var(--highlight-hot-text);font-weight:700;font-size:.9375rem}.weather-table tbody tr.row-hottest .temp-cell.high{font-weight:700}.weather-table tbody tr.row-coldest{background-color:var(--highlight-cold-bg);border-left:3px solid var(--highlight-cold-border);border-color:var(--highlight-cold-border)}.weather-table tbody tr.row-coldest:nth-child(odd){background-color:var(--highlight-cold-bg);border-color:var(--highlight-cold-border)}.weather-table tbody tr.row-coldest:hover{background-color:var(--highlight-cold-bg);border-color:var(--highlight-cold-border);filter:brightness(.96)}[data-theme=dark] .weather-table tbody tr.row-coldest:hover{filter:brightness(1.15)}.weather-table tbody tr.row-coldest .temp-cell.low .temp-value{color:var(--highlight-cold-text);font-weight:700;font-size:.9375rem}.weather-table tbody tr.row-coldest .temp-cell.low{font-weight:700}.weather-table .snow-cell{font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.weather-table tbody tr.row-coldest .snow-cell{color:var(--highlight-cold-text);font-weight:600}.snow-status-content{display:flex;align-items:center;gap:.5rem}.snow-status-text{font-size:var(--text-base);font-weight:500}.weather-table tbody tr.row-wettest{background-color:var(--highlight-wet-bg);border-left:3px solid var(--highlight-wet-border);border-color:var(--highlight-wet-border)}.weather-table tbody tr.row-wettest:nth-child(odd){background-color:var(--highlight-wet-bg);border-color:var(--highlight-wet-border)}.weather-table tbody tr.row-wettest:hover{background-color:var(--highlight-wet-bg);border-color:var(--highlight-wet-border);filter:brightness(.96)}[data-theme=dark] .weather-table tbody tr.row-wettest:hover{filter:brightness(1.15)}.weather-table tbody tr.row-wettest .precip-cell{color:var(--highlight-wet-text);font-weight:700;font-size:.875rem}.weather-comparison.compact .weather-table{font-size:.75rem}.weather-comparison.compact .weather-table th{padding:.3125rem .4375rem;font-size:.6875rem}.weather-comparison.compact .weather-table td{padding:.4375rem;font-size:.75rem}.weather-comparison.compact .temp-value{min-width:2rem;font-size:.75rem}.weather-comparison.compact .temp-diff-inline{font-size:.6875rem}.weather-table td.year-col{vertical-align:middle}.year-cell{font-weight:700;font-size:var(--text-md);color:var(--text-primary);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:.015em;vertical-align:middle}.year-with-emoji-table{display:inline-flex;align-items:center;gap:.5rem;line-height:1}.year-value{display:inline-block;font-weight:700;font-variant-numeric:tabular-nums;font-size:var(--text-md);letter-spacing:.015em;line-height:1}.extreme-indicator{display:inline-flex;align-items:center;margin-left:auto;font-size:var(--text-xl);line-height:1;opacity:.9;flex-shrink:0}.deviation-emoji-table{font-size:var(--text-xl);line-height:1;display:inline-flex;align-items:center;flex-shrink:0}.temp-cell{text-align:right;font-size:var(--text-md);white-space:nowrap;font-weight:600;color:var(--text-primary);vertical-align:middle}.temp-cell-content{display:inline-flex;align-items:baseline;justify-content:flex-end;gap:.375rem}.temp-cell .temp-value{display:inline-block;min-width:3rem;text-align:right;font-variant-numeric:tabular-nums;font-weight:700;font-size:var(--text-lg);letter-spacing:-.01em;line-height:1}.temp-cell .temp-diff-inline{font-size:var(--text-sm);font-weight:700;display:inline-block;font-variant-numeric:tabular-nums;line-height:1;min-width:2.25rem;text-align:right}.temp-cell .temp-diff-inline.above{color:var(--temp-above);font-weight:700}.temp-cell .temp-diff-inline.below{color:var(--temp-below);font-weight:700}.temp-cell .temp-diff-inline.neutral{color:var(--text-secondary);opacity:.6}.condition-cell{text-transform:capitalize;color:var(--text-secondary);font-size:var(--text-base);font-weight:500;vertical-align:middle;padding-left:1.5rem;line-height:1}.condition-cell:first-letter{font-weight:600}.precip-cell{text-align:right;color:var(--text-primary);font-weight:600;font-size:var(--text-md);font-variant-numeric:tabular-nums;vertical-align:middle;letter-spacing:-.01em;line-height:1}.precip-cell.precip-zero{color:var(--text-secondary);opacity:.6}.weather-chart-container{margin-top:.375rem;background:var(--bg-secondary);border-radius:3px;padding:.5rem;border:1px solid var(--border-color)}.weather-chart-container.chart-view{padding:0;border:none;background:transparent}.chart-wrapper{width:100%}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding:0;background:transparent;border:none}.chart-title{margin:0;color:var(--text-primary);font-size:.9375rem;font-weight:600;letter-spacing:-.015em}.chart-expand-button{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);border-radius:6px;font-size:.8125rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-family:inherit}.chart-expand-button:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-hover);transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.chart-controls{display:flex;align-items:center;gap:.5rem}.chart-type-select{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:6px;font-size:.8125rem;font-family:inherit;background:var(--bg-secondary);cursor:pointer;transition:all .2s ease;color:var(--text-primary);font-weight:500}.chart-type-select:hover{border-color:var(--border-hover);box-shadow:0 1px 3px #0000000d}.chart-type-select:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .chart-type-select:focus{box-shadow:0 0 0 3px #ffffff1a}.temperature-chart{width:100%;height:200px;max-width:100%;display:block}.temperature-chart.simplified{width:100%;height:350px;cursor:pointer;transition:opacity .2s}.temperature-chart.simplified:hover{opacity:.95}.simplified-chart-wrapper{background:var(--bg-secondary);border-radius:12px;padding:1.75rem 2rem 1.75rem .5rem;border:1px solid var(--border-color);box-shadow:0 2px 8px #0000000a;transition:all .3s ease;overflow:visible}[data-theme=dark] .simplified-chart-wrapper{box-shadow:0 2px 8px #00000040}.temperature-chart.detailed{height:400px}.chart-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border-color)}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-emoji{font-size:1rem;line-height:1;display:inline-block}.legend-text{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.legend-color{width:14px;height:14px;border-radius:3px;display:inline-block;box-shadow:0 2px 4px #0000001a;flex-shrink:0}[data-theme=dark] .legend-color{box-shadow:0 2px 4px #0000004d}.chart-tooltip-content{display:flex;flex-direction:column;min-width:140px;background:var(--bg-secondary)!important;border:1px solid var(--border-color)!important;border-radius:8px!important;box-shadow:0 8px 24px #0000001f!important;padding:.75rem 1rem!important;pointer-events:none;will-change:contents;contain:layout style paint;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}[data-theme=dark] .chart-tooltip-content{background:var(--bg-secondary)!important;border:1px solid var(--border-color)!important;box-shadow:0 8px 24px #0006!important;-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}.chart-tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.chart-tooltip-year-with-emoji{display:flex;align-items:center;gap:.5rem}.chart-tooltip-emoji{font-size:1rem;line-height:1}.chart-tooltip-year{font-size:.875rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.chart-tooltip-extreme{font-size:1rem;line-height:1}.chart-tooltip-body{display:flex;flex-direction:column;gap:.5rem}.chart-tooltip-temp-primary{display:flex;align-items:baseline;gap:.5rem}.chart-tooltip-temp-value{font-size:1.125rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.chart-tooltip-temp-diff{font-size:.75rem;font-weight:600;font-variant-numeric:tabular-nums;line-height:1.3}.chart-tooltip-temp-diff.above{color:var(--temp-above)}.chart-tooltip-temp-diff.below{color:var(--temp-below)}.chart-tooltip-temp-secondary{display:flex;align-items:baseline;gap:.375rem}.chart-tooltip-temp-value-small{font-size:.875rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.chart-tooltip-temp-diff-small{font-size:.6875rem;font-weight:600;font-variant-numeric:tabular-nums;line-height:1.35}.chart-tooltip-temp-diff-small.above{color:var(--temp-above)}.chart-tooltip-temp-diff-small.below{color:var(--temp-below)}.chart-tooltip-condition{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-secondary);font-weight:500;margin-top:.25rem}.chart-tooltip-condition-icon{font-size:.875rem;line-height:1}.chart-tooltip-condition-text{text-transform:capitalize}.chart-tooltip-card{display:flex;flex-direction:column;min-width:90px;background:color-mix(in srgb,var(--bg-secondary) 82%,transparent);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 38px -10px #0003,0 10px 20px -15px #0000001f;padding:.75rem 1rem 1rem;pointer-events:none;-webkit-backdrop-filter:blur(32px) saturate(1.8);backdrop-filter:blur(32px) saturate(1.8);contain:layout style paint;will-change:contents}[data-theme=dark] .chart-tooltip-card{background:color-mix(in srgb,var(--bg-secondary) 78%,transparent);box-shadow:0 10px 38px -10px #00000080,0 10px 20px -15px #00000059;-webkit-backdrop-filter:blur(36px) saturate(1.6);backdrop-filter:blur(36px) saturate(1.6)}.chart-tooltip-card.hottest{border-color:var(--highlight-hot-border);background:color-mix(in srgb,var(--highlight-hot-bg) 78%,transparent)}[data-theme=dark] .chart-tooltip-card.hottest{background:color-mix(in srgb,var(--highlight-hot-bg) 72%,transparent)}.chart-tooltip-card.coldest{border-color:var(--highlight-cold-border);background:color-mix(in srgb,var(--highlight-cold-bg) 78%,transparent)}[data-theme=dark] .chart-tooltip-card.coldest{background:color-mix(in srgb,var(--highlight-cold-bg) 72%,transparent)}.chart-tooltip-card.wettest{border-color:var(--highlight-wet-border);background:color-mix(in srgb,var(--highlight-wet-bg) 78%,transparent)}[data-theme=dark] .chart-tooltip-card.wettest{background:color-mix(in srgb,var(--highlight-wet-bg) 72%,transparent)}.chart-tooltip-card-header{display:flex;justify-content:space-between;align-items:center;line-height:1;white-space:nowrap;min-width:0;flex-shrink:0}.chart-tooltip-card-year{margin:0;font-size:var(--text-base);color:var(--text-secondary);font-weight:600;letter-spacing:.015em;font-variant-numeric:tabular-nums;line-height:1;text-transform:uppercase}.chart-tooltip-card.hottest .chart-tooltip-card-year{color:var(--highlight-hot-text)}.chart-tooltip-card.coldest .chart-tooltip-card-year{color:var(--highlight-cold-text)}.chart-tooltip-card.wettest .chart-tooltip-card-year{color:var(--highlight-wet-text)}.chart-tooltip-card-badge{font-size:var(--text-lg);line-height:1;opacity:.9;flex-shrink:0;white-space:nowrap;display:inline-flex;align-items:center}.chart-tooltip-card-body{display:flex;flex-direction:column;flex:1;margin-top:.625rem}.chart-tooltip-card-temps{display:flex;align-items:baseline;gap:.5rem}.chart-tooltip-card-temp{font-size:var(--text-2xl);font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1}.chart-tooltip-card-temp.high{color:var(--text-primary)}.chart-tooltip-card-temp.low{color:var(--text-tertiary)}.chart-tooltip-card.hottest .chart-tooltip-card-temp.high{color:var(--highlight-hot-text);font-weight:700}.chart-tooltip-card.coldest .chart-tooltip-card-temp.low{color:var(--highlight-cold-text);font-weight:700}.chart-tooltip-card-diffs{display:flex;align-items:baseline;gap:.5rem;margin-top:.375rem}.chart-tooltip-card-diff{font-size:var(--text-sm);font-weight:600;font-variant-numeric:tabular-nums;line-height:1;white-space:nowrap}.chart-tooltip-card-diff.above{color:var(--temp-above)}.chart-tooltip-card-diff.below{color:var(--temp-below)}.chart-tooltip-card-diff:not(.above):not(.below){color:var(--text-tertiary)}.chart-tooltip-card-condition{display:flex;align-items:center;gap:.375rem;font-size:var(--text-sm);color:var(--text-secondary);margin-top:.5rem}.chart-tooltip-card-condition-icon{font-size:var(--text-base);line-height:1}.chart-tooltip-card-condition-text{text-transform:capitalize;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-temp-label,.chart-diff-label,.chart-avg-label,.chart-trend-label{font-variant-numeric:tabular-nums}.chart-temp-label,.chart-diff-label{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.temperature-chart text{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.recharts-cartesian-grid-horizontal line{stroke:var(--border-color);stroke-opacity:.12;stroke-width:1}.recharts-cartesian-grid-vertical line{stroke:transparent}.recharts-wrapper{padding:.5rem 0}.recharts-surface{overflow:visible}.recharts-cartesian-axis-tick-value{fill:var(--text-secondary);font-size:11px;font-weight:500;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:.01em;font-variant-numeric:tabular-nums}.recharts-cartesian-axis-line{stroke:var(--border-color);stroke-opacity:.3;stroke-width:1}.recharts-tooltip-wrapper{outline:none;pointer-events:none;will-change:transform;z-index:100!important;position:relative;transition:none!important;animation:none!important}.recharts-wrapper,.recharts-wrapper *,.recharts-surface,.recharts-layer,.recharts-bar,.recharts-bar-rectangle,.recharts-rectangle,.simplified-chart-wrapper,.simplified-chart-wrapper *{outline:none!important;-webkit-tap-highlight-color:transparent}.simplified-chart-wrapper:focus,.simplified-chart-wrapper:focus-visible,.recharts-wrapper:focus,.recharts-wrapper:focus-visible,.recharts-surface:focus,.recharts-surface:focus-visible{outline:none!important;box-shadow:none!important}.recharts-tooltip-wrapper{overflow:visible!important;position:absolute!important;z-index:10000!important;pointer-events:none!important;contain:layout style!important}.recharts-tooltip-wrapper>div{background:transparent!important;border:none!important;border-radius:0!important;box-shadow:none!important;padding:.5rem!important;opacity:1!important;pointer-events:none!important;position:relative!important}[data-theme=dark] .recharts-tooltip-wrapper>div{background:transparent!important;border:none!important;box-shadow:none!important;padding:.5rem!important;opacity:1!important}.recharts-tooltip-wrapper .chart-tooltip-card{background:color-mix(in srgb,var(--bg-secondary) 82%,transparent)!important;border:1px solid var(--border-color)!important;border-radius:12px!important;box-shadow:0 10px 38px -10px #0003,0 10px 20px -15px #0000001f!important;-webkit-backdrop-filter:blur(32px) saturate(1.8)!important;backdrop-filter:blur(32px) saturate(1.8)!important}[data-theme=dark] .recharts-tooltip-wrapper .chart-tooltip-card{background:color-mix(in srgb,var(--bg-secondary) 78%,transparent)!important;box-shadow:0 10px 38px -10px #00000080,0 10px 20px -15px #00000059!important;-webkit-backdrop-filter:blur(36px) saturate(1.6)!important;backdrop-filter:blur(36px) saturate(1.6)!important}.recharts-tooltip-wrapper .chart-tooltip-card.hottest{border-color:var(--highlight-hot-border)!important;background:color-mix(in srgb,var(--highlight-hot-bg) 78%,transparent)!important}[data-theme=dark] .recharts-tooltip-wrapper .chart-tooltip-card.hottest{background:color-mix(in srgb,var(--highlight-hot-bg) 72%,transparent)!important}.recharts-tooltip-wrapper .chart-tooltip-card.coldest{border-color:var(--highlight-cold-border)!important;background:color-mix(in srgb,var(--highlight-cold-bg) 78%,transparent)!important}[data-theme=dark] .recharts-tooltip-wrapper .chart-tooltip-card.coldest{background:color-mix(in srgb,var(--highlight-cold-bg) 72%,transparent)!important}.recharts-tooltip-wrapper .chart-tooltip-card.wettest{border-color:var(--highlight-wet-border)!important;background:color-mix(in srgb,var(--highlight-wet-bg) 78%,transparent)!important}[data-theme=dark] .recharts-tooltip-wrapper .chart-tooltip-card.wettest{background:color-mix(in srgb,var(--highlight-wet-bg) 72%,transparent)!important}.recharts-tooltip-wrapper .chart-tooltip-content{background:var(--bg-secondary)!important;padding:.75rem 1rem!important}[data-theme=dark] .recharts-tooltip-wrapper .chart-tooltip-content{background:var(--bg-secondary)!important}.recharts-default-tooltip{background:var(--bg-secondary)!important;border:1px solid var(--border-color)!important;border-radius:8px!important;box-shadow:0 8px 24px #0000001f!important;padding:.75rem 1rem!important;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}[data-theme=dark] .recharts-default-tooltip{box-shadow:0 8px 24px #0006!important;-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}.recharts-tooltip-label{color:var(--text-primary)!important;font-size:.8125rem!important;font-weight:600!important;margin-bottom:.5rem!important;padding-bottom:.5rem!important;border-bottom:1px solid var(--border-color)!important;letter-spacing:-.01em!important}.recharts-tooltip-item{color:var(--text-secondary)!important;font-size:.8125rem!important;font-weight:500!important;padding:.125rem 0!important}.recharts-tooltip-item-name{font-weight:500!important}.recharts-tooltip-item-value{font-weight:600!important;color:var(--text-primary)!important;font-variant-numeric:tabular-nums!important}.chart-bg{fill:var(--bg-primary)}.chart-grid-major{stroke:var(--border-color)}.chart-grid-minor{stroke:var(--bg-tertiary)}.chart-label{fill:var(--text-secondary)}.chart-avg-zone{fill:var(--bg-tertiary);opacity:.4}.chart-avg-zone[fill]{fill:var(--bg-tertiary)}.chart-year-label{fill:var(--text-secondary)}.chart-year-label-emphasis{fill:var(--text-primary)}.chart-avg-line{stroke:var(--text-secondary);opacity:.6}[data-theme=dark] .chart-avg-line{opacity:.8}.chart-circle-stroke{stroke:var(--bg-primary)}.chart-temp-label{fill:var(--text-secondary)}.chart-temp-high-emphasis{fill:var(--temp-above)}.chart-temp-low-emphasis{fill:var(--temp-below)}.chart-avg-label{fill:var(--text-primary)}.simplified-chart-wrapper{position:relative;isolation:isolate;overflow:visible}.simplified-chart-wrapper .recharts-responsive-container{overflow:visible!important}.simplified-chart-wrapper .recharts-responsive-container>div{overflow:visible!important;overflow-x:visible!important;overflow-y:visible!important;min-width:0!important}.simplified-chart-wrapper .recharts-wrapper{position:relative;z-index:1;overflow:visible}.chart-modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:0;overflow:hidden;touch-action:none}.chart-modal{background:var(--bg-secondary);border-radius:0;width:100vw;height:100vh;max-width:100vw;max-height:100vh;display:flex;flex-direction:column;box-shadow:none;overflow:hidden}.chart-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 2.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-primary);flex-shrink:0}.chart-modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.chart-modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:9999px;transition:all .2s;line-height:1}.chart-modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.chart-modal-content{padding:2rem 2.5rem;overflow:auto;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:0;max-width:100%}.chart-modal .temperature-chart.detailed{width:100%;height:100%;min-height:500px;max-width:100%;flex:1}.chart-modal .chart-legend{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color);width:100%;max-width:100%;flex-shrink:0;display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem}@media(max-width:768px){.chart-modal-header{padding:1rem 1.25rem}.chart-modal-header h3{font-size:.9375rem;line-height:1.3}.chart-modal-close{min-width:44px;min-height:44px}.chart-modal-content{padding:1rem .75rem}.chart-modal .temperature-chart.detailed{min-height:400px}.chart-modal .chart-legend{gap:.75rem;margin-top:1.25rem;flex-wrap:wrap}.chart-modal .chart-legend .legend-item{font-size:.75rem}}@media(max-width:640px){.chart-tooltip-content{min-width:120px;padding:.625rem .75rem!important}.chart-tooltip-header{margin-bottom:.5rem}.chart-tooltip-year{font-size:.8125rem}.chart-tooltip-temp-value{font-size:1rem}.chart-tooltip-temp-diff{font-size:.6875rem}.chart-tooltip-temp-value-small{font-size:.8125rem}.chart-tooltip-temp-diff-small,.chart-tooltip-condition{font-size:.6875rem}}@media(max-width:480px){.chart-modal-header{padding:.75rem .875rem}.chart-modal-header h3{font-size:.875rem;line-height:1.3}.chart-modal-close{min-width:40px;min-height:40px;font-size:1.25rem}.chart-modal-content{padding:.75rem .5rem}.chart-modal .temperature-chart.detailed{min-height:320px}.chart-modal .chart-legend{gap:.5rem;margin-top:1rem}.chart-modal .chart-legend .legend-item{font-size:.6875rem}.chart-tooltip-content{min-width:110px;padding:.5rem .625rem!important}.chart-tooltip-year{font-size:.75rem}.chart-tooltip-temp-value{font-size:.9375rem}.chart-tooltip-temp-diff{font-size:.6875rem}.chart-tooltip-temp-value-small{font-size:.8125rem}.chart-tooltip-temp-diff-small,.chart-tooltip-condition{font-size:.6875rem}}@media(max-width:375px){.chart-modal-header{padding:.625rem .75rem}.chart-modal-header h3{font-size:.8125rem}.chart-modal-content{padding:.625rem .4375rem}.chart-modal .temperature-chart.detailed{min-height:300px}}.weather-emoji-view{margin-top:.375rem;background:var(--bg-secondary);border-radius:3px;padding:1.5rem;border:1px solid var(--border-color)}.emoji-content{text-align:center;margin-bottom:1.5rem}.emoji-header-text{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:1.125rem;font-weight:600;color:var(--text-primary);letter-spacing:.02em;margin-bottom:1rem;white-space:pre}.emoji-grid-text{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:1.5rem;font-weight:600;line-height:1.6;color:var(--text-primary);white-space:pre;word-break:break-all}.emoji-row{white-space:pre}.emoji-legend{padding-top:1.5rem;border-top:1px solid var(--border-color)}.emoji-legend-title{font-size:.75rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;text-align:center}.emoji-legend-items{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}.emoji-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.6875rem;color:var(--text-secondary)}.emoji-legend-emoji{font-size:1.25rem;line-height:1}.emoji-legend-label{font-weight:500}@media(max-width:768px){.emoji-header-text{font-size:.9375rem}.emoji-grid-text{font-size:1.25rem}.emoji-legend-items{flex-direction:column;align-items:flex-start;gap:.75rem}}@media(max-width:768px){.app-header h1{font-size:2rem}.app-header p{font-size:1rem}.controls{padding:1.5rem}.date-inputs{flex-direction:column}.comparison-header{flex-direction:column;align-items:stretch;gap:.75rem}.comparison-header .weather-stats{width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.comparison-header .controls-group{width:100%;flex-direction:row;align-items:center;justify-content:flex-end;margin-left:0}.view-toggle{width:100%;justify-content:stretch}.view-btn{flex:1}.sort-controls,.sort-select{width:100%}.weather-table-container{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;margin:0;padding:0;width:100%;max-width:100%;border-radius:12px;border:1px solid var(--border-color);background:transparent;box-shadow:0 2px 8px #0000000a;position:relative}[data-theme=dark] .weather-table-container{box-shadow:0 2px 8px #00000040}.weather-table-container::-webkit-scrollbar{height:6px}.weather-table-container::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.weather-table-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.weather-table{min-width:580px;border-collapse:separate;border-spacing:0}.weather-table th{position:static;opacity:1;padding:.625rem .875rem;font-size:.6875rem;border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color)}.weather-table td{padding:.625rem .875rem}.weather-table .year-cell,.weather-table .year-value,.weather-table .temp-cell,.weather-table .condition-cell,.weather-table .precip-cell{font-size:.75rem}.weather-table .temp-value{font-size:.75rem;min-width:2.75rem}.weather-table .temp-diff-inline{font-size:.6875rem}.weather-table .deviation-emoji-table,.weather-table .extreme-indicator{font-size:.9375rem}.weather-table tbody tr.row-hottest .temp-cell.high .temp-value,.weather-table tbody tr.row-coldest .temp-cell.low .temp-value,.weather-table tbody tr.row-wettest .precip-cell{font-size:.8125rem}.year-with-emoji-table{gap:.5rem}.weather-table th.year-col{position:sticky;left:0;z-index:12;background-color:hsla(var(--bg-secondary-hsl, 40, 10%, 22%),.85);background:var(--bg-secondary);border-right:2px solid var(--border-color);box-shadow:none;transition:box-shadow .15s ease;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}.weather-table td.year-cell{position:sticky;left:0;z-index:11;background-color:hsla(var(--bg-secondary-hsl, 40, 10%, 22%),.85);background:var(--bg-secondary);border-right:2px solid var(--border-color);box-shadow:none;transition:box-shadow .15s ease;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}.weather-table-container.is-scrolled .weather-table th.year-col,.weather-table-container.is-scrolled .weather-table td.year-cell{box-shadow:3px 0 6px -2px #00000026}[data-theme=dark] .weather-table-container.is-scrolled .weather-table th.year-col,[data-theme=dark] .weather-table-container.is-scrolled .weather-table td.year-cell{box-shadow:3px 0 6px -2px #0006}.weather-table tbody tr:nth-child(odd) td.year-cell{background:var(--bg-tertiary);-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}.weather-table tbody tr:hover td.year-cell{background:var(--bg-tertiary);-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}.weather-table tbody tr.row-hottest,.weather-table tbody tr.row-coldest,.weather-table tbody tr.row-wettest{border-left:none!important}.weather-table tbody tr.row-hottest td.year-cell{background-color:var(--highlight-hot-bg);border-left:3px solid var(--highlight-hot-border)}.weather-table tbody tr.row-hottest:nth-child(odd) td.year-cell,.weather-table tbody tr.row-hottest:hover td.year-cell{background-color:var(--highlight-hot-bg);border-left-color:var(--highlight-hot-border)}.weather-table tbody tr.row-coldest td.year-cell{background-color:var(--highlight-cold-bg);border-left:3px solid var(--highlight-cold-border)}.weather-table tbody tr.row-coldest:nth-child(odd) td.year-cell,.weather-table tbody tr.row-coldest:hover td.year-cell{background-color:var(--highlight-cold-bg);border-left-color:var(--highlight-cold-border)}.weather-table tbody tr.row-wettest td.year-cell{background-color:var(--highlight-wet-bg);border-left:3px solid var(--highlight-wet-border)}.weather-table tbody tr.row-wettest:nth-child(odd) td.year-cell,.weather-table tbody tr.row-wettest:hover td.year-cell{background-color:var(--highlight-wet-bg);border-left-color:var(--highlight-wet-border)}.temperature-chart{height:280px}.simplified-chart-wrapper{padding:.875rem .625rem .875rem .375rem}.weather-cards-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.weather-card{padding:.5rem}.temperature{flex-direction:column}.weather-card-header{flex-wrap:nowrap;gap:.375rem;white-space:nowrap}.header-main{width:100%;justify-content:space-between}.extreme-badge{flex-shrink:0;white-space:nowrap}.temp-value{font-size:1.375rem}.temp-high,.temp-low{min-height:68px;padding:.625rem .375rem}}@media(max-width:480px){.app{padding:1rem}.app-header h1{font-size:1.75rem}.controls{padding:1rem}.weather-comparison{padding:0}}.weather-search-controls{padding:0}.weather-search-controls .search-controls,.search-controls{display:flex;flex-direction:column;gap:1rem}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{font-weight:600;color:var(--text-primary);font-size:var(--text-md);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.375rem;display:block}.controls-section .control-group label{display:block}.days-input-group{display:flex;flex-direction:column;gap:.5rem}.days-suggestions{display:flex;flex-wrap:wrap;gap:.375rem}.days-tag{padding:.25rem .5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:9999px;font-size:var(--text-md);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-family:inherit}.days-tag:hover{background:var(--bg-primary);border-color:var(--border-hover)}.days-tag.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.weather-search-results{background:transparent;border-radius:8px;padding:.75rem;border:none;height:100%}.comparison-placeholder,.search-results-placeholder{padding:2rem 1.5rem;text-align:center;color:var(--text-secondary);height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}@media(max-width:768px){.comparison-placeholder,.search-results-placeholder{padding:1.5rem 1rem;min-height:250px}}@media(max-width:480px){.comparison-placeholder,.search-results-placeholder{padding:1rem .75rem;min-height:200px}}.empty-state{display:flex;flex-direction:column;gap:.75rem;text-align:center;padding:2rem 1rem}.empty-title{margin:0;font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.empty-message{margin:0;font-size:var(--text-lg);color:var(--text-secondary);line-height:1.6}.empty-hint{margin:0;font-size:var(--text-lg);color:var(--text-tertiary);margin-top:.5rem;line-height:1.5}@media(max-width:480px){.empty-state{padding:1.5rem .75rem}}.comparison-placeholder p,.search-results-placeholder p{margin:0}.query-select,.location-input-field,.days-input{width:100%;padding:.5rem .75rem;border:1px solid var(--border-hover);border-radius:9999px;font-size:var(--text-xl);font-family:inherit;background:var(--bg-secondary);transition:all .2s;color:var(--text-primary)}.query-select:focus,.location-input-field:focus,.days-input:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .query-select:focus,[data-theme=dark] .location-input-field:focus,[data-theme=dark] .days-input:focus{box-shadow:0 0 0 3px #ffffff1a}.search-button{width:100%;padding:.625rem 1rem;background:var(--accent-color);color:#fff;border:none;border-radius:9999px;font-size:var(--text-xl);font-weight:500;cursor:pointer;transition:background-color .2s;min-height:40px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.search-button:hover:not(:disabled){background:var(--accent-hover)}.search-button:disabled{opacity:.5;cursor:not-allowed}.search-error{background:var(--error-bg);border:1px solid var(--error-border);border-radius:6px;padding:.75rem;margin-bottom:.75rem;color:var(--error-text);font-size:var(--text-xl)}.search-error p{margin:.25rem 0}.search-error .error-message{color:var(--text-secondary);font-size:var(--text-lg)}.search-error .error-hint{color:var(--text-tertiary);font-size:var(--text-md);margin-top:.5rem}.search-result-header{margin-bottom:.75rem}.search-result-header h2{margin:0 0 .375rem;color:var(--text-primary);font-size:var(--text-2xl);font-weight:600;letter-spacing:-.01em}.result-description{margin:0;color:var(--text-secondary);font-size:var(--text-lg);line-height:1.5}.result-card{background:var(--bg-secondary);border-radius:6px;padding:.75rem;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000f;transition:all .2s ease;animation:fadeIn .3s ease-out}.result-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}[data-theme=dark] .result-card:hover{box-shadow:0 4px 12px #0000004d}.result-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.375rem;border-bottom:1px solid var(--border-color)}.result-card-header .condition-icon{font-size:var(--text-2xl);line-height:1}.result-card-header h3{margin:0;font-size:var(--text-xl);color:var(--text-primary);font-weight:600;letter-spacing:-.01em;font-variant-numeric:tabular-nums}.result-card-body{display:flex;flex-direction:column;gap:.375rem}.result-card-body .temperature{display:flex;gap:.375rem}.result-card-body .temp-high,.result-card-body .temp-low{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .375rem;border-radius:6px;min-height:52px}.result-card-body .temp-label{font-size:var(--text-md);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.125rem}.result-card-body .temp-value-group{display:flex;align-items:baseline;gap:.125rem}.result-card-body .temp-value{font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.result-card-body .condition{font-size:var(--text-lg);color:var(--text-secondary);text-align:center;padding:.25rem}.result-card-body .precipitation{display:flex;justify-content:space-between;align-items:center;padding:.375rem .5rem;background:var(--bg-tertiary);border-radius:6px}.result-card-body .precip-label{font-size:var(--text-md);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.result-card-body .precip-value{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.change-display{font-size:var(--text-lg);color:var(--text-secondary);text-align:center;display:flex;justify-content:space-between;align-items:center;padding:.375rem .5rem;background:var(--bg-tertiary);border-radius:6px}.change-label{font-size:var(--text-md);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.change-value{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.multi-location-comparison{width:100%}.multi-location-header{background:var(--bg-secondary);border-radius:9999px;padding:.5rem .75rem;border:1px solid var(--border-color);margin-bottom:.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.multi-location-title h2{margin:0;color:var(--text-primary);font-size:.875rem;font-weight:600;letter-spacing:-.01em}.multi-location-controls{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.multi-location-controls .view-toggle{display:flex;gap:0;background:var(--bg-tertiary);padding:.125rem;border-radius:9999px;border:1px solid var(--border-color)}[data-theme=dark] .multi-location-controls .view-toggle{background:var(--bg-primary);border-color:var(--border-color)}.multi-location-controls .view-btn{padding:.25rem .5rem;border:none;background:transparent;border-radius:3px;cursor:pointer;font-size:.6875rem;font-weight:500;color:var(--text-secondary);transition:all .2s;font-family:inherit;white-space:nowrap}.multi-location-controls .view-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}[data-theme=dark] .multi-location-controls .view-btn:hover{background:var(--bg-tertiary)}.multi-location-controls .view-btn.active{background:var(--bg-secondary);color:var(--text-primary)}[data-theme=dark] .multi-location-controls .view-btn.active{background:var(--bg-tertiary)}.multi-location-controls .sort-select{padding:.25rem .5rem;border:1px solid var(--border-hover);border-radius:9999px;font-size:.6875rem;font-family:inherit;background:var(--bg-secondary);cursor:pointer;transition:all .2s;color:var(--text-primary)}.multi-location-controls .sort-select:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .multi-location-controls .sort-select:focus{box-shadow:0 0 0 3px #ffffff1a}.multi-location-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:.5rem}.weather-comparison.compact{padding:0;border:none;background:transparent}.weather-comparison.compact .comparison-header{display:none}.weather-comparison.compact .weather-stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.375rem;margin-bottom:.5rem}.weather-comparison.compact .stat-card{padding:.5rem .625rem;gap:.375rem}.weather-comparison.compact .stat-icon{font-size:1rem}.weather-comparison.compact .stat-label{font-size:.6875rem}.weather-comparison.compact .stat-value{font-size:.8125rem}.weather-comparison.compact .stat-year{font-size:.6875rem}.weather-comparison.compact .weather-cards-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.25rem}.weather-comparison.compact .weather-card{padding:.4375rem}.weather-comparison.compact .weather-card-header{padding-bottom:.5rem}.weather-comparison.compact .weather-card-header h3{font-size:1rem}.weather-comparison.compact .condition-icon{font-size:1.125rem}.weather-comparison.compact .temp-value{font-size:1.25rem}.weather-comparison.compact .temp-high,.weather-comparison.compact .temp-low{min-height:64px;padding:.625rem .375rem}.weather-comparison.compact .temp-label{font-size:.6875rem;margin-bottom:.25rem}.weather-comparison.compact .temp-diff{font-size:.6875rem}.weather-comparison.compact .condition{font-size:.6875rem;padding:.375rem}.weather-comparison.compact .precipitation{font-size:.6875rem;padding:.375rem .5rem}.weather-comparison.compact .precip-label{font-size:.6875rem}.weather-comparison.compact .precip-value{font-size:.75rem}.weather-comparison.compact .weather-table-container{margin-top:.375rem}.weather-comparison.compact .weather-chart-container{margin-top:.375rem;padding:.5rem}.weather-comparison.compact .temperature-chart{height:180px}.weather-comparison.compact .weather-table th{padding:.3125rem .375rem;font-size:.6875rem}.weather-comparison.compact .weather-table td{padding:.25rem}.location-comparison-card{background:var(--bg-secondary);border-radius:9999px;padding:.5rem;border:1px solid var(--border-color);display:flex;flex-direction:column;transition:all .2s ease;animation:cardFadeIn .4s ease-out backwards}.location-comparison-card:nth-child(1){animation-delay:.05s}.location-comparison-card:nth-child(2){animation-delay:.1s}.location-comparison-card:nth-child(3){animation-delay:.15s}.location-comparison-card:nth-child(4){animation-delay:.2s}.location-comparison-card:nth-child(5){animation-delay:.25s}.location-comparison-card:nth-child(n+6){animation-delay:.3s}.location-comparison-card:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}[data-theme=dark] .location-comparison-card:hover{box-shadow:0 1px 4px #ffffff1a}.location-name{margin:0 0 .375rem;color:var(--text-primary);font-size:.8125rem;font-weight:600;letter-spacing:-.01em;padding-bottom:.375rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.375rem}.location-comparison-content{flex:1;overflow:visible}.multi-location-comparison.loading,.multi-location-comparison.empty{text-align:center;padding:3rem;color:var(--text-secondary);background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.loading-state,.error-state{padding:2rem;text-align:center;color:var(--text-secondary)}.error-state{color:var(--error-text)}@media(max-width:768px){.app-content{padding:.75rem;gap:1rem}.app-main{padding:0}.result-card{padding:.875rem}.result-card-header{flex-wrap:wrap;gap:.5rem}.multi-location-header{flex-direction:column;align-items:stretch;padding:1rem}.multi-location-controls{width:100%;flex-direction:column;align-items:stretch;gap:.75rem}.multi-location-controls .view-toggle{width:100%;justify-content:stretch}.multi-location-controls .view-btn{flex:1;min-height:44px}.multi-location-controls .sort-select{width:100%;min-height:44px;padding:.625rem .75rem}.multi-location-grid{grid-template-columns:1fr;gap:1rem}.location-comparison-card{padding:.875rem}.weather-comparison.compact .weather-cards-grid{grid-template-columns:repeat(4,1fr);gap:.1875rem}.weather-comparison.compact .temperature-chart{height:250px}.weather-comparison.compact .stat-card{padding:.625rem .75rem;min-height:44px}}@media(max-width:480px){.result-card{padding:.75rem}.multi-location-header{padding:.875rem}.multi-location-controls .view-btn,.multi-location-controls .sort-select{min-height:40px;font-size:.75rem}.location-comparison-card{padding:.75rem}}.theme-toggle{padding:.5rem;border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:9999px;cursor:pointer;font-size:1.125rem;color:var(--text-primary);transition:all .2s ease;font-family:inherit;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;line-height:1;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.theme-toggle:hover{background:var(--bg-tertiary);border-color:var(--border-hover);transform:scale(1.05)}.theme-toggle:active{transform:scale(.95)}.unit-toggle{padding:.5rem;border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:9999px;cursor:pointer;font-size:1.125rem;color:var(--text-primary);transition:all .2s ease;font-family:inherit;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;line-height:1;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.unit-toggle:hover{background:var(--bg-tertiary);border-color:var(--border-hover);transform:scale(1.05)}.unit-toggle:active{transform:scale(.95)}.fab-container{position:fixed;bottom:1.5rem;right:1rem;z-index:1000;display:none;flex-direction:column;gap:.75rem;align-items:flex-end}.fab{width:56px;height:56px;border-radius:50%;background:var(--accent-color);color:#fff;border:none;box-shadow:0 4px 12px #00000026;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);touch-action:manipulation;-webkit-tap-highlight-color:transparent;position:relative}[data-theme=dark] .fab{box-shadow:0 4px 12px #0006}.fab:hover{transform:scale(1.1);box-shadow:0 6px 16px #0003}.fab:active{transform:scale(.95);transition:transform .1s ease}.fab-main{background:var(--accent-color);z-index:1001}.fab-secondary{width:48px;height:48px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);font-size:1.25rem;box-shadow:0 2px 8px #0000001a;opacity:0;transform:translateY(10px) scale(.8);pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:600;display:flex;align-items:center;justify-content:center}[data-theme=dark] .fab-secondary{box-shadow:0 2px 8px #0000004d}.fab-container.expanded .fab-secondary{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.fab-secondary:nth-child(2){transition-delay:.05s}.fab-secondary:nth-child(3){transition-delay:.1s}.fab-secondary:nth-child(4){transition-delay:.15s}.fab-label{position:absolute;right:calc(100% + .75rem);background:var(--bg-primary);color:var(--text-primary);padding:.5rem .75rem;border-radius:6px;font-size:.75rem;font-weight:500;white-space:nowrap;box-shadow:0 2px 8px #00000026;border:1px solid var(--border-color);opacity:0;pointer-events:none;transform:translate(-10px);transition:all .2s ease}[data-theme=dark] .fab-label{box-shadow:0 2px 8px #0006}.fab:hover .fab-label{opacity:1;transform:translate(0)}.fab-menu-toggle{position:relative}.fab-menu-toggle{font-size:1.5rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.fab-container.expanded .fab-menu-toggle{transform:rotate(90deg)}@media(max-width:768px){.fab-container{display:flex}.app-main{padding-bottom:5rem}}@media(max-width:640px){.fab-container{bottom:1.25rem;right:.875rem;gap:.625rem}.fab{width:52px;height:52px;font-size:1.375rem}.fab-secondary{width:44px;height:44px;font-size:1rem}.app-main{padding-bottom:4.75rem}}@media(max-width:480px){.fab-container{bottom:1rem;right:.75rem;gap:.5rem}.fab{width:48px;height:48px;font-size:1.25rem}.fab-secondary{width:40px;height:40px;font-size:.9375rem}.app-main{padding-bottom:4.5rem}.fab-label{font-size:.6875rem;padding:.375rem .625rem}}@media(max-width:375px){.fab-container{bottom:.875rem;right:.625rem;gap:.4375rem}.fab{width:44px;height:44px;font-size:1.125rem}.fab-secondary{width:38px;height:38px;font-size:.875rem}.app-main{padding-bottom:4.25rem}}.seasonal-comparison{background:var(--bg-secondary);border-radius:9999px;padding:.75rem;border:1px solid var(--border-color);height:100%;animation:fadeIn .3s ease-out}.seasonal-header{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color);animation:fadeIn .3s ease-out}.seasonal-header h2{margin:0 0 .5rem;color:var(--text-primary);font-size:.875rem;font-weight:600;letter-spacing:-.01em}.seasonal-averages{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.avg-stat{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:var(--bg-primary);border-radius:9999px;border:1px solid var(--border-color);font-size:.6875rem;animation:fadeIn .3s ease-out backwards}.avg-stat:nth-child(1){animation-delay:.1s}.avg-stat:nth-child(2){animation-delay:.15s}.avg-stat:nth-child(3){animation-delay:.2s}.avg-label{color:var(--text-secondary);font-weight:500}.avg-value{font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.seasonal-data-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.seasonal-year-card{background:var(--bg-secondary);border-radius:9999px;padding:.75rem;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000f;transition:all .2s ease;animation:cardFadeIn .4s ease-out backwards}.seasonal-year-card:nth-child(1){animation-delay:.05s}.seasonal-year-card:nth-child(2){animation-delay:.1s}.seasonal-year-card:nth-child(3){animation-delay:.15s}.seasonal-year-card:nth-child(4){animation-delay:.2s}.seasonal-year-card:nth-child(5){animation-delay:.25s}.seasonal-year-card:nth-child(6){animation-delay:.3s}.seasonal-year-card:nth-child(7){animation-delay:.35s}.seasonal-year-card:nth-child(8){animation-delay:.4s}.seasonal-year-card:nth-child(n+9){animation-delay:.45s}.seasonal-year-card:hover{border-color:var(--border-hover);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}[data-theme=dark] .seasonal-year-card:hover{box-shadow:0 2px 8px #ffffff1a}.year-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.year-header h3{margin:0;font-size:.8125rem;color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums}.condition-badge{padding:.125rem .375rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:9999px;font-size:.625rem;font-weight:500;color:var(--text-secondary);text-transform:capitalize}.year-stats{display:flex;flex-direction:column;gap:.375rem}.stat-row{display:flex;justify-content:space-between;align-items:center;font-size:.6875rem}.stat-row .stat-label{color:var(--text-secondary);font-weight:500}.stat-row .stat-value{font-weight:600;color:var(--text-primary)}.stat-diff{font-size:.625rem;font-weight:600;font-variant-numeric:tabular-nums}.stat-diff.above{color:var(--temp-above)}.stat-diff.below{color:var(--temp-below)}.seasonal-comparison.loading,.seasonal-comparison.error,.seasonal-comparison.empty{text-align:center;padding:3rem;color:var(--text-secondary)}.seasonal-comparison.error{color:var(--error-text)}.weather-patterns{background:var(--bg-secondary);border-radius:9999px;padding:.75rem;border:1px solid var(--border-color);height:100%;animation:fadeIn .3s ease-out}.patterns-header{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.patterns-header h2{margin:0 0 .25rem;color:var(--text-primary);font-size:.875rem;font-weight:600;letter-spacing:-.01em}.patterns-date-range{margin:0;color:var(--text-secondary);font-size:.6875rem}.patterns-list{display:flex;flex-direction:column;gap:.75rem}.pattern-card{background:var(--bg-secondary);border-radius:9999px;padding:.75rem;border-left:4px solid;border-right:1px solid var(--border-color);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);box-shadow:0 1px 3px #0000000f;transition:all .2s ease;animation:cardFadeIn .4s ease-out backwards}.pattern-card:nth-child(1){animation-delay:.05s}.pattern-card:nth-child(2){animation-delay:.1s}.pattern-card:nth-child(3){animation-delay:.15s}.pattern-card:nth-child(4){animation-delay:.2s}.pattern-card:nth-child(5){animation-delay:.25s}.pattern-card:nth-child(6){animation-delay:.3s}.pattern-card:nth-child(7){animation-delay:.35s}.pattern-card:nth-child(8){animation-delay:.4s}.pattern-card:nth-child(n+9){animation-delay:.45s}.pattern-card:hover{box-shadow:0 4px 12px #00000026;transform:translate(2px)}[data-theme=dark] .pattern-card:hover{box-shadow:0 4px 12px #ffffff26}.pattern-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.pattern-icon{font-size:1.25rem}.pattern-title{flex:1;display:flex;justify-content:space-between;align-items:center}.pattern-title h3{margin:0;font-size:.8125rem;color:var(--text-primary);font-weight:600;text-transform:capitalize}.pattern-duration{font-size:.625rem;font-weight:500;color:var(--text-secondary);background:var(--bg-secondary);padding:.125rem .375rem;border-radius:12px;border:1px solid var(--border-color)}.pattern-dates{font-size:.6875rem;color:var(--text-secondary);margin-bottom:.375rem}.pattern-description{font-size:.75rem;color:var(--text-secondary);line-height:1.4;margin-bottom:.5rem}.pattern-stats{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color)}.pattern-stats .stat-item{display:flex;align-items:center;gap:.375rem;font-size:.6875rem}.no-patterns,.weather-patterns.loading,.weather-patterns.error,.weather-patterns.empty{text-align:center;padding:3rem;color:var(--text-secondary)}.weather-patterns.error{color:var(--error-text)}.date-range-comparison{background:var(--bg-secondary);border-radius:9999px;padding:.75rem;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000f;height:100%;animation:fadeIn .3s ease-out}.comparison-summary{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:1rem;background:linear-gradient(to bottom,var(--bg-primary),var(--bg-tertiary));border-radius:6px;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000d;animation:fadeIn .3s ease-out}[data-theme=dark] .comparison-summary{box-shadow:0 1px 3px #ffffff0d}.summary-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;animation:fadeIn .3s ease-out backwards}.summary-item:nth-child(1){animation-delay:.1s}.summary-item:nth-child(2){animation-delay:.15s}.summary-item:nth-child(n+3){animation-delay:.2s}.summary-label{font-weight:600;color:var(--text-secondary)}.summary-value{font-weight:600;color:var(--text-primary)}.summary-diff{font-size:.6875rem;color:var(--text-secondary);font-weight:400}.ranges-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.range-card{background:var(--bg-secondary);border-radius:9999px;padding:.75rem;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000f;transition:all .2s ease;animation:cardFadeIn .4s ease-out backwards}.range-card:nth-child(1){animation-delay:.05s}.range-card:nth-child(2){animation-delay:.1s}.range-card:nth-child(n+3){animation-delay:.15s}.range-card:hover{border-color:var(--border-hover);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}[data-theme=dark] .range-card:hover{box-shadow:0 2px 8px #ffffff1a}.range-card h3{margin:0 0 .5rem;color:var(--text-primary);font-size:.8125rem;font-weight:600}.range-dates{font-size:.6875rem;color:var(--text-secondary);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color);font-variant-numeric:tabular-nums}.range-stats{display:flex;flex-direction:column;gap:.5rem}.range-stats .stat-row,.range-stats .stat-item{display:flex;justify-content:space-between;align-items:center;font-size:.6875rem}.date-range-comparison.loading,.date-range-comparison.error,.date-range-comparison.empty{text-align:center;padding:3rem;color:var(--text-secondary)}.date-range-comparison.error{color:var(--error-text)}.pattern-controls,.range-comparison-controls,.seasonal-controls{display:flex;flex-direction:column;gap:.75rem}.date-range-inputs{display:flex;align-items:center;gap:.5rem}.date-range-inputs span{font-size:.75rem;color:var(--text-secondary);font-weight:500}.date-input{flex:1;padding:.375rem .5rem;border:1px solid var(--border-hover);border-radius:9999px;font-size:.75rem;font-family:inherit;background:var(--bg-secondary);transition:all .2s ease;color:var(--text-primary)}.date-input:hover{border-color:var(--text-primary)}.date-input:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .date-input:focus{box-shadow:0 0 0 3px #ffffff1a}.season-select{padding:.375rem .5rem;border:1px solid var(--border-hover);border-radius:9999px;font-size:.8125rem;font-family:inherit;background:var(--bg-secondary);cursor:pointer;transition:all .2s ease;color:var(--text-primary);width:100%}.season-select:hover{border-color:var(--text-primary)}.season-select:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}[data-theme=dark] .season-select:focus{box-shadow:0 0 0 3px #ffffff1a}.skeleton{background:linear-gradient(90deg,var(--skeleton-base) 25%,var(--skeleton-highlight) 50%,var(--skeleton-base) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}.skeleton-text{display:inline-block}.weather-card.skeleton-card{background:var(--bg-secondary);border-radius:8px;padding:.5rem .5rem .75rem;border:1px solid var(--border-color);aspect-ratio:1;animation:cardFadeIn .4s ease-out backwards}.skeleton-card .weather-card-header{margin-bottom:auto}.skeleton-card .weather-card-body{display:flex;flex-direction:column;flex:1;justify-content:flex-end}.skeleton-card .temperature-display{display:flex;flex-direction:column}.skeleton-card .temp-row{display:flex;align-items:baseline;gap:.375rem}.stat-card.skeleton-stat{display:flex;align-items:center;gap:.375rem;padding:.4375rem .625rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:9999px;box-shadow:0 1px 2px #0000000a}.skeleton-stats{display:flex;flex-direction:row;gap:.5rem;flex-wrap:wrap;flex:1;align-items:flex-end}.skeleton-view-toggle{display:flex;align-items:center}.skeleton-table tbody tr{animation:fadeIn .3s ease-out backwards}.skeleton-table tbody tr:nth-child(1){animation-delay:.05s}.skeleton-table tbody tr:nth-child(2){animation-delay:.1s}.skeleton-table tbody tr:nth-child(3){animation-delay:.15s}.skeleton-table tbody tr:nth-child(4){animation-delay:.2s}.skeleton-table tbody tr:nth-child(5){animation-delay:.25s}.skeleton-table tbody tr:nth-child(6){animation-delay:.3s}.skeleton-table tbody tr:nth-child(7){animation-delay:.35s}.skeleton-table tbody tr:nth-child(8){animation-delay:.4s}.skeleton-table tbody tr:nth-child(n+9){animation-delay:.45s}.skeleton-chart{background:linear-gradient(90deg,var(--skeleton-base) 25%,var(--skeleton-highlight) 50%,var(--skeleton-base) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:8px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}[data-theme=dark] .weather-card.skeleton-card,[data-theme=dark] .stat-card.skeleton-stat{background:var(--bg-secondary);border-color:var(--border-color)}[data-theme=dark] .skeleton-chart{background:linear-gradient(90deg,var(--skeleton-base) 25%,var(--skeleton-highlight) 50%,var(--skeleton-base) 75%);background-size:200% 100%}@media(max-width:768px){.skeleton-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.375rem;width:100%}.stat-card.skeleton-stat{padding:.4375rem .5rem;border-radius:9999px;background:transparent;border:none;gap:.3125rem;box-shadow:none}.skeleton-view-toggle{display:none}}@media(max-width:768px){.header-content{grid-template-columns:1fr;gap:.5rem}.header-logo{justify-content:center}.unit-toggle{align-self:center}.seasonal-data-grid,.ranges-grid{grid-template-columns:1fr}.date-range-inputs{flex-direction:column;align-items:stretch;gap:.75rem}.date-range-inputs span{display:none}.date-input{min-height:44px;padding:.625rem .75rem}.comparison-summary{flex-direction:column;padding:.875rem}.summary-item{padding:.5rem 0}.patterns-list{gap:1rem}.pattern-card{padding:1rem}.pattern-card .pattern-stats .stat-item{min-height:32px}.seasonal-year-card,.range-card{padding:1rem}.search-modal-quick-btn{min-height:44px;padding:.625rem .875rem}.search-modal-input{min-height:44px;padding:.625rem .75rem}}@media(max-width:480px){.date-input{min-height:40px;font-size:.6875rem}.comparison-summary{padding:.75rem}.pattern-card,.seasonal-year-card,.range-card{padding:.875rem}.search-modal-quick-btn{min-height:40px;padding:.5625rem .75rem;font-size:.6875rem}}.inline-controls{display:flex;gap:.5rem;align-items:center;justify-content:center;flex-wrap:nowrap;width:auto;min-width:0}.header-search .inline-controls{justify-content:center;flex-wrap:nowrap}.control-button{padding:.5rem .875rem;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:9999px;font-size:.8125rem;font-weight:500;letter-spacing:-.005em;line-height:1.4;cursor:pointer;transition:background .15s ease,border-color .15s ease;font-family:inherit;white-space:nowrap;min-width:0;max-width:200px;overflow:hidden;text-overflow:ellipsis;text-align:center;position:relative;display:flex;align-items:center;justify-content:center;touch-action:manipulation;-webkit-tap-highlight-color:transparent;flex:0 0 auto;box-sizing:border-box}[data-theme=dark] .control-button{background:var(--bg-tertiary)}.control-button:hover{background:var(--bg-tertiary);border-color:var(--border-hover)}[data-theme=dark] .control-button:hover{background:var(--bg-secondary)}.control-button:active{transform:scale(.97);transition:transform .1s ease}@media(max-width:768px){.control-button:active{transform:scale(.95);opacity:.9}}.control-button.active:not(.dropdown-button){background:var(--highlight-cold-bg);color:var(--text-primary);border-color:var(--highlight-cold-border);box-shadow:0 0 0 1px var(--highlight-cold-border)}[data-theme=dark] .control-button.active:not(.dropdown-button){background:var(--highlight-cold-bg);border-color:var(--highlight-cold-border)}.control-button:focus{outline:none}.control-button:focus-visible{outline:2px solid var(--text-primary);outline-offset:2px}[data-theme=dark] .control-button:focus-visible{outline:2px solid var(--text-primary);outline-offset:2px}.control-button:not(.dropdown-button){width:44px;min-width:44px;max-width:44px;height:44px;padding:.5rem;justify-content:center}.dropdown-wrapper{position:relative;flex:0 0 auto}.dropdown-wrapper.dropdown-date{width:110px}.dropdown-wrapper.dropdown-location{width:130px}.dropdown-wrapper.dropdown-year{width:70px}.dropdown-button{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;width:100%;padding-right:1.75rem;position:relative;text-align:left}.dropdown-button>span{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.dropdown-button-icon{flex-shrink:0;position:absolute;right:.625rem;pointer-events:none;width:12px;height:12px;color:var(--text-secondary);opacity:.5}.dropdown{position:absolute;top:calc(100% + .25rem);left:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:.5rem;box-shadow:0 10px 38px -10px #00000040,0 10px 20px -15px #00000026;z-index:1000;min-width:200px;max-width:300px;max-height:300px;overflow:hidden;display:flex;flex-direction:column;animation:slideDown .2s ease;max-width:min(300px,calc(100vw - 2rem));-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}.dropdown.dropdown-portal{position:fixed;z-index:10000;animation:dropdownFadeIn .15s ease-out}[data-theme=dark] .dropdown{box-shadow:0 10px 38px -10px #00000080,0 10px 20px -15px #00000059;-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}.dropdown-search,.dropdown-list{background:transparent}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-search{padding:0;margin-bottom:.5rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.dropdown-input{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);border-radius:6px;font-size:.8125rem;font-family:inherit}.dropdown-input:focus{outline:none;border-color:var(--border-hover)}.dropdown-list{max-height:250px;overflow-y:auto;padding:0}.dropdown-item{width:100%;padding:.75rem 1rem;border:none;background:transparent;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:8px;font-size:var(--text-sm);font-family:inherit;transition:background .15s ease;-webkit-tap-highlight-color:transparent;outline:none}.dropdown-item:active{transform:scale(.98);transition:transform .1s ease}.dropdown-item:hover,.dropdown-item:focus{background:var(--bg-tertiary)}.dropdown-item.active{background:var(--bg-tertiary);color:var(--text-primary)}[data-theme=dark] .dropdown-item.active{background:var(--bg-tertiary)}.dropdown-item.disabled{color:var(--text-secondary);cursor:default;padding:.75rem;text-align:center}.dropdown-item.disabled:hover{background:transparent}.simple-date-input{width:100%}.date-buttons{display:flex;gap:.5rem;flex-wrap:nowrap;align-items:center}.date-button{padding:.625rem 1rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:9999px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.date-button:hover{background:var(--bg-tertiary);border-color:var(--border-hover);transform:translateY(-1px)}.date-button:active{transform:translateY(0)}.date-button.active{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.today-button{min-width:80px}.random-button{min-width:100px}.search-button{min-width:150px;justify-content:center}.search-icon{font-size:1rem}.date-picker-overlay{position:fixed!important;inset:0!important;width:100vw!important;height:100vh!important;background:#00000080!important;z-index:10000!important;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5);margin:0!important;padding:0!important;overflow:hidden;touch-action:none;cursor:pointer}.date-picker-modal{position:fixed!important;inset:50% auto auto 50%!important;transform:translate(-50%,-50%)!important;width:fit-content!important;height:fit-content!important;max-width:min(500px,calc(100vw - 2rem))!important;max-height:min(600px,calc(100dvh - 2rem - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px)))!important;background:var(--bg-primary)!important;border:none!important;border-radius:8px!important;box-shadow:0 4px 20px #00000026!important;z-index:10001!important;min-width:300px!important;overflow:hidden!important;display:flex!important;flex-direction:column!important;animation:slideUp .2s ease;padding:0!important;margin:0 auto!important;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5);touch-action:auto;cursor:default}[data-theme=dark] .date-picker-modal{-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.date-picker-modal:focus-within{outline:none}.date-picker-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem}.date-picker-header h3{margin:0;font-size:var(--text-xl);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.search-modal-header-content{display:flex;flex-direction:column;gap:.25rem}.search-modal-header-content h3{margin:0;font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.close-button{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:9999px;transition:all .2s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent;line-height:1}.close-button:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:scale(1.1)}.close-button:active{transform:scale(.95);transition:transform .1s ease}.date-picker-content{padding:1.25rem;overflow-y:auto;flex:1;min-height:0;touch-action:pan-y;-webkit-overflow-scrolling:touch}.date-picker-inputs{display:flex;gap:1rem;margin-bottom:1rem}.date-picker-group{flex:1;display:flex;flex-direction:column;gap:.5rem}.date-picker-group label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);letter-spacing:-.005em}.date-picker-select{padding:.625rem 2.25rem .625rem .875rem;border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-primary);border-radius:9999px;font-size:var(--text-lg);font-family:inherit;cursor:pointer;transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235a5247' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center;background-size:12px;width:100%;min-width:0;overflow:visible}.date-picker-select:hover{border-color:var(--border-hover);background-color:var(--bg-primary)}.date-picker-select:focus{outline:none;border-color:var(--accent-color);background-color:var(--bg-primary);box-shadow:0 0 0 3px #0000000a}[data-theme=dark] .date-picker-select:focus{box-shadow:0 0 0 3px #ffffff14}.date-picker-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.default-location-modal{max-width:min(500px,calc(100vw - 2rem))!important}.default-location-modal .date-picker-content{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;flex:1;min-height:0;display:flex;flex-direction:column}.default-location-modal .default-location-content{display:flex;flex-direction:column;gap:1.5rem;min-height:min-content}.default-location-content{display:flex;flex-direction:column;gap:1.5rem}.default-location-description{margin:0;font-size:var(--text-base);color:var(--text-secondary);line-height:1.5}.default-location-current{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.default-location-info{display:flex;flex-direction:column;gap:.25rem}.default-location-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.default-location-value{font-size:var(--text-lg);color:var(--text-primary);font-weight:600}.default-location-modal .date-picker-actions{justify-content:flex-end;gap:.75rem}.default-location-modal .date-picker-button:disabled{opacity:.5;cursor:not-allowed}.default-location-search{display:flex;flex-direction:column;gap:.75rem}.default-location-search label{display:flex;align-items:center;gap:.5rem;font-size:var(--text-base);font-weight:500;color:var(--text-primary)}.default-location-search .search-modal-location{display:flex;flex-direction:column;gap:.75rem}.date-picker-button{padding:.625rem 1.25rem;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:9999px;font-size:var(--text-lg);font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit;letter-spacing:-.005em;touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:44px}.date-picker-button.secondary{background:var(--bg-secondary);border-color:var(--border-color)}.date-picker-button.secondary:hover{background:var(--bg-tertiary);border-color:var(--border-hover);transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}[data-theme=dark] .date-picker-button.secondary:hover{box-shadow:0 2px 4px #0003}.date-picker-button.primary{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.date-picker-button.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:0 2px 6px #00000026}[data-theme=dark] .date-picker-button.primary:hover{box-shadow:0 2px 6px #0000004d}.date-picker-button:active{transform:translateY(0) scale(.98);transition:transform .1s ease}.search-modal{min-width:400px;max-width:500px;width:auto}@media(max-width:768px){.search-modal{top:50%!important;transform:translate(-50%,-50%)!important;max-height:calc(90dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px))!important;height:auto!important}.search-modal .date-picker-content{overflow-y:auto;max-height:none;flex:1;min-height:0}}@media(max-width:480px){.search-modal{top:50%!important;transform:translate(-50%,-50%)!important;max-height:calc(90dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px))!important;width:calc(100vw - 1rem)!important;max-width:calc(100vw - 1rem)!important}}.search-modal-section{margin-bottom:1.5rem}.search-modal-section:last-of-type{margin-bottom:0}.search-modal-section label{display:flex;align-items:center;gap:.375rem;font-size:var(--text-md);font-weight:500;color:var(--text-secondary);margin-bottom:.5rem;letter-spacing:-.005em}.search-modal-label-icon{font-size:var(--text-lg);line-height:1}.search-modal-date-presets{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.search-modal-inputs{display:flex;gap:.5rem}.search-modal-inputs .date-picker-select{flex:1;min-width:0}.search-modal-input{width:100%;padding:.625rem .75rem;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:9999px;font-size:var(--text-lg);font-family:inherit;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;font-size:max(var(--text-lg),16px)}.search-modal-input::placeholder{color:var(--text-tertiary)}.search-modal-input:hover{border-color:var(--border-hover)}.search-modal-input:focus{outline:none;border-color:var(--accent-color);background:var(--bg-primary);box-shadow:0 0 0 3px #0000000a}[data-theme=dark] .search-modal-input:focus{box-shadow:0 0 0 3px #ffffff14}.search-modal-location{display:flex;flex-direction:column;gap:.75rem}.search-modal-input-wrapper{position:relative;width:100%}.search-modal-input-wrapper .search-modal-input{padding-right:2.5rem}.search-modal-input-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:24px;height:24px;border:none;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:9999px;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s ease;padding:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.search-modal-input-clear:hover{background:var(--text-tertiary);color:var(--bg-primary)}.search-modal-input-clear:active{transform:translateY(-50%) scale(.9)}.search-modal-autocomplete{position:fixed;background:#ffffffbf;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:10002;max-height:200px;overflow-y:auto;isolation:isolate;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5);color:var(--text-primary)}[data-theme=dark] .search-modal-autocomplete{background:#1e1e20bf;box-shadow:0 4px 12px #0000004d;-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}.search-modal-autocomplete-item{width:100%;padding:.625rem .875rem;border:none;background:transparent;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:0;font-size:var(--text-md);font-family:inherit;transition:all .15s ease;-webkit-tap-highlight-color:transparent;display:block}.search-modal-autocomplete-item:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.search-modal-autocomplete-item:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.search-modal-autocomplete-item:hover,.search-modal-autocomplete-item.highlighted{background:var(--bg-tertiary);color:var(--text-primary)}.search-modal-autocomplete-item:active{background:var(--bg-secondary)}.search-modal-quick-locations,.search-modal-year-ranges{display:flex;flex-wrap:wrap;gap:.5rem}.search-modal-quick-btn{padding:.5rem .875rem;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:9999px;font-size:var(--text-base);font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit;letter-spacing:-.005em;touch-action:manipulation;-webkit-tap-highlight-color:transparent;white-space:nowrap;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}.search-modal-quick-btn:hover{background:var(--bg-secondary);border-color:var(--border-hover);transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}[data-theme=dark] .search-modal-quick-btn{-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}[data-theme=dark] .search-modal-quick-btn:hover{background:var(--bg-tertiary);box-shadow:0 2px 4px #0003}.search-modal-quick-btn:active{transform:translateY(0) scale(.98);transition:transform .1s ease}.search-modal-quick-btn.active{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--accent-color);border-width:2px;box-shadow:0 2px 8px #0000001a,0 0 0 .5px var(--accent-color);font-weight:600}[data-theme=dark] .search-modal-quick-btn.active{background:var(--bg-secondary);border-color:var(--accent-color);box-shadow:0 2px 8px #0000004d,0 0 0 .5px var(--accent-color)}.search-modal-quick-btn.active:hover{background:var(--bg-tertiary);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:0 3px 10px #0000001f,0 0 0 .5px var(--accent-hover)}[data-theme=dark] .search-modal-quick-btn.active:hover{background:var(--bg-tertiary);border-color:var(--accent-hover);box-shadow:0 3px 10px #00000059,0 0 0 .5px var(--accent-hover)}.search-modal-section{animation:searchSectionFadeIn .3s ease forwards;opacity:0}.search-modal-section-1{animation-delay:.05s}.search-modal-section-2{animation-delay:.1s}.search-modal-section-3{animation-delay:.15s}@keyframes searchSectionFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.search-modal-section{animation:none;opacity:1}}@media(max-width:768px){.date-picker-modal{inset:50% auto auto 50%;transform:translate(-50%,-50%);margin:0;width:calc(100vw - 2rem);max-width:calc(100vw - 2rem);max-height:calc(100dvh - 2rem)}.date-picker-modal.search-modal{top:50%!important;transform:translate(-50%,-50%)!important;max-height:calc(90dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px))!important}.date-picker-modal.default-location-modal{max-height:calc(90dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px))!important;height:auto!important}.date-picker-header{padding:.75rem 1rem}.date-picker-content{padding:.875rem 1rem}.search-modal{min-width:auto}.search-modal-inputs{flex-direction:row;gap:.5rem}.search-modal-date-presets{flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;gap:.375rem;margin-top:.5rem;padding:.25rem 0;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;mask-image:linear-gradient(to right,black 0,black calc(100% - 12px),transparent 100%);-webkit-mask-image:linear-gradient(to right,black 0,black calc(100% - 12px),transparent 100%)}.search-modal-date-presets::-webkit-scrollbar{display:none}.search-modal-date-presets.scrolled-left{mask-image:linear-gradient(to right,transparent 0,black 12px,black calc(100% - 12px),transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,black 12px,black calc(100% - 12px),transparent 100%)}.search-modal-date-presets.scrolled-end{mask-image:linear-gradient(to right,transparent 0,black 12px,black 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,black 12px,black 100%)}.search-modal-date-presets.scrolled-start{mask-image:none;-webkit-mask-image:none}.search-modal-quick-locations{flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;gap:.375rem;padding:.25rem 0;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;mask-image:linear-gradient(to right,black 0,black calc(100% - 12px),transparent 100%);-webkit-mask-image:linear-gradient(to right,black 0,black calc(100% - 12px),transparent 100%)}.search-modal-quick-locations::-webkit-scrollbar{display:none}.search-modal-quick-locations.scrolled-left{mask-image:linear-gradient(to right,transparent 0,black 12px,black calc(100% - 12px),transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,black 12px,black calc(100% - 12px),transparent 100%)}.search-modal-quick-locations.scrolled-end{mask-image:linear-gradient(to right,transparent 0,black 12px,black 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,black 12px,black 100%)}.search-modal-quick-locations.scrolled-start{mask-image:none;-webkit-mask-image:none}.search-modal-section{margin-bottom:.875rem}.search-modal-label{margin-bottom:.375rem}.search-modal-quick-btn{min-height:44px;padding:.625rem .875rem;flex-shrink:0}.search-modal-input{min-height:40px;padding:.5rem .75rem}.date-picker-select{min-height:40px;padding:.5rem 2.25rem .5rem .75rem}.search-modal-autocomplete{max-height:150px}.search-modal-autocomplete-item{padding:.625rem .75rem;font-size:var(--text-md)}.date-picker-actions{padding-top:.75rem;margin-top:.75rem}}@media(max-width:480px){.date-picker-modal{inset:50% auto auto 50%!important;transform:translate(-50%,-50%)!important;width:calc(100vw - 1rem);max-width:calc(100vw - 1rem);max-height:calc(100dvh - 1rem)}.date-picker-modal.search-modal{top:50%!important;transform:translate(-50%,-50%)!important;max-height:calc(90dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px))!important}.date-picker-header{padding:.625rem .75rem}.date-picker-content{padding:.75rem}.search-modal-section{margin-bottom:.75rem}.search-modal-label{margin-bottom:.25rem;font-size:var(--text-sm)}.search-modal-label-icon{font-size:var(--text-base)}.search-modal-quick-btn{min-height:44px;padding:.5rem .75rem;font-size:var(--text-sm)}.search-modal-date-presets,.search-modal-quick-locations{gap:.25rem;margin-top:.375rem}.search-modal-year-ranges{gap:.375rem}.search-modal-input{min-height:44px;padding:.5rem .75rem;font-size:var(--text-base)}.search-modal-input-wrapper .search-modal-input{padding-right:2rem}.search-modal-input-clear{width:18px;height:18px;font-size:.75rem;right:.5rem}.date-picker-select{min-height:44px;padding:.5rem 1.75rem .5rem .75rem;font-size:var(--text-base);background-position:right .5rem center;background-size:10px}.search-modal-autocomplete{max-height:120px}.search-modal-autocomplete-item{padding:.5rem .625rem;font-size:var(--text-base)}.date-picker-actions{padding-top:.625rem;margin-top:.625rem;gap:.5rem}.date-picker-button{min-height:44px;padding:.5rem 1rem;font-size:var(--text-base)}}.simple-location-input{width:100%}.location-buttons{display:flex;gap:.5rem;flex-wrap:nowrap;align-items:center}.location-button{padding:.625rem 1rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:9999px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit;white-space:nowrap}.location-button:hover{background:var(--bg-tertiary);border-color:var(--border-hover);transform:translateY(-1px)}.location-button:active{transform:translateY(0)}.location-button.active{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.location-search-inline{display:flex;gap:.25rem;align-items:center;margin-left:auto}.location-search-field-inline{padding:.625rem .75rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:9999px;font-size:.875rem;font-family:inherit;width:120px}.location-search-field-inline:focus{outline:none;border-color:var(--border-hover);width:180px;transition:width .2s ease}.location-search-button-inline{padding:.625rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:9999px;font-size:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;height:36px}.location-search-button-inline:hover{background:var(--bg-tertiary);border-color:var(--border-hover)}.location-search-button-inline:active{transform:scale(.95)}@media(max-width:768px){.inline-controls{flex-wrap:nowrap;justify-content:center;gap:.375rem}.control-button{font-size:.75rem;padding:.5rem .625rem;min-height:40px;height:40px}.control-button:not(.dropdown-button){width:40px;min-width:40px;max-width:40px;padding:.5rem;flex:0 0 auto}.dropdown-wrapper.dropdown-date{width:100px}.dropdown-wrapper.dropdown-location{width:110px}.dropdown-wrapper.dropdown-year{width:62px}.dropdown-button{min-height:40px;height:40px;padding:.5rem 1.5rem .5rem .625rem}.dropdown{min-width:200px;max-width:calc(100vw - 2rem);left:50%;transform:translate(-50%)}.dropdown-list{max-height:50vh}.dropdown-item{padding:.75rem 1rem;min-height:44px;font-size:.875rem}.date-picker-modal{min-width:300px;max-width:calc(100vw - 2rem)}.date-picker-inputs{flex-direction:column;gap:.75rem}.date-picker-button{min-height:44px;padding:.75rem 1.25rem}.date-picker-select{min-height:44px;padding:.75rem 2.25rem .75rem .875rem}}@media(max-width:480px){.inline-controls{gap:.25rem;flex-wrap:nowrap}.control-button{font-size:.6875rem;padding:.375rem .5rem;min-height:44px;height:44px}.control-button:not(.dropdown-button){width:44px;min-width:44px;max-width:44px;padding:.5rem}.dropdown-wrapper.dropdown-date{width:80px}.dropdown-wrapper.dropdown-location{width:90px}.dropdown-wrapper.dropdown-year{width:55px}.dropdown-button{min-height:44px;height:44px;padding:.5rem 1.25rem .5rem .625rem;font-size:.75rem}.dropdown-button-icon{right:.375rem;width:10px;height:10px}.dropdown{min-width:180px;max-width:calc(100vw - 1rem)}.dropdown-item{padding:.625rem .875rem;min-height:40px;font-size:.8125rem}.date-picker-modal{min-width:280px;max-width:calc(100vw - 1rem)}.date-picker-header,.date-picker-content{padding:.875rem}.date-picker-button{min-height:40px;padding:.625rem 1rem;font-size:.8125rem}}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:modalSlideIn .2s ease-out;max-height:calc(100vh - 2rem);overflow-y:auto;width:100%;max-width:600px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.extreme-weather-search{width:100%;max-width:600px;margin:0 auto}.extreme-weather-modal{background:var(--bg-primary);border-radius:16px;padding:1.5rem;box-shadow:0 20px 60px #0000004d;-webkit-backdrop-filter:blur(12px) saturate(1.5);backdrop-filter:blur(12px) saturate(1.5)}[data-theme=dark] .extreme-weather-modal{-webkit-backdrop-filter:blur(16px) saturate(1.3);backdrop-filter:blur(16px) saturate(1.3)}.extreme-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.extreme-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.extreme-close-btn{background:transparent;border:none;font-size:1.25rem;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s}.extreme-close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.extreme-subtitle{color:var(--text-secondary);font-size:.875rem;margin:0 0 1.25rem}.extreme-controls{display:flex;flex-direction:column;gap:1rem}.extreme-type-selector{display:flex;gap:.5rem;background:var(--bg-secondary);padding:.25rem;border-radius:12px}.extreme-type-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.75rem .5rem;border:none;background:transparent;border-radius:10px;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.extreme-type-btn:hover{background:var(--bg-tertiary)}.extreme-type-btn.active{background:var(--bg-primary);box-shadow:0 2px 8px #00000026;color:var(--text-primary)}.extreme-type-emoji{font-size:1.5rem}.extreme-type-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.02em}.extreme-date-controls{display:flex;gap:.5rem}.extreme-select{flex:1;padding:.75rem 2rem .75rem 1rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:10px;font-size:.9375rem;cursor:pointer;transition:all .2s;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:none!important}.extreme-select:hover{border-color:var(--border-hover)}.extreme-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-alpha)}.extreme-select-day{flex:0 0 70px}.extreme-search-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.25rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary, var(--accent-primary)));color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(var(--accent-primary-rgb, 59, 130, 246),.3)}.extreme-search-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px rgba(var(--accent-primary-rgb, 59, 130, 246),.4)}.extreme-search-btn:active:not(:disabled){transform:translateY(0)}.extreme-search-btn:disabled{opacity:.7;cursor:not-allowed}.extreme-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.extreme-error{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#ef4444;font-size:.875rem}.extreme-results{margin-top:1.5rem}.extreme-results-header{margin-bottom:1rem}.extreme-results-header h3{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.extreme-results-meta{margin:0;font-size:.75rem;color:var(--text-secondary)}.extreme-results-list{display:flex;flex-direction:column;gap:.5rem}.extreme-result-card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);transition:all .2s}.extreme-result-card:hover{border-color:var(--border-hover);transform:translate(2px)}.extreme-result-card.extreme-rank-gold{background:linear-gradient(135deg,#ffd7001a,#ffc1070d);border-color:#ffd70066}.extreme-result-card.extreme-rank-silver{background:linear-gradient(135deg,#c0c0c01a,#9ca3af0d);border-color:#c0c0c066}.extreme-result-card.extreme-rank-bronze{background:linear-gradient(135deg,#cd7f321a,#b453090d);border-color:#cd7f3266}.extreme-result-rank{font-size:1.25rem;min-width:2rem;text-align:center;font-weight:600;color:var(--text-secondary)}.extreme-result-info{flex:1;min-width:0}.extreme-result-location{font-weight:600;color:var(--text-primary);font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.extreme-result-region{font-size:.75rem;color:var(--text-secondary)}.extreme-result-value{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.extreme-value-main{font-size:1.25rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.extreme-value-condition{font-size:.6875rem;color:var(--text-secondary)}.extreme-result-temps{display:flex;align-items:center;gap:.25rem;font-size:.8125rem;font-variant-numeric:tabular-nums}.extreme-result-temps .temp-high{color:var(--temp-hot, #ef4444);font-weight:600}.extreme-result-temps .temp-separator{color:var(--text-secondary)}.extreme-result-temps .temp-low{color:var(--temp-cold, #3b82f6);font-weight:500}.extreme-disclaimer{margin:1rem 0 0;font-size:.6875rem;color:var(--text-secondary);font-style:italic;text-align:center}.extreme-no-results{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem;color:var(--text-secondary);text-align:center}.extreme-no-results span{font-size:2rem}.extreme-no-results p{margin:0;font-size:.9375rem}@media(max-width:480px){.extreme-weather-modal{padding:1.25rem}.extreme-header h2{font-size:1.125rem}.extreme-type-emoji{font-size:1.25rem}.extreme-type-label{font-size:.6875rem}.extreme-date-controls{flex-wrap:wrap}.extreme-select{padding:.625rem .875rem;font-size:.875rem}.extreme-search-btn{padding:.75rem 1rem;font-size:.9375rem}.extreme-result-card{padding:.75rem;gap:.5rem}.extreme-result-rank{font-size:1rem;min-width:1.75rem}.extreme-result-location{font-size:.875rem}.extreme-value-main{font-size:1.125rem}.extreme-result-temps{font-size:.75rem}}.search-modal-tabs{display:flex;gap:0;padding:0 1rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.search-modal-tab{flex:1;padding:.75rem 1rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.375rem}.search-modal-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.search-modal-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.extreme-type-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.extreme-type-option{flex:1;min-width:90px;display:flex;align-items:center;justify-content:center;gap:.375rem}.extreme-inline-error{margin-top:1rem;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:.8125rem}.extreme-inline-results{margin-top:1rem;padding:1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color)}.extreme-inline-results-header{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.25rem}.extreme-inline-results-header>span:first-child{font-size:1.25rem;line-height:1}.extreme-inline-results-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);line-height:1.3}.extreme-inline-results-meta{margin:0 0 .75rem;font-size:.6875rem;color:var(--text-secondary)}.extreme-inline-results-list{display:flex;flex-direction:column;gap:.375rem}.extreme-inline-result-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .625rem;background:var(--bg-primary);border-radius:8px;border:1px solid var(--border-color);transition:all .15s}.extreme-inline-result-row:hover{border-color:var(--border-hover)}.extreme-inline-result-row.rank-1{background:linear-gradient(135deg,#ffd7001a,#ffc1070d);border-color:#ffd70066}.extreme-inline-result-row.rank-2{background:linear-gradient(135deg,#c0c0c01a,#9ca3af0d);border-color:#c0c0c066}.extreme-inline-result-row.rank-3{background:linear-gradient(135deg,#cd7f321a,#b453090d);border-color:#cd7f3266}.extreme-inline-rank{font-size:.875rem;min-width:1.75rem;text-align:center;font-weight:600;color:var(--text-secondary)}.extreme-inline-location{flex:1;min-width:0;display:flex;flex-direction:column;gap:0}.extreme-inline-city{font-size:.8125rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.extreme-inline-region{font-size:.625rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.extreme-inline-value{font-size:1rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.extreme-inline-condition{font-size:.875rem}.extreme-inline-more{margin:.5rem 0 0;font-size:.6875rem;color:var(--text-secondary);text-align:center}.extreme-inline-no-results{margin-top:1rem;padding:1.5rem;text-align:center;color:var(--text-secondary);font-size:.875rem}@media(max-width:480px){.search-modal-tabs{padding:0 .75rem}.search-modal-tab{padding:.625rem .5rem;font-size:.8125rem}.extreme-type-buttons{gap:.375rem}.extreme-type-option{min-width:80px;font-size:.75rem}.extreme-inline-results{padding:.75rem}.extreme-inline-results-title{font-size:.8125rem}.extreme-inline-result-row{padding:.375rem .5rem}.extreme-inline-city{font-size:.75rem}.extreme-inline-value{font-size:.875rem}}.heart-particle{transform-origin:center;will-change:transform,opacity}@keyframes heartExplode{0%{transform:translate(-50%,-50%) scale(0) rotate(0);opacity:1}10%{transform:translate(-50%,-50%) scale(1.2) rotate(0);opacity:1}to{transform:translate(calc(-50% + var(--vx)),calc(-50% + var(--vy) + 100px)) scale(.4) rotate(720deg);opacity:0}}.app-footer{padding:1rem;text-align:center;font-size:.75rem;color:var(--text-secondary);margin-top:auto}.app-footer p{margin:0}.app-footer a{color:var(--text-secondary);text-decoration:underline;text-decoration-color:var(--text-tertiary);text-underline-offset:2px}.app-footer a:hover{color:var(--text-primary);text-decoration-color:var(--text-primary)}@media(max-width:768px){.app-footer{padding:.75rem;padding-bottom:calc(.75rem + 60px);font-size:.6875rem}}@media(display-mode:standalone){.app{padding-top:env(safe-area-inset-top,0)}.app-header{top:calc(env(safe-area-inset-top,0) + .5rem)}.mobile-bottom-bar{padding-bottom:max(env(safe-area-inset-bottom,0px) + .5rem,2rem)}.date-picker-overlay{top:calc(-1*env(safe-area-inset-top,0))!important;height:calc(100vh + env(safe-area-inset-top,0) + env(safe-area-inset-bottom,0))!important}.date-picker-modal{max-height:min(600px,calc(100dvh - 3rem - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px)))!important}.search-modal{top:50%!important;transform:translate(-50%,-50%)!important;max-height:calc(90dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px))!important}.app-footer{padding-bottom:calc(.75rem + 70px + env(safe-area-inset-bottom,0))}}@supports (-webkit-touch-callout: none){@media(display-mode:standalone){.date-picker-overlay,.date-picker-modal{overscroll-behavior:contain}input,select,textarea{font-size:16px!important}}}.christmas-chart{padding:1.5rem}.christmas-chart-title{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;text-align:center}.christmas-chart-stats{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}.christmas-stat{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:var(--text-sm)}.christmas-stat.highlight-cold{background:var(--highlight-cold-bg);border-color:var(--highlight-cold-border)}.christmas-stat-icon{font-size:var(--text-lg)}.christmas-stat-label{color:var(--text-secondary);font-size:var(--text-sm)}.christmas-stat-value{color:var(--text-primary);font-weight:600;font-size:var(--text-base)}.christmas-chart-bars{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem;max-width:100%}.christmas-bar{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;transition:all .2s ease}.christmas-bar.coldest{background:var(--highlight-cold-bg);border-color:var(--highlight-cold-border)}.christmas-bar-icon{font-size:var(--text-xl)}.christmas-bar-year{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.christmas-bar.coldest .christmas-bar-year{color:var(--text-primary);font-weight:600}.weather-chart-container .recharts-cartesian-axis-tick-value{font-variant-numeric:tabular-nums;white-space:nowrap}@media(max-width:480px){.weather-chart-container .recharts-cartesian-axis-tick-value{font-size:9px!important}.weather-chart-container .recharts-xAxis{overflow:visible}.weather-chart-container .recharts-wrapper{padding-bottom:.5rem}}@media(max-width:768px){.weather-chart-container .recharts-cartesian-axis-tick-value{font-size:10px!important}}
