:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes skeleton-shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.skeleton{background:linear-gradient(90deg,#0000000f,#0000001f,#0000000f);background-size:1000px 100%;animation:skeleton-shimmer 2s infinite linear;border-radius:var(--radius-sm)}.weather-content-skeleton{display:flex;flex-direction:column;gap:clamp(20px,4vw,40px);animation:fadeInContent .5s var(--ease-out)}.skeleton-current-weather{text-align:center;padding:var(--space-lg) var(--space-md);border-bottom:2px solid rgba(0,0,0,.05);margin-bottom:var(--space-lg)}.skeleton-title{height:40px;width:300px;max-width:80%;margin:0 auto var(--space-lg)}.skeleton-weather-main{display:flex;justify-content:center;align-items:center;gap:var(--space-xl);margin-bottom:var(--space-md)}.skeleton-icon{width:140px;height:140px;border-radius:var(--radius-md)}.skeleton-temperature{height:120px;width:200px;border-radius:var(--radius-md)}.skeleton-description{height:32px;width:200px;margin:0 auto var(--space-lg);border-radius:var(--radius-full)}.skeleton-weather-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-lg);max-width:600px;margin:0 auto;padding:var(--space-md);background:linear-gradient(135deg,#00000005,#0000000a);border-radius:var(--radius-md)}.skeleton-detail{display:flex;flex-direction:column;gap:var(--space-xs);align-items:center}.skeleton-detail-icon{width:32px;height:32px;border-radius:50%;margin-bottom:var(--space-xs)}.skeleton-detail-label{height:14px;width:80px}.skeleton-detail-value{height:24px;width:60px}.skeleton-hourly-forecast{padding:var(--space-md) 0;margin-bottom:var(--space-lg)}.skeleton-hourly-scroll{display:flex;gap:var(--space-sm);overflow-x:hidden;padding:var(--space-xs)}.skeleton-hourly-item{flex-shrink:0;width:110px;background:linear-gradient(135deg,#ffffffe6,#f9f9f9cc);padding:var(--space-md) var(--space-sm);border-radius:var(--radius-md);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.skeleton-hourly-item:first-child{background:var(--accent-gradient)}.skeleton-hourly-item:first-child .skeleton{background:linear-gradient(90deg,#ffffff4d,#ffffff80,#ffffff4d);background-size:1000px 100%}.skeleton-hourly-time{height:16px;width:50px}.skeleton-hourly-icon{width:50px;height:50px;border-radius:var(--radius-sm)}.skeleton-hourly-temp{height:28px;width:45px}.skeleton-daily-forecast,.skeleton-weekly-forecast{padding:var(--space-md) 0;margin-bottom:var(--space-lg)}.skeleton-section-title{height:36px;width:200px;margin-bottom:var(--space-lg);position:relative}.skeleton-periods{display:grid;gap:var(--space-md)}.skeleton-period{background:linear-gradient(135deg,var(--card-bg-secondary) 0%,rgba(255,255,255,.5) 100%);padding:var(--space-md);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.skeleton-period:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent-gradient)}.skeleton-period-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.skeleton-period-name{height:24px;width:120px}.skeleton-period-icon{width:70px;height:70px;border-radius:var(--radius-sm)}.skeleton-period-temp{height:32px;width:80px;margin-bottom:var(--space-sm)}.skeleton-period-description{height:60px;margin-bottom:var(--space-sm)}.skeleton-period-wind{height:16px;width:140px}.skeleton-forecast-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:var(--space-md)}.skeleton-forecast-card{background:var(--accent-gradient);padding:var(--space-md);border-radius:var(--radius-md);box-shadow:var(--shadow-md);position:relative;overflow:hidden;min-height:200px}.skeleton-forecast-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#ffffff4d,#ffffff1a);pointer-events:none}.skeleton-forecast-card .skeleton{background:linear-gradient(90deg,#ffffff4d,#ffffff80,#ffffff4d);background-size:1000px 100%;animation:skeleton-shimmer 2s infinite linear;position:relative;z-index:1}.skeleton-day-name{height:20px;width:80%;margin:0 auto var(--space-sm)}.skeleton-weather-icon{width:70px;height:70px;margin:var(--space-sm) auto;border-radius:var(--radius-sm)}.skeleton-temp{height:32px;width:60%;margin:var(--space-sm) auto}.skeleton-conditions{height:16px;width:80%;margin:var(--space-sm) auto 0}@media(max-width:768px){.skeleton-weather-main{flex-direction:column;gap:var(--space-md)}.skeleton-temperature{width:150px;height:80px}.skeleton-weather-details{grid-template-columns:1fr}.skeleton-forecast-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}}@media(min-width:640px){.skeleton-forecast-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.skeleton-forecast-grid{grid-template-columns:repeat(7,1fr)}.skeleton-periods{grid-template-columns:repeat(2,1fr)}}@media(prefers-reduced-motion:reduce){.skeleton{animation:skeleton-pulse 2s infinite ease-in-out}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-gradient-start: #5B47FB;--bg-gradient-end: #A855F7;--bg-gradient-angle: 135deg;--card-bg: rgba(255, 255, 255, .95);--card-bg-secondary: rgba(249, 249, 249, .9);--card-border: rgba(255, 255, 255, .2);--text-primary: #2c3e50;--text-secondary: #546e7a;--text-muted: #78909c;--text-on-accent: #ffffff;--accent-primary: #5B47FB;--accent-secondary: #A855F7;--accent-gradient: linear-gradient(135deg, #5B47FB 0%, #A855F7 100%);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .12);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .2);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 25px;--radius-full: 9999px;--space-xs: 8px;--space-sm: 12px;--space-md: 20px;--space-lg: 30px;--space-xl: 40px;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--text-7xl: 4.5rem;--text-hero: 6rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--leading-tight: 1.2;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .35s;--ease-out: cubic-bezier(.33, 1, .68, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--ease-spring: cubic-bezier(.68, -.55, .265, 1.55);--glass-blur: 20px;--glass-opacity: .9;--focus-ring-color: var(--accent-primary);--focus-ring-width: 3px;--focus-ring-offset: 2px}*:focus{outline:none}*:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}button:focus-visible,.location-pill:focus-visible,.quick-access-toggle:focus-visible,.suggestion-chip:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-ring-width) var(--focus-ring-color)}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:0}[data-weather-theme=snowy] *:focus-visible,[data-weather-theme=foggy] *:focus-visible{--focus-ring-color: #1E40AF}[data-weather-theme=snowy] button:focus-visible,[data-weather-theme=snowy] .location-pill:focus-visible,[data-weather-theme=foggy] button:focus-visible,[data-weather-theme=foggy] .location-pill:focus-visible{box-shadow:0 0 0 var(--focus-ring-width) #1e40af}[data-weather-theme=night] *:focus-visible,[data-weather-theme=stormy] *:focus-visible{--focus-ring-color: #C084FC}[data-weather-theme=night] button:focus-visible,[data-weather-theme=night] .location-pill:focus-visible,[data-weather-theme=stormy] button:focus-visible,[data-weather-theme=stormy] .location-pill:focus-visible{box-shadow:0 0 0 var(--focus-ring-width) #c084fc}[data-weather-theme=sunny]{--bg-gradient-start: #FFB800;--bg-gradient-end: #FF6B00;--bg-gradient-angle: 120deg;--accent-primary: #FF3D00;--accent-secondary: #FF9100;--accent-gradient: linear-gradient(120deg, #FF3D00 0%, #FF9100 100%);--shadow-lg: 0 10px 40px rgba(255, 61, 0, .3)}[data-weather-theme=cloudy]{--bg-gradient-start: #94A3B8;--bg-gradient-end: #475569;--bg-gradient-angle: 135deg;--accent-primary: #3B82F6;--accent-secondary: #1E40AF;--accent-gradient: linear-gradient(135deg, #3B82F6 0%, #1E40AF 100%);--shadow-lg: 0 10px 40px rgba(59, 130, 246, .25)}[data-weather-theme=rainy]{--bg-gradient-start: #0EA5E9;--bg-gradient-end: #0C4A6E;--bg-gradient-angle: 135deg;--accent-primary: #0066FF;--accent-secondary: #1E40AF;--accent-gradient: linear-gradient(135deg, #0066FF 0%, #1E40AF 100%);--shadow-lg: 0 12px 48px rgba(0, 102, 255, .35)}[data-weather-theme=stormy]{--bg-gradient-start: #1E1B4B;--bg-gradient-end: #312E81;--bg-gradient-angle: 135deg;--accent-primary: #A855F7;--accent-secondary: #7C3AED;--accent-gradient: linear-gradient(135deg, #A855F7 0%, #7C3AED 100%);--shadow-lg: 0 15px 50px rgba(168, 85, 247, .4);--shadow-xl: 0 25px 70px rgba(124, 58, 237, .5)}[data-weather-theme=snowy]{--bg-gradient-start: #F0F9FF;--bg-gradient-end: #BAE6FD;--bg-gradient-angle: 135deg;--accent-primary: #06B6D4;--accent-secondary: #0891B2;--accent-gradient: linear-gradient(135deg, #06B6D4 0%, #0891B2 100%);--shadow-lg: 0 10px 40px rgba(6, 182, 212, .35)}[data-weather-theme=foggy]{--bg-gradient-start: #CBD5E1;--bg-gradient-end: #64748B;--bg-gradient-angle: 135deg;--accent-primary: #6366F1;--accent-secondary: #4F46E5;--accent-gradient: linear-gradient(135deg, #6366F1 0%, #4F46E5 100%);--shadow-lg: 0 10px 40px rgba(99, 102, 241, .2)}[data-weather-theme=night]{--bg-gradient-start: #0C1445;--bg-gradient-end: #1E3A8A;--bg-gradient-angle: 135deg;--accent-primary: #8B5CF6;--accent-secondary: #C084FC;--accent-gradient: linear-gradient(135deg, #8B5CF6 0%, #C084FC 100%);--shadow-lg: 0 12px 45px rgba(139, 92, 246, .4)}[data-theme=dark]{--card-bg: rgba(30, 30, 40, .95);--card-bg-secondary: rgba(40, 40, 55, .9);--card-border: rgba(255, 255, 255, .1);--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .6);--focus-ring-color: #A855F7}[data-theme=dark] .search-input-wrapper{background:#1e1e2efa;border:1px solid rgba(255,255,255,.15)}[data-theme=dark] .search-input-wrapper:focus-within{background:#232337;border-color:#a855f780;box-shadow:0 4px 20px #0000004d,0 0 0 var(--focus-ring-width) var(--focus-ring-color)}[data-theme=dark] .location-search input{color:#fff}[data-theme=dark] .location-search input::placeholder{color:#fff9}[data-theme=dark] .country-button{border-right-color:#ffffff26}[data-theme=dark] .country-button:hover{background:#ffffff0d}[data-theme=dark] .country-caret{color:#ffffff80}[data-theme=dark] .country-dropdown{background:#1e1e2efa;border:1px solid rgba(255,255,255,.15)}[data-theme=dark] .country-option:hover{background:#ffffff0d}[data-theme=dark] .country-option.selected{background:#a855f733}[data-theme=dark] .country-option .country-name{color:#fff}[data-theme=dark] .location-pill{background:#1e1e2efa;color:#fff;border-color:#ffffff26}[data-theme=dark] .location-pill:hover{background:#28283c;border-color:#a855f766}[data-theme=dark] .pill-location{color:#fff}[data-theme=dark] .pill-icon{color:#fff9}[data-theme=dark] .weather-trends{background:linear-gradient(135deg,#1e1e2e99,#28283c99);border-color:#ffffff1a}[data-theme=dark] .trend-item{background:#1e1e2ef2;color:#fff;box-shadow:0 2px 4px #0003}[data-theme=dark] .trend-item:hover{background:#28283c;box-shadow:0 4px 8px #0000004d}[data-theme=dark] .location-search button{background:#a855f7e6;color:#fff;border-color:#a855f7e6}[data-theme=dark] .location-search button:hover:not(:disabled){background:#a855f7}[data-theme=dark] .location-search button:disabled{background:#64647880;border-color:#64647880}[data-theme=dark] .autocomplete-dropdown{background:#1e1e2efa;border:1px solid rgba(255,255,255,.15);box-shadow:0 8px 32px #0006}[data-theme=dark] .autocomplete-item{color:#fff}[data-theme=dark] .autocomplete-item .city-details{color:#fff9}[data-theme=dark] .autocomplete-item:hover,[data-theme=dark] .autocomplete-item.selected{background:#a855f733}[data-theme=dark] .search-hint{color:#ffffffb3}[data-theme=dark] .current-weather,[data-theme=dark] .forecast-section,[data-theme=dark] .daily-forecast,[data-theme=dark] .weekly-forecast,[data-theme=dark] .hourly-forecast{background:var(--card-bg)}[data-theme=dark] .quick-access-dropdown{background:#1e1e2e;border:1px solid rgba(255,255,255,.1)}[data-theme=dark] .no-alerts-banner{background:#22c55e1a;border-color:#22c55e33;color:#86efac}.dark-mode-toggle{display:flex;align-items:center;gap:var(--space-xs);padding:8px 12px;background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-full);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);transition:all var(--duration-fast) var(--ease-out)}[data-theme=dark] .dark-mode-toggle{background:#323241e6;border-color:#ffffff1a;color:var(--text-primary)}.dark-mode-toggle:hover{transform:scale(1.05)}.dark-mode-toggle .toggle-icon{font-size:1rem;line-height:1}.dark-mode-toggle .toggle-label{min-width:36px}.language-selector{display:flex;align-items:center;gap:var(--space-xs)}.language-label{display:none}.language-select{padding:8px 28px 8px 12px;background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-full);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);transition:all var(--duration-fast) var(--ease-out);appearance:none;-webkit-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='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}[data-theme=dark] .language-select{background-color:#323241e6;border-color:#ffffff1a;color:var(--text-primary);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='%23ccc' d='M6 8L1 3h10z'/%3E%3C/svg%3E")}.language-select:hover{transform:scale(1.05)}.language-select:focus{outline:none;box-shadow:0 0 0 var(--focus-ring-width) #5b47fb4d}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background:linear-gradient(var(--bg-gradient-angle),var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);min-height:100vh;overflow-x:hidden;max-width:100vw}#root{width:100%;max-width:100%}.app{max-width:1200px;width:100%;margin:0 auto;padding:var(--space-md);overflow-x:hidden}.app-header{text-align:center;color:#fff;margin-bottom:var(--space-lg);padding:var(--space-md) 0;position:relative;overflow:visible}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);width:100%}.header-left{display:flex;align-items:center;gap:var(--space-md)}.app-logo{width:48px;height:48px;border-radius:12px;box-shadow:var(--shadow-md);transition:transform var(--duration-normal) var(--ease-out);flex-shrink:0}.app-logo:hover{transform:scale(1.05) rotate(2deg);box-shadow:var(--shadow-lg)}.app-subtitle{font-size:.9rem;font-weight:500;color:#ffffffd9;letter-spacing:.03em;margin:0}.header-right-controls{display:flex;align-items:center;gap:var(--space-sm)}.location-search{position:relative;max-width:600px;flex:1}.location-search.collapsed{flex:0 0 auto;max-width:none}.location-pill{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(91,71,251,.15);border-radius:var(--radius-full);padding:12px 20px;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;gap:var(--space-xs);transition:all var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-sm);white-space:nowrap;max-width:280px;overflow:hidden;text-overflow:ellipsis}.location-pill:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#5b47fb4d;background:#fff}.location-pill:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.location-pill:disabled{opacity:.6;cursor:not-allowed}.pill-location{color:#1a1a2e;font-weight:var(--font-bold)}.pill-icon{color:#00000080;font-size:.9em;transition:transform var(--duration-fast)}.location-pill:hover:not(:disabled) .pill-icon{transform:translateY(2px)}.location-search.expanded form,.location-search form{display:flex;gap:var(--space-sm);justify-content:center;align-items:flex-start}.search-input-wrapper{flex:1;position:relative;display:flex;align-items:center;background:#fffffff2;border-radius:var(--radius-full);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--duration-normal) var(--ease-out)}.search-input-wrapper:focus-within{background:#fff;box-shadow:0 4px 20px #ffffff4d,0 0 0 var(--focus-ring-width) var(--focus-ring-color);transform:scale(1.02)}.country-selector{position:relative;flex-shrink:0}.country-button{display:flex;align-items:center;gap:4px;padding:12px 8px 12px 16px;background:transparent;border:none;border-right:1px solid rgba(0,0,0,.1);cursor:pointer;font-size:var(--text-xl);transition:background var(--duration-fast) var(--ease-out);border-radius:var(--radius-full) 0 0 var(--radius-full)}.country-button:hover{background:#0000000d}.country-flag{font-size:1.25em;line-height:1}.country-caret{font-size:.6em;color:#00000080}.country-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:10000;min-width:70px;max-height:200px;overflow-y:auto;animation:slideDown var(--duration-fast) var(--ease-out)}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.country-option{display:flex;align-items:center;gap:6px;width:100%;padding:6px 12px;background:transparent;border:none;cursor:pointer;font-size:var(--text-sm);text-align:left;transition:background var(--duration-fast) var(--ease-out)}.country-option:hover{background:#0000000d}.country-option.selected{background:#a855f71a;font-weight:var(--font-medium)}.country-option .country-flag{font-size:1em}.country-option .country-name{color:var(--text-primary)}.location-search input{padding:18px 24px 18px 12px;font-size:var(--text-lg);border:none;border-radius:0 var(--radius-full) var(--radius-full) 0;width:100%;background:transparent;transition:all var(--duration-normal) var(--ease-out);font-weight:var(--font-medium);color:var(--text-primary);min-height:52px}.location-search input::placeholder{color:#0006}.location-search input:focus-visible{outline:none}.search-hint{position:absolute;top:100%;left:var(--space-md);margin-top:var(--space-xs);font-size:var(--text-xs);color:#fffc;font-weight:var(--font-medium)}.autocomplete-dropdown{position:absolute;top:calc(100% + var(--space-xs));left:0;right:80px;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-xl);max-height:300px;overflow-y:auto;z-index:1000;animation:fadeInContent .2s var(--ease-out);min-width:200px}.autocomplete-item{padding:var(--space-md) var(--space-md);cursor:pointer;transition:background var(--duration-fast) var(--ease-out);border-bottom:1px solid rgba(0,0,0,.05);min-height:48px;display:flex;flex-direction:column;justify-content:center}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover,.autocomplete-item.selected{background:#5b47fb14}.autocomplete-item .city-name{display:block;font-weight:var(--font-semibold);color:var(--text-primary);font-size:var(--text-base)}.autocomplete-item .city-details{display:block;font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.location-search button{padding:16px 32px;font-size:var(--text-lg);background:#fff;color:var(--accent-primary);border:2px solid white;border-radius:var(--radius-full);cursor:pointer;font-weight:var(--font-bold);transition:all var(--duration-normal) var(--ease-out);box-shadow:0 4px 16px #0003;min-height:48px;min-width:100px}.location-search .random-button{padding:16px 24px;font-size:var(--text-2xl);min-width:60px;background:linear-gradient(135deg,gold,orange);color:#fff;border-color:gold;position:relative;overflow:hidden}.location-search .random-button:hover:not(:disabled){transform:translateY(-2px) scale(1.08) rotate(5deg);box-shadow:0 8px 24px #ffa50066}.location-search .random-button:active:not(:disabled){transform:translateY(0) scale(1.02) rotate(-5deg)}.location-search button:hover:not(:disabled){transform:translateY(-2px) scale(1.05);box-shadow:0 8px 24px #0000004d;background:#fffffff2}.location-search button:disabled{opacity:.6;cursor:not-allowed;background:#ffffffb3}.recent-searches{position:absolute;top:100%;left:var(--space-md);margin-top:var(--space-xs);display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap;animation:fadeInContent .3s var(--ease-out)}.recent-label{font-size:var(--text-xs);color:#ffffffe6;font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em}.recent-chip{background:#fffffff2;color:var(--accent-primary);border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-full);padding:4px 12px;font-size:var(--text-xs);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);box-shadow:0 2px 6px #0000001a;white-space:nowrap}.recent-chip:hover:not(:disabled){background:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #00000026;border-color:var(--accent-primary)}.recent-chip:active:not(:disabled){transform:translateY(0)}.recent-chip:disabled{opacity:.5;cursor:not-allowed}.random-fact{margin-top:var(--space-md);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,#ffd700f2,#ffa500f2);color:#1a1a1a;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);box-shadow:var(--shadow-lg);animation:slideInFromTop .4s var(--ease-out);border:2px solid rgba(255,215,0,.5);text-align:center;line-height:var(--leading-relaxed)}.random-fact strong{color:#8b4513;font-weight:var(--font-bold)}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.app-main{background:var(--card-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-radius:var(--radius-lg);border:1px solid var(--card-border);padding:clamp(20px,5vw,40px);box-shadow:var(--shadow-xl);min-height:500px;position:relative;overflow:hidden;transition:min-height .3s var(--ease-out)}.app-main:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent)}.loading-message,.error,.welcome{text-align:center;padding:var(--space-xl) var(--space-md);animation:fadeInContent .4s var(--ease-out)}.loading-message{padding:var(--space-md) var(--space-md) var(--space-lg)}.loading-placeholder{text-align:center;padding:var(--space-md);color:var(--text-muted);font-size:var(--text-sm);font-style:italic}@keyframes fadeInContent{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.spinner{width:60px;height:60px;border:6px solid rgba(0,0,0,.08);border-top:6px solid transparent;border-radius:50%;animation:spin .8s cubic-bezier(.68,-.55,.265,1.55) infinite,fadeInSpinner .3s var(--ease-out) forwards;margin:0 auto var(--space-md);position:relative;opacity:0}.spinner:before{content:"";position:absolute;inset:-6px;border-radius:50%;border:6px solid transparent;border-top-color:var(--accent-primary);animation:spin 1s cubic-bezier(.68,-.55,.265,1.55) infinite reverse}@keyframes fadeInSpinner{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.loading-message p{font-size:var(--text-xl);color:var(--accent-primary);font-weight:var(--font-semibold);margin-top:var(--space-md);font-style:italic;animation:fadeInScale .5s var(--ease-spring);min-height:2em;display:flex;align-items:center;justify-content:center}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.error{background:linear-gradient(135deg,#e74c3c26,#e74c3c14);border-radius:var(--radius-md);padding:var(--space-xl);border-left:4px solid #e74c3c}.error p{font-size:var(--text-xl);margin-bottom:var(--space-md);color:#dc2626;font-weight:var(--font-semibold)}.retry-button{padding:16px 32px;font-size:var(--text-lg);background:var(--accent-gradient);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;font-weight:var(--font-bold);transition:all var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-md);min-height:48px}.retry-button:hover{transform:translateY(-2px) scale(1.02);box-shadow:var(--shadow-lg)}.error-actions{display:flex;gap:var(--space-md);flex-wrap:wrap;justify-content:center}.random-retry{background:linear-gradient(135deg,#9b59b6,#8e44ad)}.welcome{color:var(--text-primary);font-size:var(--text-2xl);font-weight:var(--font-semibold);display:flex;flex-direction:column;gap:var(--space-sm);align-items:center}.welcome-subtitle{font-size:var(--text-lg);font-weight:var(--font-normal);color:var(--text-secondary)}.location-options{margin-top:var(--space-md);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.use-location-button{background:var(--accent-gradient);color:#fff;border:none;padding:16px var(--space-xl);border-radius:var(--radius-full);font-size:var(--text-lg);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-lg);min-height:48px}.use-location-button:hover{transform:translateY(-2px) scale(1.05);box-shadow:var(--shadow-xl);filter:brightness(1.1)}.use-location-button:active{transform:translateY(0) scale(.98);box-shadow:var(--shadow-md)}.random-welcome-btn{background:#fffffff2;color:var(--accent-primary);border:2px solid rgba(91,71,251,.3);box-shadow:var(--shadow-md)}.random-welcome-btn:hover{background:#fff;border-color:var(--accent-primary);box-shadow:var(--shadow-lg)}.welcome-suggestions{margin-top:var(--space-xl);text-align:center}.suggestions-title{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-md);font-weight:var(--font-semibold)}.suggestion-chips{display:flex;gap:var(--space-sm);justify-content:center;flex-wrap:wrap}.suggestion-chip{background:#ffffffe6;color:var(--accent-primary);border:2px solid rgba(91,71,251,.2);border-radius:var(--radius-full);padding:12px 24px;min-height:44px;font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);box-shadow:0 2px 8px #0000001a}.suggestion-chip:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 4px 16px #5b47fb4d;border-color:var(--accent-primary);background:#fff}.suggestion-chip:active{transform:translateY(0) scale(.98);box-shadow:0 2px 8px #0000001a}.location-error{font-size:var(--text-sm);color:#c0392b;padding:var(--space-xs) var(--space-md);background:#e74c3c1a;border-radius:var(--radius-sm);border:1px solid rgba(231,76,60,.4);font-weight:var(--font-medium)}.weather-content{display:flex;flex-direction:column;gap:clamp(20px,4vw,40px);animation:fadeInContent .5s var(--ease-out)}.no-alerts-banner{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);color:#166534;font-size:var(--text-sm);font-weight:var(--font-medium)}.no-alerts-banner span:first-child{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#22c55e33;border-radius:50%;font-size:var(--text-xs)}.current-weather{text-align:center;padding:var(--space-lg) var(--space-md);border-bottom:2px solid rgba(0,0,0,.05);margin-bottom:var(--space-lg)}.current-weather .location{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.current-weather .location-actions{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.current-weather .location h2{font-size:clamp(1.5rem,4vw,2.5rem);color:var(--text-primary);margin-bottom:0;font-weight:var(--font-bold);letter-spacing:-.01em}.share-button{background:var(--accent-gradient);color:#fff;border:none;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #3b82f64d;min-height:44px;min-width:100px}.share-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.share-button:active{transform:translateY(0)}.data-freshness{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);background:#4ade8026;border:1px solid rgba(74,222,128,.3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);transition:all var(--duration-fast) var(--ease-out)}.data-freshness.stale{background:#fbbf2426;border-color:#fbbf2466}.freshness-icon{font-size:var(--text-base)}.freshness-text{font-size:var(--text-sm);white-space:nowrap}.refresh-button{background:none;border:none;font-size:var(--text-xl);color:var(--accent-primary);cursor:pointer;padding:8px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--duration-fast) var(--ease-out);line-height:1}.refresh-button:hover{background:#5b47fb1a;transform:rotate(180deg) scale(1.1)}.refresh-button:active{transform:rotate(360deg) scale(.95);background:#5b47fb33}.refresh-button-standalone{background:#ffffffe6;border:1px solid rgba(91,71,251,.2);font-size:var(--text-xl);color:var(--accent-primary);cursor:pointer;padding:8px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--duration-fast) var(--ease-out);line-height:1;box-shadow:var(--shadow-sm)}.refresh-button-standalone:hover{background:#5b47fb1a;transform:rotate(180deg) scale(1.1);box-shadow:var(--shadow-md)}.refresh-button-standalone:active{transform:rotate(360deg) scale(.95);background:#5b47fb33}.current-weather .weather-main{display:flex;justify-content:center;align-items:center;gap:var(--space-xl);margin-bottom:var(--space-md)}.current-weather .icon{position:relative}.current-weather .icon img{width:140px;height:140px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15));animation:iconFloat 3s ease-in-out infinite}@keyframes iconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.current-weather .temperature{font-size:clamp(4rem,12vw,7rem);font-weight:var(--font-extrabold);background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:var(--leading-tight);letter-spacing:-.04em;font-variant-numeric:tabular-nums}.current-weather .temp-unit{font-size:clamp(2rem,4vw,3rem);opacity:.8}.current-weather .description{font-size:var(--text-2xl);color:var(--text-secondary);margin-bottom:var(--space-md);text-transform:capitalize;font-weight:var(--font-medium);display:inline-block;padding:var(--space-xs) var(--space-md);background:#00000008;border-radius:var(--radius-full)}.weather-trends{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap;margin-bottom:var(--space-lg);padding:var(--space-sm);background:linear-gradient(135deg,#5b47fb0d,#a855f70d);border-radius:var(--radius-md);border:1px solid rgba(91,71,251,.1)}.trend-item{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);padding:4px 12px;background:#fffc;border-radius:var(--radius-full);box-shadow:0 2px 4px #0000000d;transition:all var(--duration-fast) var(--ease-out)}.trend-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.current-weather .weather-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-lg);max-width:600px;margin:0 auto;padding:var(--space-md);background:linear-gradient(135deg,#00000005,#0000000a);border-radius:var(--radius-md)}.current-weather .detail{display:flex;flex-direction:column;gap:var(--space-xs);align-items:center}.current-weather .detail-icon{font-size:2rem;margin-bottom:var(--space-xs);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.current-weather .label{font-weight:var(--font-semibold);color:var(--text-muted);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em}.current-weather .value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary)}.weather-insight{margin-top:var(--space-lg);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,#5b47fb14,#3a86ff14);border-left:4px solid var(--accent-primary);border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--space-sm);max-width:600px;margin-left:auto;margin-right:auto}.insight-icon{font-size:1.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));flex-shrink:0}.insight-text{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary);line-height:1.5}.daily-forecast,.weekly-forecast,.radar-viewer{padding:var(--space-md) 0;margin-bottom:var(--space-lg)}.daily-forecast h3,.weekly-forecast h3,.radar-viewer h3{font-size:var(--text-3xl);color:var(--text-primary);margin-bottom:var(--space-lg);font-weight:var(--font-bold);position:relative;padding-bottom:var(--space-sm)}.daily-forecast h3:after,.weekly-forecast h3:after,.radar-viewer h3:after{content:"";position:absolute;bottom:0;left:0;width:80px;height:4px;background:var(--accent-gradient);border-radius:var(--radius-full)}.daily-forecast .periods{display:grid;gap:var(--space-md)}.daily-forecast .period{background:linear-gradient(135deg,var(--card-bg-secondary) 0%,rgba(255,255,255,.5) 100%);padding:var(--space-md);border-radius:var(--radius-md);transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.daily-forecast .period:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent-gradient);transition:width var(--duration-normal) var(--ease-out)}.daily-forecast .period:hover{transform:translate(4px);box-shadow:var(--shadow-md)}.daily-forecast .period:hover:before{width:8px}.daily-forecast .period-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.daily-forecast .period-header h4{font-size:var(--text-xl);background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:var(--font-bold)}.daily-forecast .period-header img{width:70px;height:70px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.1))}.daily-forecast .period-temp-range{display:flex;gap:var(--space-lg);margin-bottom:var(--space-md);align-items:center}.daily-forecast .temp-high,.daily-forecast .temp-low{display:flex;flex-direction:column;gap:var(--space-xs)}.daily-forecast .temp-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.daily-forecast .temp-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);font-variant-numeric:tabular-nums}.daily-forecast .temp-high .temp-value{color:#ef4444}.daily-forecast .temp-low .temp-value{color:#3b82f6}.daily-forecast .period-description{color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-sm);font-size:var(--text-base)}.daily-forecast .period-description.night-forecast{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid rgba(0,0,0,.1);font-size:var(--text-sm)}.daily-forecast .period-wind{color:var(--text-muted);font-size:var(--text-sm);font-weight:var(--font-medium);display:flex;align-items:center;gap:var(--space-xs)}.forecast-chart-section{margin-bottom:var(--space-lg);padding:var(--space-md);background:linear-gradient(135deg,#5b47fb0d,#a855f70d);border-radius:var(--radius-md);border:1px solid rgba(91,71,251,.1)}.forecast-chart-section h4{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-md)}.temperature-chart{position:relative;width:100%;margin:0 auto}.temp-chart-svg{width:100%;height:auto;display:block}.temp-chart-labels{display:flex;justify-content:space-between;margin-top:var(--space-xs);padding:0 var(--space-sm)}.temperature-comparison{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);padding:var(--space-md);margin:var(--space-md) 0}.temp-period{background:linear-gradient(135deg,#5b47fb14,#5b47fb05);border:2px solid rgba(91,71,251,.1);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;transition:all var(--duration-fast) var(--ease-out)}.temp-period:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#5b47fb4d}.temp-period-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em}.temp-period-value{font-size:clamp(2rem,4vw,3rem);font-weight:var(--font-bold);background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.temp-min,.temp-max{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--accent-primary)}.temp-min:before{content:"↓ ";opacity:.6}.temp-max:before{content:"↑ ";opacity:.6}.hourly-forecast{padding:var(--space-md) 0;margin-bottom:var(--space-lg);max-width:100%;overflow:hidden}.hourly-forecast h3{font-size:var(--text-3xl);color:var(--text-primary);margin-bottom:var(--space-lg);font-weight:var(--font-bold);position:relative;padding-bottom:var(--space-sm)}.hourly-forecast h3:after{content:"";position:absolute;bottom:0;left:0;width:80px;height:4px;background:var(--accent-gradient);border-radius:var(--radius-full)}.hourly-scroll-container{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--accent-primary) rgba(0,0,0,.1);padding-bottom:var(--space-sm)}.hourly-scroll-container::-webkit-scrollbar{height:8px}.hourly-scroll-container::-webkit-scrollbar-track{background:#0000000d;border-radius:var(--radius-full)}.hourly-scroll-container::-webkit-scrollbar-thumb{background:var(--accent-gradient);border-radius:var(--radius-full)}.hourly-periods{display:flex;gap:var(--space-sm);padding:var(--space-xs)}.hourly-period{flex-shrink:0;width:110px;background:linear-gradient(135deg,#ffffffe6,#f9f9f9cc);padding:var(--space-md) var(--space-sm);border-radius:var(--radius-md);text-align:center;transition:all var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.05)}.hourly-period:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);background:linear-gradient(135deg,#fff,#f9f9f9e6)}.hourly-period:first-child{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-md)}.hourly-period:first-child .hourly-time,.hourly-period:first-child .hourly-temp,.hourly-period:first-child .hourly-condition,.hourly-period:first-child .hourly-wind{color:#fff}.hourly-time{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}.hourly-icon{width:50px;height:50px;margin:var(--space-xs) auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.hourly-temp{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--text-primary);margin:var(--space-xs) 0;font-variant-numeric:tabular-nums}.hourly-condition{font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-xs);line-height:var(--leading-tight);min-height:2.5em;display:flex;align-items:center;justify-content:center}.hourly-wind{font-size:var(--text-xs);color:var(--text-muted);font-weight:var(--font-medium)}[data-theme=dark] .hourly-period{background:linear-gradient(135deg,#1e1e2dfa,#191928f2)!important;border-color:#ffffff26;box-shadow:0 2px 8px #0000004d}[data-theme=dark] .hourly-period:hover{background:linear-gradient(135deg,#28283cfa,#232337f2)!important}[data-theme=dark] .hourly-period:first-child{background:var(--accent-gradient)!important}[data-theme=dark] .hourly-time{color:#f1f5f9!important}[data-theme=dark] .hourly-temp{color:#fff!important}[data-theme=dark] .hourly-condition{color:#cbd5e1!important}[data-theme=dark] .hourly-wind{color:#94a3b8!important}[data-theme=dark] .hourly-precip{color:#7dd3fc!important}.weekly-forecast .forecast-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:var(--space-md)}.weekly-forecast .forecast-card{background:var(--accent-gradient);color:var(--text-on-accent);padding:var(--space-md);border-radius:var(--radius-md);text-align:center;transition:all var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-md);position:relative;overflow:hidden;cursor:pointer}.weekly-forecast .forecast-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#fff3,#ffffff0d);pointer-events:none}.weekly-forecast .forecast-card:hover{transform:translateY(-6px) scale(1.03);box-shadow:var(--shadow-xl)}.weekly-forecast .day-name{font-weight:var(--font-bold);font-size:var(--text-lg);margin-bottom:var(--space-sm);position:relative;z-index:1}.weekly-forecast .weather-icon{width:70px;height:70px;margin:var(--space-sm) auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));position:relative;z-index:1;background:#fff3;border-radius:var(--radius-sm);padding:var(--space-xs)}.weekly-forecast .temp-range{display:flex;justify-content:center;gap:var(--space-md);margin:var(--space-sm) 0;position:relative;z-index:1}.weekly-forecast .temp-high,.weekly-forecast .temp-low{display:flex;flex-direction:column;align-items:center}.weekly-forecast .temp-high .temp-value{font-size:var(--text-2xl);font-weight:var(--font-extrabold);font-variant-numeric:tabular-nums;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.weekly-forecast .temp-low .temp-value{font-size:var(--text-xl);font-weight:var(--font-bold);font-variant-numeric:tabular-nums;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.weekly-forecast .temp-label{font-size:var(--text-xs);font-weight:var(--font-medium);opacity:.7;margin-bottom:2px}.weekly-forecast .conditions{font-size:var(--text-sm);opacity:.95;position:relative;z-index:1;font-weight:var(--font-medium)}.radar-viewer{padding:var(--space-md) 0;margin-bottom:var(--space-lg);width:100%;max-width:100%;overflow:hidden}.radar-viewer h3{font-size:var(--text-3xl);color:var(--text-primary);margin-bottom:var(--space-lg);font-weight:var(--font-bold);position:relative;padding-bottom:var(--space-sm)}.radar-viewer h3:after{content:"";position:absolute;bottom:0;left:0;width:80px;height:4px;background:var(--accent-gradient);border-radius:var(--radius-full)}.radar-viewer .radar-image{text-align:center;background:linear-gradient(135deg,var(--card-bg-secondary),rgba(255,255,255,.5));padding:var(--space-md);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;width:100%;max-width:100%;min-height:70vh;display:flex;align-items:center;justify-content:center}.radar-viewer .radar-image img{width:100%;max-width:100%;min-height:65vh;height:auto;border-radius:var(--radius-sm);box-shadow:0 4px 12px #00000026;border:2px solid rgba(0,0,0,.05);display:block;object-fit:contain}@media(max-width:768px){.radar-viewer .radar-image{min-height:50vh}.radar-viewer .radar-image img{min-height:45vh}}.app-footer{text-align:center;color:#fff;margin-top:var(--space-lg);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.mythology-text{font-size:var(--text-base);font-weight:var(--font-medium);opacity:.95;font-style:italic;animation:fadeIn .6s var(--ease-out);transition:opacity .4s var(--ease-out)}.api-credit{font-size:var(--text-xs);opacity:.6;font-weight:var(--font-normal)}.keyboard-shortcuts-hint{font-size:var(--text-xs);opacity:.7;display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap;justify-content:center;margin-top:var(--space-xs)}.shortcut-key{background:#fff3;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-weight:var(--font-semibold);font-size:var(--text-xs);border:1px solid rgba(255,255,255,.3)}.keyboard-shortcuts-hint .separator{opacity:.5}.attribution{font-size:var(--text-xs);opacity:.6;margin-top:var(--space-sm)}.attribution a{color:inherit;text-decoration:underline;text-underline-offset:2px;transition:opacity var(--duration-fast) var(--ease-out)}.attribution a:hover{opacity:1}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:.95;transform:translateY(0)}}.temperature-toggle{background:#ffffffe6;border:2px solid rgba(255,255,255,.3);border-radius:var(--radius-full);padding:8px 14px;display:flex;align-items:center;gap:6px;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);font-weight:var(--font-bold);font-size:var(--text-sm);box-shadow:0 2px 8px #0000001a;min-height:44px}.temperature-toggle:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026;background:#fff;border-color:#ffffff80}.temperature-toggle .unit{color:var(--text-muted);transition:all var(--duration-fast) var(--ease-out);font-size:var(--text-sm);padding:2px 4px;border-radius:4px}.temperature-toggle .unit.active{color:var(--accent-primary);background:#5b47fb1a;font-weight:var(--font-extrabold)}.temperature-toggle .separator{color:#0003;font-weight:var(--font-normal)}.quick-access-container{display:inline-flex;align-items:center;gap:var(--space-sm);position:relative}.favorite-star-button{background:#fffffff2;border:2px solid rgba(255,215,0,.5);border-radius:50%;width:48px;height:48px;font-size:1.5rem;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;color:gold}.favorite-star-button:hover:not(:disabled){transform:scale(1.1) rotate(15deg);box-shadow:var(--shadow-md);border-color:gold}.favorite-star-button.is-favorited{background:linear-gradient(135deg,gold,orange);color:#fff;border-color:gold;box-shadow:0 4px 12px #ffd70066}.favorite-star-button:disabled{cursor:not-allowed;opacity:1}.quick-access-toggle{background:#ffffffd9;border:1px solid rgba(255,255,255,.9);border-radius:var(--radius-full);padding:10px 18px;font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);box-shadow:0 1px 3px #0000001a;color:var(--accent-primary);min-height:44px}.quick-access-toggle:hover{transform:translateY(-1px);background:#fffffff2;box-shadow:0 2px 6px #00000026}.favorites-max-message{position:absolute;top:100%;left:0;margin-top:var(--space-xs);background:#ff4500f2;color:#fff;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--font-medium);white-space:nowrap;box-shadow:var(--shadow-md);animation:fadeInContent .3s var(--ease-out);z-index:100}.quick-access-dropdown{position:absolute;top:calc(100% + var(--space-sm));right:0;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-xl);min-width:320px;max-width:400px;max-height:600px;overflow:hidden;z-index:1000;animation:fadeInContent .2s var(--ease-out)}.quick-access-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);border-bottom:2px solid rgba(0,0,0,.05);background:var(--accent-gradient);color:#fff}.quick-access-header h4{margin:0;font-size:var(--text-lg);font-weight:var(--font-bold)}.quick-access-close{background:none;border:none;font-size:2rem;color:#fff;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--duration-fast);line-height:1}.quick-access-close:hover{background:#fff3;transform:scale(1.1)}.quick-access-empty{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.quick-access-empty .empty-icon{font-size:2.5rem;display:block;margin-bottom:var(--space-sm);opacity:.6}.quick-access-empty .empty-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-xs)}.quick-access-empty .empty-description{font-size:var(--text-sm);color:var(--text-muted);line-height:var(--leading-relaxed);max-width:250px;margin:0 auto}.quick-access-empty-hint{padding:var(--space-sm) var(--space-md);color:var(--text-muted);font-size:var(--text-sm);font-style:italic}.quick-access-content{max-height:520px;overflow-y:auto}.quick-access-section{border-bottom:1px solid rgba(0,0,0,.08)}.quick-access-section:last-child{border-bottom:none}.quick-access-section-header{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-md) var(--space-sm) var(--space-md);background:#5b47fb08;border-bottom:1px solid rgba(0,0,0,.05)}.section-icon{font-size:1.2rem;line-height:1}.section-title{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.quick-access-item{display:flex;align-items:center;border-bottom:1px solid rgba(0,0,0,.05);transition:background var(--duration-fast)}.quick-access-item:hover{background:#5b47fb0d}.quick-access-item:last-child{border-bottom:none}.personal-station-item{background:linear-gradient(135deg,#5b47fb0d,#3a86ff0d)}.quick-access-item-button{flex:1;background:none;border:none;padding:var(--space-md);text-align:left;cursor:pointer;font-family:inherit}.item-name{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-xs);flex-wrap:wrap}.item-icon{font-size:1rem;line-height:1}.item-subtitle{font-size:var(--text-sm);font-weight:var(--font-normal);color:var(--text-muted);margin-left:var(--space-xs)}.item-meta{font-size:var(--text-sm);color:var(--text-muted);font-family:Courier New,monospace}.item-action-button{background:none;border:none;font-size:1.2rem;color:var(--text-muted);cursor:pointer;padding:var(--space-sm);margin-right:var(--space-xs);width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--duration-fast);line-height:1}.item-action-button:hover{background:#5b47fb1a;color:var(--accent-primary);transform:scale(1.1)}.item-action-button.remove{font-size:1.8rem;padding:var(--space-sm);margin-right:var(--space-sm);width:44px;height:44px}.item-action-button.remove:hover{background:#e74c3c1a;color:#c0392b}.favorite-edit-form{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm);flex:1}.nickname-input{flex:1;padding:var(--space-xs) var(--space-sm);border:2px solid rgba(91,71,251,.3);border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:inherit;transition:border-color var(--duration-fast)}.nickname-input:focus-visible{border-color:var(--accent-primary);outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:1px}.nickname-save,.nickname-cancel{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--duration-fast);line-height:1}.nickname-save{color:#10b981}.nickname-save:hover{background:#10b9811a;transform:scale(1.1)}.nickname-cancel{color:var(--text-muted)}.nickname-cancel:hover{background:#0000001a;color:var(--text-primary);transform:scale(1.1)}.favorite-subtitle{display:block;font-size:var(--text-xs);color:var(--text-muted);font-weight:var(--font-normal);margin-top:2px}.weather-alerts{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}.alert-card{border-radius:var(--radius-md);padding:var(--space-md);border-left:6px solid;background:#fff;box-shadow:var(--shadow-md);animation:slideInAlert .4s var(--ease-out);transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}@keyframes slideInAlert{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.alert-card:hover{box-shadow:var(--shadow-lg);transform:translate(4px)}.alert-extreme{border-left-color:#8b0000;background:linear-gradient(to right,#8b000026,#8b00000d,#fff);box-shadow:0 4px 16px #8b000033}.alert-severe{border-left-color:#ff4500;background:linear-gradient(to right,#ff45001f,#ff45000a,#fff);box-shadow:0 4px 16px #ff450026}.alert-moderate{border-left-color:orange;background:linear-gradient(to right,#ffa5001f,#ffa5000a,#fff);box-shadow:0 4px 16px #ffa5001f}.alert-minor{border-left-color:gold;background:linear-gradient(to right,#ffd7001f,#ffd7000a,#fff);box-shadow:0 4px 16px #ffd7001a}.alert-unknown{border-left-color:gray;background:linear-gradient(to right,#8080801a,#fff)}.alert-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm)}.alert-title{display:flex;align-items:center;gap:var(--space-sm);flex:1}.alert-title h3{margin:0;font-size:var(--text-xl);color:var(--text-primary);font-weight:var(--font-bold)}.alert-severity-badge{display:inline-block;padding:6px 12px;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 4px #00000026}.alert-extreme .alert-severity-badge{background:linear-gradient(135deg,#8b0000,#a00000);color:#fff}.alert-severe .alert-severity-badge{background:linear-gradient(135deg,#ff4500,#ff6b35);color:#fff}.alert-moderate .alert-severity-badge{background:linear-gradient(135deg,orange,#ffb733);color:#fff}.alert-minor .alert-severity-badge{background:linear-gradient(135deg,gold,#ffe033);color:#333}.alert-dismiss{background:none;border:none;font-size:1.8rem;color:var(--text-muted);cursor:pointer;padding:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--duration-fast)}.alert-dismiss:hover{background:#0000001a;color:var(--text-primary);transform:scale(1.1)}.alert-headline{font-size:var(--text-lg);margin-bottom:var(--space-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.alert-details{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-sm);font-size:var(--text-sm);color:var(--text-secondary)}.alert-details strong{color:var(--text-primary);font-weight:var(--font-semibold)}.alert-instruction{background:#0000000d;padding:var(--space-sm);border-radius:var(--radius-sm);margin-bottom:var(--space-sm);font-size:var(--text-base)}.alert-instruction strong{display:block;margin-bottom:var(--space-xs);color:var(--text-primary);font-weight:var(--font-semibold)}.alert-description-toggle{margin-top:var(--space-sm);cursor:pointer}.alert-description-toggle summary{color:var(--accent-primary);font-weight:var(--font-semibold);list-style:none;-webkit-user-select:none;user-select:none;padding:var(--space-xs) 0;transition:color var(--duration-fast)}.alert-description-toggle summary:hover{color:var(--accent-secondary);text-decoration:underline}.alert-description-toggle summary::-webkit-details-marker{display:none}.alert-description-toggle summary:before{content:"▶ ";display:inline-block;transition:transform var(--duration-fast)}.alert-description-toggle[open] summary:before{transform:rotate(90deg)}.alert-description{margin-top:var(--space-sm);padding:var(--space-sm);background:#00000005;border-radius:var(--radius-sm);font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text-secondary);white-space:pre-wrap}.mobile-menu-container{display:none;position:relative}.mobile-menu-toggle{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mobile-menu-toggle:hover{background:var(--glass-bg-hover);transform:scale(1.05)}.hamburger-icon{display:flex;flex-direction:column;justify-content:center;align-items:center;width:28px;height:20px;position:relative}.hamburger-icon span{display:block;width:100%;height:2px;background:#fff;border-radius:1px;transition:all .3s var(--ease-out);position:absolute}.hamburger-icon span:nth-child(1){top:0}.hamburger-icon span:nth-child(2){top:50%;transform:translateY(-50%)}.hamburger-icon span:nth-child(3){bottom:0}.hamburger-icon.open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}.hamburger-icon.open span:nth-child(2){opacity:0;transform:translate(-10px)}.hamburger-icon.open span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}.mobile-menu-dropdown{position:absolute;top:calc(100% + var(--space-sm));right:0;min-width:280px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--space-md);z-index:1000;animation:fadeInContent .2s var(--ease-out)}.mobile-menu-section{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-sm) 0;border-bottom:1px solid var(--card-border)}.mobile-menu-section:last-child{border-bottom:none;padding-bottom:0}.mobile-menu-section:first-child{padding-top:0}.mobile-menu-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.mobile-menu-favorites{padding-top:var(--space-md)}.mobile-menu-favorites .quick-access-container{position:static}.mobile-menu-favorites .quick-access-button{width:100%;justify-content:center}@media(max-width:768px){.app{padding:var(--space-sm)}.app-header{margin-bottom:var(--space-md)}.desktop-only{display:none!important}.mobile-menu-container{display:block}.header-top{flex-direction:row;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);gap:var(--space-sm);overflow:visible}.header-left{flex:1;flex-direction:row;align-items:center;gap:var(--space-sm);min-width:0}.header-left .app-logo{width:40px;height:40px;flex-shrink:0}.header-left .location-search{flex:1;min-width:0}.quick-access-container{position:relative;top:auto;right:auto}.quick-access-dropdown{right:0;left:auto;transform:none;max-width:calc(100vw - var(--space-md) * 2);width:320px}.current-weather{padding:var(--space-md)}.current-weather .temperature{font-size:4.5rem}.current-weather .weather-main{flex-direction:column;gap:var(--space-md)}.current-weather .weather-details{grid-template-columns:1fr 1fr;gap:var(--space-md);padding:var(--space-md)}.weekly-forecast .forecast-grid{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:var(--space-xs)}.weekly-forecast .forecast-card{padding:var(--space-md) var(--space-sm)}.alert-card{padding:var(--space-md)}.alert-title{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.alert-details{font-size:var(--text-sm)}.location-search form{flex-direction:column;width:100%;gap:var(--space-md)}.location-search input,.location-search button{width:100%}.autocomplete-dropdown{right:0}.daily-forecast .period{padding:var(--space-md)}.weather-content{gap:var(--space-lg)}.location-search button{padding:18px 32px;font-size:var(--text-xl)}.use-location-button{padding:18px var(--space-xl);font-size:var(--text-xl)}}@media(min-width:640px)and (max-width:1023px){.app .desktop-only{display:flex!important}.app .mobile-menu-container{display:none!important}.app .header-top{flex-direction:row;justify-content:space-between;align-items:center}.app .header-left{flex-direction:row;align-items:center;width:auto}.app .header-right-controls{width:auto;justify-content:flex-end}.app .quick-access-container{position:relative}.current-weather .weather-details{grid-template-columns:repeat(3,1fr);gap:var(--space-sm);font-size:var(--text-sm)}.current-weather .detail{padding:var(--space-sm)}.current-weather .detail .label{font-size:var(--text-xs)}.weekly-forecast .forecast-grid{grid-template-columns:repeat(3,1fr)}.location-search form{flex-direction:row;width:auto}.location-search input,.location-search button{width:auto}.location-search input{flex:1;min-width:200px}}@media(min-width:1024px){.app{padding:var(--space-lg)}.weekly-forecast .forecast-grid{grid-template-columns:repeat(7,1fr)}.daily-forecast .periods{grid-template-columns:repeat(2,1fr)}}@media(min-width:1280px){.app{max-width:1600px}.app-main{padding:var(--space-xl)}}@media(min-width:1440px){.app{max-width:1800px}.app-main{max-width:1400px;margin-left:auto;margin-right:auto}}.side-nav{position:fixed;left:var(--space-lg);top:50%;transform:translateY(-50%);z-index:100;transition:opacity var(--duration-normal) var(--ease-out)}.side-nav-container{display:flex;flex-direction:column;gap:var(--space-xs);background:var(--card-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border-radius:var(--radius-lg);padding:var(--space-sm);box-shadow:var(--shadow-lg);border:1px solid var(--card-border)}.side-nav-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);color:var(--text-secondary);text-decoration:none;white-space:nowrap;font-size:var(--text-sm);font-weight:var(--font-medium);position:relative;overflow:hidden}.side-nav-item:hover{background:#5b47fb1a;color:var(--accent-primary);transform:translate(2px)}.side-nav-item.active{background:var(--accent-gradient);color:var(--text-on-accent);box-shadow:var(--shadow-md)}.side-nav-item.active .side-nav-icon{transform:scale(1.1)}.side-nav-icon{font-size:var(--text-xl);display:flex;align-items:center;justify-content:center;transition:transform var(--duration-normal) var(--ease-spring);min-width:24px}.side-nav-label{font-size:var(--text-sm);font-weight:var(--font-medium);transition:opacity var(--duration-normal) var(--ease-out)}@media(min-width:769px){.app-main{margin-left:220px}}@media(max-width:768px){.side-nav{display:none}}@media(min-width:769px)and (max-width:1024px){.side-nav{left:var(--space-sm)}.side-nav-label{display:none}.side-nav-item{padding:var(--space-sm);justify-content:center}.app-main{margin-left:100px}}@media(max-width:370px){.app{padding:var(--space-xs)}.app-header{margin-bottom:var(--space-sm)}.current-weather .temperature{font-size:3.5rem}.current-weather .unit{font-size:1.5rem}.weekly-forecast .forecast-grid{grid-template-columns:repeat(auto-fit,minmax(75px,1fr));gap:4px}.weekly-forecast .forecast-card{padding:var(--space-sm) var(--space-xs)}.weekly-forecast .day-name{font-size:var(--text-xs)}.weekly-forecast .temp-high .temp-value,.weekly-forecast .temp-low .temp-value{font-size:var(--text-base)}.hourly-period{width:85px;min-width:85px;padding:var(--space-sm)}.location-search button{padding:14px 24px;font-size:var(--text-lg)}.quick-access-dropdown{max-width:calc(100vw - var(--space-sm) * 2);width:280px}.autocomplete-dropdown{max-height:200px}}@media(hover:none)and (pointer:coarse){.hourly-period:hover{transform:none;box-shadow:var(--shadow-sm)}.weekly-forecast .forecast-card:hover,.daily-forecast .period:hover{transform:none}.autocomplete-item:hover{background:transparent}.autocomplete-item:active{background:#5b47fb14}.refresh-button:hover{transform:none;background:none}.refresh-button:active{transform:scale(.95);background:#5b47fb33}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.pull-to-refresh-indicator{position:fixed;top:0;left:50%;transform:translate(-50%);z-index:1000;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;pointer-events:none}.pull-to-refresh-spinner{width:40px;height:40px;background:var(--card-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:transform .1s ease-out}.pull-to-refresh-spinner .refreshing-icon{font-size:20px;animation:spin .8s linear infinite}.pull-to-refresh-spinner .pull-icon{font-size:18px;color:var(--accent-primary)}.pull-text{font-size:var(--text-sm);color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3);font-weight:var(--font-medium)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(hover:hover)and (pointer:fine){.pull-to-refresh-indicator{display:none}}.precip-high{background:linear-gradient(135deg,#0ea5e926,#3b82f633);color:#0284c7;padding:4px 8px;border-radius:var(--radius-sm);font-weight:var(--font-semibold);border:1px solid rgba(14,165,233,.3)}.hourly-precip.precip-high,.precip.precip-high{background:linear-gradient(135deg,#0ea5e933,#3b82f640);color:#0369a1;padding:3px 6px;border-radius:var(--radius-sm);font-weight:var(--font-bold);border:1px solid rgba(14,165,233,.4);animation:precipPulse 2s ease-in-out infinite}@keyframes precipPulse{0%,to{opacity:1}50%{opacity:.8}}[data-theme=dark] .precip-high,[data-theme=dark] .hourly-precip.precip-high,[data-theme=dark] .precip.precip-high{background:linear-gradient(135deg,#38bdf840,#6366f14d);color:#7dd3fc;border-color:#38bdf880}.weather-source{text-align:center;font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-md);opacity:.6}[data-theme=dark] .weather-source{color:var(--text-muted);opacity:.5}.what-to-wear-container{margin-top:var(--space-md)}.weather-advisor{display:flex;align-items:flex-start;gap:var(--space-sm)}.advisor-identity{display:flex;flex-direction:column;align-items:flex-start;gap:6px;flex-shrink:0}.advisor-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--accent-primary);box-shadow:var(--shadow-sm)}.advisor-bubble{flex:1;position:relative;background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-sm) var(--space-md)}.advisor-bubble:before{content:"";position:absolute;left:-8px;top:14px;width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-right:8px solid var(--card-bg);filter:drop-shadow(-2px 0 1px rgba(0,0,0,.05))}.advisor-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.advisor-speech{flex:1;min-width:200px}.advisor-name{display:flex;flex-direction:column;align-items:flex-start;gap:0;text-align:left}.advisor-intro{font-size:9px;font-weight:var(--font-medium);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;line-height:1.2}.advisor-name-text{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--accent-primary);letter-spacing:.3px;line-height:1.2}.advisor-advice{margin:0;font-size:var(--text-sm);color:var(--text-primary);line-height:1.4}.advisor-insight{margin:6px 0 0;font-size:var(--text-xs);color:var(--text-secondary);line-height:1.4;padding-top:6px;border-top:1px solid rgba(0,0,0,.06)}.what-to-wear{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}@media(max-width:540px){.advisor-header{flex-direction:column;align-items:flex-start}.advisor-avatar{width:60px;height:60px}.advisor-bubble:before{top:10px}.advisor-speech{min-width:0}.advisor-advice{font-size:var(--text-xs)}.what-to-wear{justify-content:flex-start;margin-top:var(--space-sm)}}.wear-item{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--card-bg);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--text-primary);box-shadow:var(--shadow-sm);transition:transform var(--duration-fast) var(--ease-out)}.wear-item:hover{transform:scale(1.05)}.wear-item .wear-emoji{font-size:1.2em}.wear-item .wear-label{font-weight:var(--font-medium)}.wear-item.recommended{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;font-weight:var(--font-semibold)}.wear-item.optional{opacity:.7;border:1px dashed var(--text-muted)}[data-theme=dark] .advisor-intro{color:#94a3b8}[data-theme=dark] .advisor-name-text{color:#60a5fa}[data-theme=dark] .advisor-bubble{background:#282837f2}[data-theme=dark] .advisor-advice{color:#f1f5f9}[data-theme=dark] .advisor-insight{color:#94a3b8;border-top-color:#ffffff1a}[data-theme=dark] .wear-item{background:#323246e6;color:#f1f5f9}[data-theme=dark] .wear-item.optional{border-color:#64748b}@media(max-width:480px){.what-to-wear{gap:6px;padding:var(--space-xs) var(--space-sm)}.wear-item{padding:6px 10px;font-size:var(--text-xs)}}.toast-container{position:fixed;bottom:var(--space-lg);right:var(--space-lg);z-index:9999;display:flex;flex-direction:column-reverse;gap:var(--space-sm);pointer-events:none}.toast{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);pointer-events:auto;animation:toastSlideIn .3s var(--ease-out);min-width:280px;max-width:400px}.toast-exit{animation:toastSlideOut .3s var(--ease-out) forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@media(prefers-reduced-motion:reduce){.toast{animation:fadeIn .01ms}.toast-exit{animation:fadeOut .01ms forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}}.toast-success{border-left:4px solid #22c55e}.toast-error{border-left:4px solid #ef4444}.toast-info{border-left:4px solid var(--accent-primary)}.toast-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--font-bold);flex-shrink:0}.toast-success .toast-icon{background:#22c55e26;color:#22c55e}.toast-error .toast-icon{background:#ef444426;color:#ef4444}.toast-info .toast-icon{background:#5b47fb26;color:var(--accent-primary)}.toast-message{flex:1;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.toast-dismiss{background:none;border:none;font-size:var(--text-lg);color:var(--text-muted);cursor:pointer;padding:4px;line-height:1;transition:color var(--duration-fast)}.toast-dismiss:hover{color:var(--text-primary)}@media(max-width:480px){.toast-container{left:var(--space-sm);right:var(--space-sm);bottom:var(--space-md)}.toast{min-width:auto;max-width:none}}.offline-indicator{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:var(--space-xs) var(--space-md);text-align:center;font-size:var(--text-sm);font-weight:var(--font-semibold);z-index:10000;display:flex;align-items:center;justify-content:center;gap:var(--space-xs);animation:slideDown .3s var(--ease-out)}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.app:has(.offline-indicator) .app-header{top:36px}.app:has(.offline-indicator) .side-nav{top:136px}.swipe-indicator{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;color:#fff;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);font-size:var(--text-lg);font-weight:var(--font-semibold);pointer-events:none;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media(hover:hover)and (pointer:fine){.swipe-indicator{display:none}}.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-md)}.admin-login-card{background:var(--card-bg);padding:var(--space-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:400px;text-align:center}.admin-login-card h1{margin-bottom:var(--space-lg);color:var(--text-primary)}.admin-login-card form{display:flex;flex-direction:column;gap:var(--space-md)}.admin-login-card input{padding:var(--space-md);border:2px solid rgba(0,0,0,.1);border-radius:var(--radius-md);font-size:var(--text-base);background:var(--card-bg-secondary);color:var(--text-primary)}.admin-login-card button{padding:var(--space-md);background:var(--accent-gradient);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;transition:transform var(--duration-fast),opacity var(--duration-fast)}.admin-login-card button:hover:not(:disabled){transform:translateY(-2px)}.admin-login-card button:disabled{opacity:.6;cursor:not-allowed}.admin-error{color:#dc2626;margin-top:var(--space-md);font-size:var(--text-sm)}.admin-back{display:inline-block;margin-top:var(--space-lg);color:var(--text-muted);text-decoration:none;font-size:var(--text-sm)}.admin-back:hover{color:var(--accent-primary)}.admin-dashboard{min-height:100vh;padding:var(--space-lg);max-width:1200px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.admin-header h1{color:#fff;margin:0}.admin-actions{display:flex;gap:var(--space-sm)}.admin-actions button{padding:var(--space-sm) var(--space-md);background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-md);cursor:pointer;font-weight:var(--font-medium);transition:background var(--duration-fast)}.admin-actions button:hover:not(:disabled){background:#ffffff4d}.admin-actions button.logout{background:#dc262633;border-color:#dc26264d}.admin-actions button.logout:hover{background:#dc262666}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-md)}.admin-card{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md)}.admin-card.wide{grid-column:1 / -1}.admin-card.summary{text-align:center}.admin-card h3{color:var(--text-secondary);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-md)}.admin-card .big-number{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--accent-primary);margin:0}.daily-chart{display:flex;justify-content:space-between;align-items:flex-end;height:150px;gap:var(--space-sm)}.day-bar{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.day-bar .bar{flex:1;width:100%;background:var(--accent-gradient);border-radius:var(--radius-sm) var(--radius-sm) 0 0;display:flex;align-items:flex-start;justify-content:center;padding-top:var(--space-xs);min-height:5%}.day-bar .count{font-size:var(--text-xs);color:#fff;font-weight:var(--font-semibold)}.day-bar .date{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-xs)}.stats-list{list-style:none;padding:0;margin:0}.stats-list li{display:flex;justify-content:space-between;padding:var(--space-sm) 0;border-bottom:1px solid rgba(0,0,0,.05)}.stats-list li:last-child{border-bottom:none}.stats-list .label{color:var(--text-primary);font-weight:var(--font-medium)}.stats-list .value{color:var(--accent-primary);font-weight:var(--font-semibold)}.stats-list.searches{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-xs)}.stats-list.searches li{padding:var(--space-xs) var(--space-sm);background:#00000005;border-radius:var(--radius-sm);border-bottom:none}.no-data{color:var(--text-muted);font-style:italic;text-align:center;padding:var(--space-lg)}.admin-footer{margin-top:var(--space-xl);text-align:center;color:#ffffffb3;font-size:var(--text-sm)}.admin-footer a{color:#fff;margin-left:var(--space-md)}.admin-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--text-xl)}[data-theme=dark] .admin-login-card input{background:#1e1e2ee6;border-color:#ffffff1a}[data-theme=dark] .stats-list li{border-color:#ffffff0d}[data-theme=dark] .stats-list.searches li{background:#ffffff08}
