*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: #3b82f6;--primary-dark: #2563eb;--bg-gradient-start: #eff6ff;--bg-gradient-end: #dbeafe;--card-bg: rgba(255, 255, 255, .75);--card-bg-solid: #ffffff;--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--border: rgba(255, 255, 255, .3);--shadow: rgba(0, 0, 0, .08);--shadow-lg: rgba(0, 0, 0, .12);--detail-bg: rgba(255, 255, 255, .5);--detail-bg-hover: rgba(255, 255, 255, .7);--success: #10b981;--error: #ef4444;--radius: 1rem;--radius-lg: 1.25rem;--transition: .25s ease}@media(prefers-color-scheme:dark){:root{--primary: #60a5fa;--primary-dark: #3b82f6;--bg-gradient-start: #0f172a;--bg-gradient-end: #1e293b;--card-bg: rgba(30, 41, 59, .7);--card-bg-solid: #1e293b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border: rgba(255, 255, 255, .08);--shadow: rgba(0, 0, 0, .3);--shadow-lg: rgba(0, 0, 0, .4);--detail-bg: rgba(51, 65, 85, .6);--detail-bg-hover: rgba(71, 85, 105, .7)}}@media(prefers-reduced-motion:reduce){:root{--transition: .01s ease}}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);min-height:100vh;color:var(--text-primary);line-height:1.6;transition:background 1.5s ease}.container{max-width:960px;margin:0 auto;padding:2rem 1rem;position:relative;z-index:1}.header{text-align:center;margin-bottom:2rem}.logo-container{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.5rem}.logo{height:3rem;width:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.2))}.title{font-size:2.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;text-shadow:0 2px 10px rgba(255,255,255,.8),0 0 20px rgba(255,255,255,.4)}@media(prefers-color-scheme:dark){.title{text-shadow:0 2px 10px rgba(0,0,0,.8),0 0 20px rgba(0,0,0,.4)}}.subtitle{color:var(--text-secondary);font-size:1rem;font-weight:600;text-shadow:0 1px 4px rgba(255,255,255,.8)}@media(prefers-color-scheme:dark){.subtitle{text-shadow:0 1px 4px rgba(0,0,0,.8)}}.search-card{background:var(--card-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:0 8px 32px var(--shadow),0 2px 8px #0000000a;margin-bottom:2rem;transition:transform var(--transition),box-shadow var(--transition)}.search-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px var(--shadow-lg),0 12px 24px var(--shadow-lg)}.search-form{display:flex;gap:.5rem;margin-bottom:1.5rem}.search-input{flex:1;padding:.75rem 1rem;border:2px solid var(--border);border-radius:.5rem;font-size:1rem;font-family:inherit;transition:border-color var(--transition),box-shadow var(--transition);outline:none;background:#ffffff80;color:var(--text-primary)}@media(prefers-color-scheme:dark){.search-input{background:#1e293b99}}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f626}.btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background var(--transition),transform var(--transition),box-shadow var(--transition),border-color var(--transition),color var(--transition);outline:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 8px var(--shadow)}.btn-outline{width:100%;background:transparent;color:var(--text-primary);border:2px solid var(--border)}.btn-outline:hover{background:var(--detail-bg);border-color:var(--primary);color:var(--primary)}.btn:disabled{opacity:.5;cursor:not-allowed}.icon{width:1.25rem;height:1.25rem;flex-shrink:0}.btn-text{display:none}@media(min-width:640px){.btn-text{display:inline}}.divider{display:flex;align-items:center;margin:1.5rem 0;color:var(--text-muted)}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.divider-text{padding:0 1rem;font-size:.875rem}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.loading{text-align:center;padding:3rem;color:var(--text-secondary)}.spinner{width:3rem;height:3rem;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;margin:0 auto 1rem}@media(prefers-reduced-motion:no-preference){.spinner{animation:spin .8s linear infinite}}@keyframes spin{to{transform:rotate(360deg)}}.weather-content{display:flex;flex-direction:column;gap:1.5rem}.weather-card{background:var(--card-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;box-shadow:0 8px 32px var(--shadow),0 2px 8px #0000000a}@media(prefers-reduced-motion:no-preference){.weather-card{animation:fadeInUp .5s ease}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.weather-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.location h2{font-size:1.75rem;font-weight:600;letter-spacing:-.02em}.location-time-label{display:inline-block;margin-top:.25rem;font-size:.875rem;font-weight:500;color:var(--primary);background:#3b82f61a;padding:.15rem .75rem;border-radius:999px;letter-spacing:.02em}.weather-icon-large{width:5rem;height:5rem}.weather-main{text-align:center;margin-bottom:2rem}.temperature{display:flex;justify-content:center;align-items:baseline;margin-bottom:.5rem}.temp-value{font-size:4rem;font-weight:700;line-height:1;letter-spacing:-.03em;color:var(--text-primary);text-shadow:0 2px 10px rgba(255,255,255,.6),0 0 20px rgba(255,255,255,.3)}@media(prefers-color-scheme:dark){.temp-value{text-shadow:0 2px 10px rgba(0,0,0,.6),0 0 20px rgba(0,0,0,.3)}}.temp-unit{font-size:2rem;font-weight:400;margin-left:.25rem;color:var(--text-secondary);text-shadow:0 1px 4px rgba(255,255,255,.6)}@media(prefers-color-scheme:dark){.temp-unit{text-shadow:0 1px 4px rgba(0,0,0,.6)}}.weather-description{font-size:1.25rem;color:var(--text-secondary);text-transform:capitalize;margin-bottom:.5rem;text-shadow:0 1px 4px rgba(255,255,255,.6)}@media(prefers-color-scheme:dark){.weather-description{text-shadow:0 1px 4px rgba(0,0,0,.6)}}.feels-like{font-size:.875rem;color:var(--text-muted)}.weather-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.detail-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--detail-bg);border-radius:.75rem;transition:background var(--transition),transform var(--transition)}.detail-item:hover{background:var(--detail-bg-hover);transform:translateY(-2px)}@media(prefers-reduced-motion:reduce){.detail-item:hover{transform:none}}.detail-icon{width:2rem;height:2rem;color:var(--primary);flex-shrink:0}.detail-info{display:flex;flex-direction:column}.detail-label{font-size:.875rem;color:var(--text-muted)}.detail-value{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.weather-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.weather-grid-full{grid-column:1 / -1}.forecast-section{background:var(--card-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:0 8px 32px var(--shadow),0 2px 8px #0000000a;transition:transform var(--transition),box-shadow var(--transition);height:100%}.forecast-section:hover{box-shadow:0 12px 40px var(--shadow-lg),0 4px 12px #0000000f}.forecast-section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;letter-spacing:-.02em}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-icon{width:4rem;height:4rem;margin:0 auto 1rem;opacity:.3}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:var(--card-bg-solid);color:var(--text-primary);padding:1rem 1.5rem;border-radius:.5rem;box-shadow:0 4px 12px var(--shadow-lg);z-index:1000;font-weight:500}@media(prefers-reduced-motion:no-preference){.toast{animation:slideUp .3s ease}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.toast.error{background:var(--error);color:#fff}.toast.success{background:var(--success);color:#fff}.week-forecast{display:flex;justify-content:space-between;gap:.75rem;width:100%}.week-day-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.65rem;background:var(--detail-bg);border-radius:.75rem;transition:background var(--transition),transform var(--transition),box-shadow var(--transition)}.week-day-card:hover{background:var(--detail-bg-hover);box-shadow:0 4px 12px var(--shadow)}@media(prefers-reduced-motion:no-preference){.week-day-card:hover{transform:translateY(-2px)}}.week-day-name{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.week-day-icon{width:2.25rem;height:2.25rem}.week-day-temps{display:flex;gap:.4rem;font-size:.8rem}.week-day-max{font-weight:600;color:var(--text-primary)}.week-day-min{color:var(--text-muted)}.week-day-rain{font-size:.7rem;color:var(--primary);font-weight:500}.temp-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.temp-summary-item{text-align:center;padding:.75rem;background:var(--detail-bg);border-radius:.75rem;transition:transform var(--transition),box-shadow var(--transition)}.temp-summary-item:hover{box-shadow:0 4px 12px var(--shadow)}@media(prefers-reduced-motion:no-preference){.temp-summary-item:hover{transform:translateY(-2px)}}.temp-summary-item.temp-summary-avg .temp-summary-value{color:var(--primary);font-size:1.4rem}.temp-summary-label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:.2rem}.temp-summary-value{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.hourly-chart-section{min-width:0}.hourly-chart{display:flex;align-items:flex-end;margin-bottom:.5rem;min-height:90px}.hourly-chart-bars{display:flex;align-items:flex-end;justify-content:space-between;gap:.2rem;width:100%;height:90px}.hourly-chart-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;min-width:0;height:90px}.hourly-chart-bar{width:100%;max-width:1.75rem;min-height:4px;border-radius:.25rem .25rem 0 0;background:linear-gradient(180deg,var(--primary) 0%,var(--primary-dark) 100%);transition:opacity var(--transition)}.hourly-chart-bar-wrap:hover .hourly-chart-bar{opacity:.9}.hourly-chart-temp{font-size:.625rem;font-weight:600;color:var(--text-primary);margin-top:.2rem}.hourly-chart-labels{display:flex;justify-content:space-between;gap:.2rem;padding-top:.4rem;border-top:1px solid var(--border)}.hourly-chart-label{flex:1;font-size:.6rem;color:var(--text-muted);text-align:center;min-width:0}.rain-list{display:flex;flex-direction:column;gap:.75rem}.rain-day{display:grid;grid-template-columns:2.5rem 1fr 2.5rem;align-items:center;gap:.75rem}.rain-day-name{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.rain-bar-wrap{height:.5rem;background:var(--detail-bg);border-radius:999px;overflow:hidden}.rain-bar{height:100%;background:linear-gradient(90deg,var(--primary),#0ea5e9);border-radius:999px;transition:width var(--transition)}.rain-day-pct{font-size:.875rem;font-weight:600;color:var(--text-primary);text-align:right}.weather-ambience{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;transition:background 1.5s ease}.weather-canvas{position:absolute;inset:0;width:100%;height:100%}.ambience-vignette{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 40%,rgba(0,0,0,.25) 100%);pointer-events:none}@media(max-width:768px){.title{font-size:2rem}.temp-value{font-size:3rem}.weather-details{grid-template-columns:repeat(2,1fr)}.container{padding:1.5rem 1rem}.weather-grid{grid-template-columns:1fr}.weather-grid-full{grid-column:1}.week-forecast,.temp-summary-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:480px){.week-forecast{grid-template-columns:repeat(2,1fr)}.weather-details{grid-template-columns:1fr}}
