@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.app-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;transition:all .3s ease}.app-container.dark{background:linear-gradient(135deg,#1a1a2e,#16213e)}.app-header{max-width:1200px;margin:0 auto 40px;background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:20px 30px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center}.app-title{font-size:2.5rem;font-weight:700;color:#fff;margin:0;display:flex;align-items:center;gap:15px}.weather-emoji{font-size:3rem;animation:bounceIn 1s ease-out}.header-actions{display:flex;gap:15px}.theme-toggle,.refresh-btn,.export-btn{background:#fff3;border:none;border-radius:12px;padding:12px;color:#fff;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.theme-toggle:hover,.refresh-btn:hover,.export-btn:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 5px 15px #0003}.spinning{animation:spin 1s linear infinite}.search-section{max-width:1200px;margin:0 auto 40px}.search-container{display:flex;flex-direction:column;align-items:center;gap:20px}.search-bar{display:flex;align-items:center;background:#fffffff2;border-radius:16px;padding:8px;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);width:100%;max-width:600px}.search-icon{margin:0 15px;color:#64748b}.search-input{flex:1;border:none;outline:none;font-size:1.1rem;padding:12px 0;background:transparent;color:#1e293b;font-weight:500}.search-input::placeholder{color:#64748b}.search-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;border-radius:12px;padding:12px 24px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:1rem}.search-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #3b82f666}.location-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:12px;padding:10px 20px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;gap:8px;font-weight:500}.location-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.weather-content{max-width:1200px;margin:0 auto;animation:fadeIn .8s ease-out}.location-info{text-align:center;margin-bottom:40px;color:#fff}.location-name{font-size:2rem;font-weight:600;margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:12px}.location-country{font-size:1.2rem;opacity:.8;margin-bottom:8px}.current-time{font-size:1rem;opacity:.7}.weather-alerts{background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:16px;padding:20px;margin-bottom:30px;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.weather-alerts h3{margin-bottom:15px;font-size:1.3rem}.alert-item{margin-bottom:10px}.current-weather{background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:40px;margin-bottom:40px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.current-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}.temperature-display{display:flex;align-items:baseline;color:#fff}.temperature{font-size:5rem;font-weight:700;line-height:1}.temperature-unit{font-size:2rem;font-weight:400;margin-left:8px}.weather-condition{display:flex;flex-direction:column;align-items:center;text-align:center;color:#fff}.condition-details{margin-top:15px}.condition-text{font-size:1.4rem;font-weight:600;margin-bottom:5px}.feels-like{font-size:1rem;opacity:.8}.weather-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px}.detail-card{background:#ffffff1a;border-radius:16px;padding:20px;display:flex;align-items:center;gap:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.detail-card:hover{background:#fff3;transform:translateY(-5px);box-shadow:0 10px 25px #00000026}.detail-icon{color:#fffc;font-size:1.5rem}.detail-label{display:block;font-size:.9rem;color:#ffffffb3;margin-bottom:5px}.detail-value{display:block;font-size:1.2rem;font-weight:600;color:#fff}.uv-low{color:#10b981}.uv-moderate{color:#f59e0b}.uv-high{color:#f97316}.uv-very-high{color:#ef4444}.uv-extreme{color:#8b5cf6}.air-quality{background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:30px;margin-bottom:40px;border:1px solid rgba(255,255,255,.2);color:#fff}.air-quality h3{font-size:1.5rem;margin-bottom:20px}.aqi-container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.aqi-main{display:flex;flex-direction:column;align-items:center}.aqi-value{font-size:2.5rem;font-weight:700;padding:10px 20px;border-radius:15px;margin-bottom:8px}.aqi-good{background:#10b98133;color:#10b981}.aqi-moderate{background:#f59e0b33;color:#f59e0b}.aqi-unhealthy-for-sensitive{background:#f9731633;color:#f97316}.aqi-unhealthy{background:#ef444433;color:#ef4444}.aqi-very-unhealthy{background:#8b5cf633;color:#8b5cf6}.aqi-hazardous{background:#7c2d1233;color:#7c2d12}.pollutants{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.pollutant{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background:#ffffff1a;border-radius:10px;font-size:.9rem}.forecast-toggle{display:flex;justify-content:center;margin-bottom:30px;background:#ffffff1a;border-radius:16px;padding:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:400px;margin-left:auto;margin-right:auto}.toggle-btn{flex:1;padding:12px 24px;border:none;border-radius:12px;background:transparent;color:#ffffffb3;font-weight:500;cursor:pointer;transition:all .3s ease}.toggle-btn.active{background:#fff3;color:#fff;font-weight:600}.hourly-forecast{background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:30px;margin-bottom:40px;border:1px solid rgba(255,255,255,.2)}.hourly-forecast h3{color:#fff;font-size:1.5rem;margin-bottom:25px;text-align:center}.hourly-scroll{display:flex;gap:20px;overflow-x:auto;padding-bottom:10px;scroll-behavior:smooth}.hourly-item{min-width:140px;background:#ffffff1a;border-radius:16px;padding:20px 15px;text-align:center;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff}.hourly-time{display:block;font-weight:600;margin-bottom:10px;font-size:.9rem}.hourly-temp{display:block;font-size:1.3rem;font-weight:700;margin:10px 0}.hourly-condition{display:block;font-size:.8rem;opacity:.8;margin-bottom:10px}.hourly-details{display:flex;justify-content:space-around;font-size:.7rem;opacity:.7}.forecast{background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:30px;margin-bottom:40px;border:1px solid rgba(255,255,255,.2)}.forecast h3{color:#fff;font-size:1.5rem;margin-bottom:25px;text-align:center}.forecast-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.forecast-card{background:#ffffff1a;border-radius:16px;padding:25px 20px;text-align:center;border:2px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:all .3s ease;color:#fff}.forecast-card:hover{background:#fff3;transform:translateY(-5px);box-shadow:0 10px 30px #0003}.forecast-card.selected{border-color:#3b82f699;background:#3b82f633}.forecast-date{margin-bottom:15px}.day-name{display:block;font-weight:600;font-size:1.1rem;margin-bottom:5px}.date-number{font-size:.9rem;opacity:.8}.forecast-weather{margin-bottom:15px}.forecast-condition{display:block;font-size:.9rem;opacity:.8;margin-top:10px}.forecast-temps{margin-bottom:20px;font-size:1.3rem;font-weight:600}.max-temp{color:#fff}.temp-divider{margin:0 5px;opacity:.5}.min-temp{opacity:.7}.forecast-details{display:flex;justify-content:space-around;margin-bottom:15px;font-size:.9rem}.forecast-detail{display:flex;align-items:center;gap:5px;opacity:.8}.sun-times{display:flex;justify-content:space-around;padding-top:15px;border-top:1px solid rgba(255,255,255,.1);font-size:.8rem}.sun-time{display:flex;align-items:center;gap:5px;opacity:.8}.loading-container{text-align:center;padding:80px 20px;color:#fff}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;gap:20px}.loading-spinner{border-radius:50%;border:4px solid rgba(255,255,255,.2);border-top:4px solid white;animation:spin 1s linear infinite}.loading-text{font-size:1.1rem;font-weight:500}.error-container{display:flex;justify-content:center;padding:40px 20px}.error-message{background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:16px;padding:30px;text-align:center;color:#fff;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);max-width:500px}.error-message h3{font-size:1.5rem;margin-bottom:15px}.error-message p{margin-bottom:20px;opacity:.9}.retry-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:12px;padding:12px 24px;font-weight:600;cursor:pointer;transition:all .3s ease}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #ef444466}.app-footer{text-align:center;color:#ffffffb3;font-size:.9rem;margin-top:40px;padding:20px}.app-footer p{margin-bottom:10px}.dark .search-bar{background:#1e293be6;border-color:#94a3b84d}.dark .search-input{color:#f8fafc}.dark .search-input::placeholder{color:#94a3b8}@media (max-width: 768px){.app-container{padding:10px}.app-header{padding:20px;margin-bottom:20px}.header-content{flex-direction:column;gap:20px}.app-title{font-size:2rem}.current-main{flex-direction:column;gap:30px;text-align:center}.temperature{font-size:4rem}.weather-details-grid{grid-template-columns:repeat(2,1fr);gap:15px}.forecast-grid{grid-template-columns:1fr}.aqi-container{flex-direction:column}.pollutants{grid-template-columns:1fr}}@media (max-width: 480px){.search-bar{flex-direction:column;gap:10px;padding:15px}.search-button{width:100%}.weather-details-grid{grid-template-columns:1fr}.temperature{font-size:3rem}.hourly-item{min-width:120px}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){.app-container{background:linear-gradient(135deg,navy,#000040)}.forecast-card,.detail-card,.current-weather{border-width:2px;border-color:#fff}}.search-wrapper{position:relative;width:100%;max-width:600px}.search-bar{display:flex;align-items:center;background:#fffffff2;border-radius:16px;padding:8px;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);width:100%;position:relative}.clear-search{background:none;border:none;color:#64748b;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease;margin-right:8px}.clear-search:hover{background:#64748b1a;color:#475569}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);border-radius:16px;box-shadow:0 12px 40px #00000026;margin-top:8px;max-height:400px;overflow-y:auto;z-index:1000;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.suggestion-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:all .2s ease;border-bottom:1px solid rgba(226,232,240,.5)}.suggestion-item:hover,.suggestion-item.selected{background:#3b82f614;border-radius:12px;margin:2px 8px;border-bottom:1px solid transparent}.suggestion-item:last-child{border-bottom:none}.suggestion-icon{color:#3b82f6;flex-shrink:0}.suggestion-content{display:flex;flex-direction:column;flex:1;min-width:0}.suggestion-name{font-weight:600;color:#1e293b;font-size:.95rem}.suggestion-details{font-size:.85rem;color:#64748b;opacity:.8}.loading-suggestion{justify-content:center;color:#64748b;font-size:.9rem;padding:16px}.loading-suggestion .loading-spinner{margin-right:8px}.no-results{justify-content:center;color:#64748b;font-size:.9rem;padding:16px;font-style:italic}.suggestions-footer{padding:8px 16px;background:#f1f5f9cc;border-top:1px solid rgba(226,232,240,.5);text-align:center;font-size:.75rem;color:#64748b;border-radius:0 0 16px 16px}.dark .suggestions-dropdown{background:#1e293bfa;border-color:#94a3b84d}.dark .suggestion-item:hover,.dark .suggestion-item.selected{background:#3b82f626}.dark .suggestion-name{color:#f8fafc}.dark .suggestion-details{color:#94a3b8}.dark .suggestions-footer{background:#334155cc;border-color:#47556980;color:#94a3b8}.dark .no-results,.dark .loading-suggestion,.dark .clear-search{color:#94a3b8}.dark .clear-search:hover{background:#94a3b81a;color:#cbd5e1}@media (max-width: 768px){.suggestions-dropdown{max-height:300px;margin-top:4px}.suggestion-item{padding:10px 12px}.suggestion-name{font-size:.9rem}.suggestion-details{font-size:.8rem}}.suggestions-dropdown::-webkit-scrollbar{width:6px}.suggestions-dropdown::-webkit-scrollbar-track{background:#f1f5f980;border-radius:3px}.suggestions-dropdown::-webkit-scrollbar-thumb{background:#cbd5e1cc;border-radius:3px}.suggestions-dropdown::-webkit-scrollbar-thumb:hover{background:#94a3b8cc}.search-input:focus+.suggestions-dropdown{border-color:#3b82f680}.suggestion-item{animation:fadeInUp .1s ease-out;animation-fill-mode:both}.suggestion-item:nth-child(1){animation-delay:0ms}.suggestion-item:nth-child(2){animation-delay:20ms}.suggestion-item:nth-child(3){animation-delay:40ms}.suggestion-item:nth-child(4){animation-delay:60ms}.suggestion-item:nth-child(5){animation-delay:80ms}.suggestion-item:nth-child(6){animation-delay:.1s}.suggestion-item:nth-child(7){animation-delay:.12s}.suggestion-item:nth-child(8){animation-delay:.14s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-blue: #3b82f6;--primary-blue-dark: #2563eb;--primary-blue-light: #60a5fa;--secondary-gray: #64748b;--success-green: #10b981;--warning-orange: #f59e0b;--error-red: #ef4444;--background-light: #f8fafc;--background-white: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1)}html{font-size:16px;line-height:1.6}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;padding:20px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes bounceIn{0%,20%,40%,60%,80%{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.fade-in{animation:fadeIn .5s ease-out}.slide-in{animation:slideIn .3s ease-out}.bounce-in{animation:bounceIn .6s ease-out}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid var(--primary-blue);outline-offset:2px}@media (max-width: 768px){html{font-size:14px}#root{padding:10px}}@media (max-width: 480px){html{font-size:13px}#root{padding:5px}}
