*{margin:0;padding:0;box-sizing:border-box}:root[data-theme=dark]{--bg-primary: #0f1419;--bg-secondary: #1a1f2e;--bg-tertiary: #252b3a;--text-primary: #ffffff;--text-secondary: #a0a9c0;--text-muted: #6b7280;--border: #2d3748;--accent: #3b82f6;--accent-hover: #2563eb;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4)}:root[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #64748b;--border: #e2e8f0;--accent: #3b82f6;--accent-hover: #2563eb;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1)}:root{--bg-primary: #0f1419;--bg-secondary: #1a1f2e;--bg-tertiary: #252b3a;--text-primary: #ffffff;--text-secondary: #a0a9c0;--text-muted: #6b7280;--border: #2d3748;--accent: #3b82f6;--accent-hover: #2563eb;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.nav-brand h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--accent),#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.theme-toggle{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:1.2rem}.theme-toggle:hover{background:var(--accent);transform:translateY(-1px)}.container{display:flex;flex:1;max-width:1400px;margin:0 auto;width:100%}.sidebar{width:320px;background:var(--bg-secondary);border-right:1px solid var(--border);padding:2rem;overflow-y:auto;height:calc(100vh - 73px);position:sticky;top:73px}.search-panel{margin-bottom:2rem}.search-box{position:relative;margin-bottom:1rem}.search-box input{width:100%;padding:.75rem 3rem .75rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);font-size:.95rem;outline:none;transition:all .2s ease}.search-box input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61a}.search-box input::placeholder{color:var(--text-muted)}.search-box button{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:var(--accent);border:none;border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease;color:#fff}.search-box button:hover{background:var(--accent-hover)}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-tertiary);border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px;z-index:1000;max-height:200px;overflow-y:auto;box-shadow:var(--shadow-lg)}.suggestion-item{width:100%;padding:.75rem 1rem;background:none;border:none;color:var(--text-primary);text-align:left;cursor:pointer;transition:background .2s ease;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.suggestion-item:hover{background:var(--accent)}.suggestion-item svg{color:var(--text-muted)}.controls-row{display:flex;gap:1rem;align-items:center}.unit-selector{display:flex;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;overflow:hidden}.unit-selector button{flex:1;padding:.5rem 1rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-weight:500}.unit-selector button.active{background:var(--accent);color:#fff}.location-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500}.location-btn:hover:not(:disabled){background:var(--accent);color:#fff}.location-btn:disabled{opacity:.5;cursor:not-allowed}.quick-access{margin-top:2rem}.section{margin-bottom:2rem}.section h3{font-size:.9rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.city-list{display:flex;flex-direction:column;gap:.5rem}.city-btn{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:.9rem;text-align:left}.city-btn:hover{background:var(--accent);transform:translate(4px)}.city-btn svg{color:var(--text-muted);flex-shrink:0}.main-content{flex:1;padding:2rem;overflow-y:auto}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top:3px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.alert{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;margin-bottom:2rem;font-size:.9rem}.alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--error)}.weather-dashboard{animation:fadeIn .5s ease-out}.weather-alerts{margin-bottom:2rem}.weather-alerts h4{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.alerts-grid{display:flex;flex-wrap:wrap;gap:.75rem}.alert-item{padding:.75rem 1rem;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border:1px solid rgba(59,130,246,.2);border-radius:12px;font-size:.9rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}@keyframes fadeIn{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:2rem}.location-info h2{font-size:2rem;font-weight:700;margin-bottom:.5rem}.location-info p{color:var(--text-secondary);font-size:1rem}.favorite-toggle{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-muted)}.favorite-toggle:hover{background:var(--accent);color:#fff}.favorite-toggle.active{color:var(--warning);background:#f59e0b1a;border-color:#f59e0b4d}.weather-tabs{display:flex;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:.25rem;margin-bottom:2rem}.tab{flex:1;padding:.75rem 1.5rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;border-radius:8px;font-weight:500;font-size:.9rem}.tab.active{background:var(--accent);color:#fff}.tab:hover:not(.active){background:var(--bg-tertiary);color:var(--text-primary)}.current-weather{display:flex;flex-direction:column;gap:2rem}.weather-overview{display:flex;align-items:center;gap:3rem;padding:2rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px}.weather-visual{display:flex;align-items:center;gap:1rem}.weather-icon{width:120px;height:120px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.temperature-display{display:flex;align-items:flex-start;gap:.5rem}.temperature{font-size:4rem;font-weight:200;line-height:1;background:linear-gradient(135deg,var(--accent),#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.unit{font-size:1.5rem;font-weight:400;color:var(--text-secondary);margin-top:.5rem}.weather-summary h3{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;text-transform:capitalize}.weather-summary p{color:var(--text-secondary);font-size:1.1rem;margin-bottom:1rem}.temp-range{display:flex;gap:1rem;font-size:1rem;color:var(--text-secondary)}.weather-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.metric-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;transition:all .2s ease}.metric-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.metric-icon{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#3b82f61a;border-radius:8px}.metric-info{flex:1}.metric-label{display:block;font-size:.9rem;color:var(--text-secondary);margin-bottom:.25rem}.metric-value{display:block;font-size:1.25rem;font-weight:600;margin-bottom:.25rem}.metric-detail{display:block;font-size:.85rem;color:var(--text-muted)}.progress-bar{width:100%;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden;margin-top:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#8b5cf6);border-radius:2px;transition:width 1s ease}.hourly-forecast{padding:1rem 0}.forecast-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.hourly-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;transition:all .2s ease}.hourly-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.hour-time{font-size:.9rem;color:var(--text-secondary);font-weight:500}.hour-icon{width:48px;height:48px}.hour-temp{font-size:1.1rem;font-weight:600}.hour-condition{font-size:.85rem;color:var(--text-secondary);text-align:center}.hour-rain,.hour-wind{font-size:.75rem;color:var(--text-muted);font-weight:500}.hour-rain{color:var(--accent)}.daily-forecast{padding:1rem 0}.forecast-list{display:flex;flex-direction:column;gap:1rem}.daily-card{display:flex;align-items:center;gap:2rem;padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;transition:all .2s ease}.daily-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.day-info{min-width:80px}.day-name{font-size:1rem;font-weight:600;margin-bottom:.25rem}.day-date{font-size:.85rem;color:var(--text-secondary)}.day-icon{width:60px;height:60px}.day-condition{flex:1;font-size:1rem;color:var(--text-secondary);text-transform:capitalize}.day-temps{display:flex;align-items:center;gap:.75rem;min-width:100px}.temp-high{font-size:1.1rem;font-weight:600}.temp-low{font-size:1rem;color:var(--text-secondary)}.day-details{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--text-muted);min-width:80px}@media (max-width: 1024px){.container{flex-direction:column}.sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1px solid var(--border)}.weather-overview{flex-direction:column;text-align:center;gap:2rem}.weather-visual{flex-direction:column;gap:1rem}.weather-metrics{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media (max-width: 768px){.navbar,.sidebar,.main-content{padding:1rem}.controls-row{flex-direction:column;align-items:stretch;gap:.75rem}.location-btn{justify-content:center}.weather-header{flex-direction:column;gap:1rem;align-items:flex-start}.location-info h2{font-size:1.5rem}.temperature{font-size:3rem}.weather-metrics{grid-template-columns:1fr}.forecast-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.daily-card{flex-direction:column;text-align:center;gap:1rem}.day-temps{justify-content:center}.weather-tabs{flex-direction:column}.tab{text-align:center}}@media (max-width: 480px){.weather-overview{padding:1rem}.temperature{font-size:2.5rem}.weather-icon{width:100px;height:100px}.metric-card{padding:1rem}.hourly-card{padding:1rem .5rem}.daily-card{padding:1rem}}
