:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--sunny-gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--cloudy-gradient: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--rainy-gradient: linear-gradient(135deg, #43e97b 0%, #38f9d7 100%);--night-gradient: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);--color-primary: #667eea;--color-secondary: #764ba2;--color-accent: #f5576c;--color-success: #43e97b;--color-warning: #ffd93d;--color-error: #ff6b6b;--bg-primary: #f8f9fa;--bg-secondary: #ffffff;--bg-card: rgba(255, 255, 255, .9);--text-primary: #2d3748;--text-secondary: #718096;--text-tertiary: #a0aec0;--border-color: rgba(0, 0, 0, .1);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .16);--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Outfit", "Inter", sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: .5rem;--radius-md: 1rem;--radius-lg: 1.5rem;--radius-xl: 2rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--glass-bg: rgba(255, 255, 255, .25);--glass-border: rgba(255, 255, 255, .18);--glass-blur: blur(20px)}[data-theme=dark]{--bg-primary: linear-gradient(135deg, #0a0e27 0%, #1a1b3d 50%, #0f0c29 100%);--bg-secondary: #1a1d3a;--bg-card: rgba(26, 29, 58, .85);--text-primary: #ffffff;--text-secondary: #e0e7ff;--text-tertiary: #a5b4fc;--border-color: rgba(139, 92, 246, .3);--shadow-sm: 0 2px 12px rgba(139, 92, 246, .15), 0 4px 8px rgba(0, 0, 0, .4);--shadow-md: 0 4px 20px rgba(139, 92, 246, .25), 0 8px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 40px rgba(139, 92, 246, .35), 0 12px 24px rgba(0, 0, 0, .6);--glass-bg: linear-gradient(135deg, rgba(139, 92, 246, .15) 0%, rgba(59, 130, 246, .1) 50%, rgba(139, 92, 246, .15) 100%);--glass-border: rgba(167, 139, 250, .3);--glass-blur: blur(24px);--color-primary: #a78bfa;--color-secondary: #818cf8;--color-accent: #f472b6;--primary-gradient: linear-gradient(135deg, #8b5cf6 0%, #3b82f6 50%, #06b6d4 100%);--night-gradient: linear-gradient(135deg, #312e81 0%, #1e1b4b 50%, #0f172a 100%)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-primary);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background var(--transition-base),color var(--transition-base);min-height:100vh}[data-theme=dark] body{background:linear-gradient(135deg,#0a0e27,#1a1b3d,#0f0c29);background-attachment:fixed}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:3rem;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:2rem}h3{font-size:1.5rem}p{margin-bottom:var(--spacing-md)}.glass-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md);transition:all var(--transition-base)}.glass-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}[data-theme=dark] .glass-card{background:linear-gradient(135deg,#8b5cf61f,#3b82f614,#8b5cf61f);border:1px solid rgba(167,139,250,.25);box-shadow:0 4px 20px #8b5cf633,0 2px 8px #0006,inset 0 1px #ffffff0d}[data-theme=dark] .glass-card:hover{border-color:#a78bfa66;box-shadow:0 8px 32px #8b5cf64d,0 4px 16px #00000080,inset 0 1px #ffffff1a,0 0 40px #8b5cf626}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);font-family:var(--font-primary);font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-decoration:none;white-space:nowrap}.btn-units:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-2px) scale(1.05);box-shadow:var(--shadow-md)}.btn-units:active{transform:translateY(0) scale(.95)}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-secondary)}.btn-icon{padding:var(--spacing-md);border-radius:var(--radius-full)}.input{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-family:var(--font-primary);font-size:1rem;color:var(--text-primary);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-base);outline:none}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #667eea26;transform:scale(1.01)}.input::placeholder{color:var(--text-tertiary)}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn var(--transition-slow) ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slideIn var(--transition-slow) ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.bounce{animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.shimmer{background:linear-gradient(90deg,var(--bg-card) 0%,var(--bg-primary) 50%,var(--bg-card) 100%);background-size:200% 100%;animation:shimmer 2s ease-in-out infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.gradient-animate{background-size:200% 200%;animation:gradientShift 3s ease infinite}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.scale-hover{transition:transform var(--transition-base)}.scale-hover:hover{transform:scale(1.05)}.glow{box-shadow:0 0 20px #667eea80;animation:glow 2s ease-in-out infinite}@keyframes glow{0%,to{box-shadow:0 0 20px #667eea80}50%{box-shadow:0 0 30px #667eeacc}}.container{max-width:100%;margin:0 auto;padding:0 var(--spacing-xl)}@media(min-width:1920px){.container{max-width:1800px}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}@media(max-width:768px){html{font-size:14px}h1{font-size:2rem}h2{font-size:1.5rem}.container{padding:0 var(--spacing-md)}}@media(max-width:480px){html{font-size:13px}.glass-card{padding:var(--spacing-lg)}}.search-bar-container{position:relative;width:100%;max-width:600px;margin:0 auto}.search-form{display:flex;gap:var(--spacing-sm);align-items:center;width:100%;margin-bottom:var(--spacing-md)}.search-input-wrapper{position:relative;flex:1;display:flex;align-items:center}.search-loading{position:absolute;right:var(--spacing-lg);font-size:1.25rem;animation:spin 1s linear infinite}.search-input{width:100%;padding:var(--spacing-lg);font-size:1.125rem;color:var(--text-primary);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-xl);transition:all var(--transition-base);outline:none;box-shadow:var(--shadow-sm)}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #667eea1a,var(--shadow-md);transform:translateY(-2px)}.search-input::placeholder{color:var(--text-tertiary)}.btn-search{padding:var(--spacing-lg);font-size:1.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;min-width:56px;min-height:56px}.btn-search:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);filter:brightness(1.1)}.btn-search:active{transform:translateY(0)}.btn-enable-location{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:fit-content;margin:0 auto;padding:var(--spacing-sm) var(--spacing-lg);font-size:.875rem;font-weight:600;color:var(--text-secondary);background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base)}.btn-enable-location:hover{background:var(--bg-card);color:var(--color-primary);border-color:var(--color-primary);transform:translateY(-1px)}.location-pin{font-size:1.125rem}.suggestions-dropdown{position:absolute;top:calc(100% + var(--spacing-sm));left:0;right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;z-index:1000;animation:slideDown var(--transition-base)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.suggestion-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-color)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:var(--bg-primary)}.suggestion-icon{font-size:1.25rem;opacity:.7}.suggestion-content{flex:1}.suggestion-name{font-weight:600;color:var(--text-primary);margin-bottom:2px}.suggestion-details{font-size:.875rem;color:var(--text-secondary)}@media(max-width:768px){.search-form{gap:var(--spacing-sm)}.search-input{font-size:1rem;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) 3rem}.search-icon{left:var(--spacing-md);font-size:1.125rem}.btn-search{min-width:48px;min-height:48px;font-size:1.25rem}}.current-weather{width:100%}.weather-hero{text-align:center;padding:var(--spacing-2xl) 0;margin-bottom:var(--spacing-xl)}.weather-icon-large{font-size:8rem;margin-bottom:var(--spacing-lg);filter:drop-shadow(0 4px 12px rgba(0,0,0,.15))}.weather-main-info{margin-bottom:var(--spacing-lg)}.temperature{font-size:5rem;font-weight:800;margin-bottom:var(--spacing-sm);background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.weather-description{font-size:1.5rem;color:var(--text-secondary);text-transform:capitalize;margin-bottom:var(--spacing-sm);font-weight:500}.location{font-size:1.125rem;color:var(--text-tertiary);font-weight:500}.weather-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.detail-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);min-height:100px}.detail-icon{font-size:2.5rem;opacity:.9}.detail-content{flex:1}.detail-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:4px;font-weight:500}.detail-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.wind-direction{font-size:.875rem;color:var(--text-secondary);font-weight:500}.temp-range{display:flex;align-items:center;justify-content:space-around;padding:var(--spacing-xl);max-width:500px;margin:0 auto}.temp-range-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.temp-range-icon{font-size:2rem}.temp-range-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.temp-range-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.temp-range-divider{width:2px;height:60px;background:var(--border-color);border-radius:2px}@media(max-width:768px){.weather-icon-large{font-size:6rem}.temperature{font-size:4rem}.weather-description{font-size:1.25rem}.weather-details-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.detail-card{padding:var(--spacing-md);min-height:80px}.detail-icon{font-size:2rem}.detail-value{font-size:1.125rem}}@media(max-width:480px){.weather-icon-large{font-size:5rem}.temperature{font-size:3rem}.weather-details-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.temp-range{padding:var(--spacing-lg)}}.forecast-container{width:100%;margin-top:var(--spacing-2xl)}.forecast-title{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-xl);text-align:center;color:var(--text-primary)}.forecast-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-3xl)}.forecast-card{text-align:center;padding:var(--spacing-xl);cursor:pointer;transition:all var(--transition-base)}.forecast-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.forecast-date{font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.forecast-icon{font-size:3.5rem;margin:var(--spacing-md) 0;filter:drop-shadow(0 2px 8px rgba(0,0,0,.1))}.forecast-description{font-size:.875rem;color:var(--text-secondary);text-transform:capitalize;margin-bottom:var(--spacing-lg);min-height:40px}.forecast-temps{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.forecast-temp-item{display:flex;flex-direction:column;gap:4px}.temp-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.temp-value{font-size:1.25rem;font-weight:700}.temp-high{color:var(--color-accent)}.temp-low{color:var(--color-primary)}.forecast-temp-divider{width:1px;height:40px;background:var(--border-color)}.hourly-forecast{margin-top:var(--spacing-3xl)}.hourly-title{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.hourly-scroll{display:flex;gap:var(--spacing-md);overflow-x:auto;padding-bottom:var(--spacing-md);scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.hourly-scroll::-webkit-scrollbar{height:8px}.hourly-scroll::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.hourly-scroll::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.hourly-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.hourly-item{flex:0 0 auto;min-width:100px;padding:var(--spacing-lg);text-align:center;transition:all var(--transition-base)}.hourly-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.hourly-time{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.hourly-icon{font-size:2.5rem;margin:var(--spacing-sm) 0}.hourly-temp{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.hourly-detail{display:flex;align-items:center;justify-content:center;gap:4px;font-size:.875rem;color:var(--text-secondary)}.hourly-detail-icon{font-size:1rem}@media(max-width:768px){.forecast-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.forecast-card{padding:var(--spacing-lg)}.forecast-icon{font-size:3rem}.hourly-item{min-width:90px;padding:var(--spacing-md)}.hourly-icon{font-size:2rem}}@media(max-width:480px){.forecast-title{font-size:1.5rem}.forecast-grid{grid-template-columns:1fr}.hourly-title{font-size:1.25rem}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);min-height:200px}.weather-loader{position:relative;width:100px;height:100px;margin-bottom:var(--spacing-lg)}.sun{position:absolute;top:10px;right:10px;width:40px;height:40px;background:linear-gradient(135deg,#ffd93d,#ff6b6b);border-radius:50%;box-shadow:0 0 20px #ffd93d99;animation:sunPulse 2s ease-in-out infinite}.cloud{position:absolute;bottom:20px;left:10px;width:60px;height:30px;background:#ffffffe6;border-radius:20px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:cloudFloat 3s ease-in-out infinite;box-shadow:0 4px 10px #0000001a}.cloud:before{content:"";position:absolute;top:-15px;left:10px;width:25px;height:25px;background:#ffffffe6;border-radius:50%}.cloud:after{content:"";position:absolute;top:-20px;right:10px;width:35px;height:35px;background:#ffffffe6;border-radius:50%}@keyframes sunPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}@keyframes cloudFloat{0%,to{transform:translate(0)}50%{transform:translate(10px)}}.loading-message{font-size:1.125rem;color:var(--text-secondary);font-weight:500;animation:pulse 2s infinite}.theme-toggle{position:fixed;top:var(--spacing-lg);right:var(--spacing-lg);width:56px;height:56px;font-size:1.5rem;background:var(--bg-card);border:2px solid var(--border-color);box-shadow:var(--shadow-md);z-index:1000;transition:all var(--transition-base)}.theme-toggle:hover{transform:translateY(-2px) rotate(15deg);box-shadow:var(--shadow-lg);border-color:var(--color-primary)}.theme-toggle:active{transform:translateY(0) rotate(0)}[data-theme=dark] .theme-toggle{background:linear-gradient(135deg,#8b5cf633,#3b82f633);border-color:#a78bfa66;box-shadow:0 4px 20px #8b5cf64d,0 0 40px #8b5cf633,inset 0 0 20px #a78bfa1a}[data-theme=dark] .theme-toggle:hover{box-shadow:0 8px 30px #8b5cf680,0 0 60px #8b5cf64d,inset 0 0 30px #a78bfa33;border-color:#a78bfa99}@media(max-width:768px){.theme-toggle{top:var(--spacing-md);right:var(--spacing-md);width:48px;height:48px;font-size:1.25rem}}.weather-particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;opacity:.6}.favorites-container{display:flex;gap:var(--spacing-md);align-items:center;justify-content:center;flex-wrap:wrap;position:relative}.btn-favorite,.btn-show-favorites{padding:var(--spacing-md) var(--spacing-lg);font-size:.875rem;font-weight:600;color:var(--text-primary);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:var(--spacing-sm)}.btn-favorite:hover:not(:disabled),.btn-show-favorites:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-favorite.is-favorite{background:linear-gradient(135deg,#ffd93d,#f5576c);color:#fff;border-color:transparent;cursor:default}.btn-favorite:disabled{opacity:.8}.favorites-dropdown{position:absolute;top:calc(100% + var(--spacing-md));right:0;min-width:300px;max-width:400px;padding:0;overflow:hidden;z-index:1000;animation:slideDown var(--transition-base)}.favorites-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.favorites-header h3{margin:0;font-size:1.125rem;color:var(--text-primary)}.btn-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:var(--radius-sm);transition:all var(--transition-fast)}.btn-close:hover{background:var(--bg-primary);color:var(--text-primary)}.favorites-list{max-height:300px;overflow-y:auto}.favorite-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);transition:background var(--transition-fast)}.favorite-item:last-child{border-bottom:none}.favorite-item:hover{background:var(--bg-primary)}.favorite-city-btn{flex:1;display:flex;align-items:center;gap:var(--spacing-sm);background:none;border:none;padding:var(--spacing-sm);cursor:pointer;text-align:left;color:var(--text-primary);font-size:1rem;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.favorite-city-btn:hover{background:var(--bg-secondary)}.favorite-icon{font-size:1.25rem}.favorite-name{font-weight:600}.btn-remove{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:all var(--transition-fast);opacity:.6}.btn-remove:hover{opacity:1;background:#ff6b6b1a;transform:scale(1.1)}.favorites-list::-webkit-scrollbar{width:6px}.favorites-list::-webkit-scrollbar-track{background:var(--bg-secondary)}.favorites-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.favorites-list::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@media(max-width:768px){.favorites-dropdown{left:0;right:0;min-width:auto;max-width:none}}.weather-stats{margin:var(--spacing-2xl) 0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg)}.stat-card{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xl);transition:all var(--transition-base)}.stat-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--shadow-lg)}.stat-icon{font-size:3rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.1))}.stat-content{flex:1}.stat-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:4px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.stat-card{padding:var(--spacing-lg)}.stat-icon{font-size:2.5rem}.stat-value{font-size:1.25rem}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.clothing-recommendation{margin:var(--spacing-3xl) 0}.recommendation-title{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);font-size:2rem;margin-bottom:var(--spacing-xl);text-align:center}.title-icon{font-size:2.5rem;animation:bounce 2s ease-in-out infinite}.recommendation-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg)}.recommendation-card{padding:var(--spacing-xl);transition:all var(--transition-base)}.recommendation-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}.card-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.card-icon{font-size:2.5rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.1))}.card-header h3{font-size:1.25rem;margin:0;color:var(--text-primary);font-weight:700}.outfit-text{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm);line-height:1.6}.layer-text{font-size:.875rem;color:var(--text-secondary);font-style:italic;margin:0}.umbrella-needed{background:linear-gradient(135deg,#43e97b1a,#38f9d71a);border:2px solid rgba(67,233,123,.3)}.umbrella-not-needed{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:2px solid rgba(102,126,234,.3)}.umbrella-status{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.umbrella-reason{font-size:.875rem;color:var(--text-secondary);margin:0}.accessories-card{grid-column:span 1}.accessories-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.accessory-item{display:flex;flex-direction:column;gap:4px;padding:var(--spacing-sm);background:var(--bg-primary);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.accessory-item:hover{background:var(--bg-secondary);transform:translate(4px)}.accessory-name{font-size:1rem;font-weight:600;color:var(--text-primary)}.accessory-reason{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.comfort-card{background:linear-gradient(135deg,#ffd93d1a,#f5576c1a);border:2px solid rgba(255,217,61,.3)}.comfort-text{font-size:1rem;color:var(--text-primary);line-height:1.6;margin:0;font-weight:500}@media(max-width:768px){.recommendation-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.recommendation-card{padding:var(--spacing-lg)}.recommendation-title{font-size:1.5rem}.title-icon,.card-icon{font-size:2rem}.outfit-text{font-size:1rem}}@media(max-width:480px){.recommendation-title{font-size:1.25rem;flex-direction:column;gap:var(--spacing-sm)}.card-header{flex-direction:column;text-align:center}}.app{min-height:100vh;position:relative;overflow-x:hidden;padding:var(--spacing-md) 0}.app-background{position:fixed;inset:0;background:var(--dynamic-gradient, var(--primary-gradient));opacity:.15;z-index:-1;transition:background 1s ease}.app-header{text-align:center;padding:var(--spacing-2xl) 0;margin-bottom:var(--spacing-xl)}.app-title{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);font-size:3rem;margin-bottom:var(--spacing-sm)}.title-icon{font-size:3.5rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.app-subtitle{font-size:1.125rem;color:var(--text-secondary);font-weight:500}.search-section{max-width:600px;margin:0 auto var(--spacing-3xl);display:flex;flex-direction:column;gap:var(--spacing-lg);align-items:center}.controls-row{display:flex;gap:var(--spacing-md);align-items:center;justify-content:center;flex-wrap:wrap;width:100%}.btn-units{padding:var(--spacing-md) var(--spacing-xl);font-size:.875rem;font-weight:600;color:var(--text-primary);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.btn-units:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.error-message{max-width:600px;margin:var(--spacing-3xl) auto;padding:var(--spacing-xl);text-align:center;background:#ff6b6b1a;border:2px solid var(--color-error)}.error-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-md)}.error-message p{font-size:1.125rem;color:var(--text-primary);margin:0}.welcome-message{max-width:600px;margin:var(--spacing-3xl) auto;padding:var(--spacing-3xl);text-align:center}.welcome-icon{font-size:4rem;display:block;margin-bottom:var(--spacing-lg);animation:wave 2s ease-in-out infinite}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}75%{transform:rotate(-20deg)}}.welcome-message h2{font-size:2rem;margin-bottom:var(--spacing-md);color:var(--text-primary)}.welcome-message p{font-size:1.125rem;color:var(--text-secondary);margin:0}.app-footer{text-align:center;padding:var(--spacing-3xl) 0 var(--spacing-xl);margin-top:var(--spacing-3xl);color:var(--text-tertiary);font-size:.875rem}.app-footer p{margin:var(--spacing-sm) 0}.footer-credits{font-weight:600;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(max-width:768px){.app{padding:0}.app-header{padding:var(--spacing-lg) 0;margin-bottom:var(--spacing-lg)}.app-title{font-size:2rem}.title-icon{font-size:2.5rem}.app-subtitle{font-size:1rem}.search-section{margin-bottom:var(--spacing-xl);padding:0 var(--spacing-sm)}.container{padding:0 var(--spacing-sm)}}@media(max-width:480px){.app-title{font-size:1.75rem;flex-direction:column;gap:var(--spacing-sm)}.welcome-message{padding:var(--spacing-2xl)}.welcome-message h2{font-size:1.5rem}}
