@import url(https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{cursor:pointer}button:focus{outline:none}:root{--primary-color:#4a6fa5;--secondary-color:#4d9de0;--accent-color:#56ccf2;--text-primary:#333;--text-secondary:#666;--background-primary:#f5f7fa;--background-secondary:#e9ecef;--border-color:#dee2e6;--success-color:#28a745;--error-color:#dc3545;--warning-color:#ffc107;--card-shadow:0 4px 6px #0000001a;--transition-speed:0.3s}[data-theme=dark]{--primary-color:#4a6fa5;--secondary-color:#3a7bd5;--accent-color:#56ccf2;--text-primary:#f5f5f5;--text-secondary:#adb5bd;--background-primary:#1a1a2e;--background-secondary:#16213e;--border-color:#374151;--card-shadow:0 4px 6px #0000004d}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f7fa;background-color:var(--background-primary);color:#333;color:var(--text-primary);font-family:Roboto,Segoe UI,Arial,sans-serif;line-height:1.6;transition:background-color .3s ease;transition:background-color var(--transition-speed) ease}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{align-items:center;background-color:#4a6fa5;background-color:var(--primary-color);box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:1rem 2rem}.app-header h1{font-size:1.8rem;font-weight:600}.app-content{flex:1 1;margin:0 auto;max-width:1200px;padding:2rem;width:100%}.app-footer{background-color:#e9ecef;background-color:var(--background-secondary);border-top:1px solid #dee2e6;border-top:1px solid var(--border-color);color:#666;color:var(--text-secondary);margin-top:auto;padding:1.5rem;text-align:center}@media (max-width:768px){.app-content,.app-header{padding:1rem}}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.card{background-color:#e9ecef;background-color:var(--background-secondary);border-radius:8px;box-shadow:0 4px 6px #0000001a;box-shadow:var(--card-shadow);margin-bottom:1.5rem;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.card:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-5px)}.search-container{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.search-form{display:flex;width:100%}.search-input{background-color:var(--background-secondary);border:2px solid var(--border-color);border-radius:8px 0 0 8px;border-right:none;color:var(--text-primary);flex:1 1;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color var(--transition-speed) ease}.search-input:focus{border-color:var(--accent-color)}.search-button{align-items:center;background-color:var(--primary-color);border:none;border-radius:0 8px 8px 0;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;justify-content:center;padding:.75rem 1.5rem;transition:background-color var(--transition-speed) ease}.search-button:hover{background-color:var(--secondary-color)}.search-icon{font-size:1.25rem;margin-right:.5rem}.location-button{align-items:center;background-color:var(--background-secondary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-size:1rem;font-weight:500;justify-content:center;padding:.75rem 1.5rem;transition:all var(--transition-speed) ease}.location-button:hover{background-color:var(--border-color)}.location-icon{font-size:1.25rem;margin-right:.5rem}.recent-searches{margin-top:1rem;width:100%}.recent-title{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem}.recent-list{display:flex;flex-wrap:wrap;gap:.5rem}.recent-item{background-color:var(--background-secondary);border:1px solid var(--border-color);border-radius:20px;color:var(--text-primary);cursor:pointer;font-size:.9rem;padding:.4rem .8rem;transition:all var(--transition-speed) ease}.recent-item:hover{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}@media (min-width:768px){.search-container{flex-direction:row;flex-wrap:wrap}.search-form{flex:2 1}.location-button{flex:1 1;margin-left:1rem}.recent-searches{flex-basis:100%}}@media (max-width:576px){.location-text,.search-text{display:none}.location-icon,.search-icon{margin-right:0}.location-button,.search-button{padding:.75rem}}.current-weather{background-color:var(--background-secondary);border-radius:12px;box-shadow:var(--card-shadow);margin-bottom:2rem;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.current-weather:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-5px)}.current-weather-header{background-color:var(--primary-color);border-radius:12px 12px 0 0;color:#fff;padding:1.5rem}.location{font-size:1.6rem;font-weight:600;margin-bottom:.5rem}.date{font-size:1rem;opacity:.9}.current-weather-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr;padding:2rem}@media (min-width:768px){.current-weather-content{grid-template-columns:1fr 1fr}.sun-times{grid-column:1/-1}}.weather-main{align-items:center;display:flex;flex-direction:column;text-align:center}.weather-icon{height:100px;margin-bottom:1rem;width:100px}.temperature-container{margin-bottom:.5rem}.temperature{color:var(--primary-color);font-size:3rem;font-weight:700}.temperature-fahrenheit{color:var(--text-secondary);font-size:1.5rem;margin-left:.5rem}.weather-description{text-align:center}.description{font-size:1.25rem;font-weight:500;margin-bottom:.5rem;text-transform:capitalize}.feels-like{color:var(--text-secondary);font-size:1rem}.weather-details{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.detail-item{display:flex;flex-direction:column}.detail-label{color:var(--text-secondary);font-size:.875rem;margin-bottom:.25rem}.detail-value{font-size:1.25rem;font-weight:500}.sun-times{background-color:#4a6fa51a;border-radius:8px;display:flex;justify-content:space-around;padding:1.5rem}.sun-item{align-items:center;display:flex}.sun-icon{font-size:2rem;margin-right:1rem}.sun-info{display:flex;flex-direction:column}.sun-label{color:var(--text-secondary);font-size:.875rem}.sun-time{font-size:1.25rem;font-weight:500}.forecast-container{margin-top:2rem}.forecast-title{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.forecast-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.forecast-card{align-items:center;background-color:var(--background-secondary);border-radius:12px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;padding:1.5rem;transition:transform .3s ease,box-shadow .3s ease}.forecast-card:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-5px)}.forecast-day{margin-bottom:1rem;text-align:center}.forecast-day h3{font-size:1.25rem;font-weight:600;margin-bottom:.25rem;text-transform:capitalize}.forecast-date{color:var(--text-secondary);font-size:.875rem}.forecast-icon{align-items:center;display:flex;flex-direction:column;margin-bottom:1rem}.forecast-icon img{height:64px;width:64px}.forecast-description{color:var(--text-secondary);font-size:.875rem;text-align:center;text-transform:capitalize}.forecast-temps{display:flex;justify-content:space-between;margin-bottom:1.5rem;width:100%}.temp-max,.temp-min{align-items:center;display:flex;flex-direction:column}.temp-label{color:var(--text-secondary);font-size:.75rem;margin-bottom:.25rem}.temp-value{font-size:1.25rem;font-weight:600}.temp-max .temp-value{color:var(--error-color)}.temp-min .temp-value{color:var(--accent-color)}.forecast-details-toggle{background-color:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;padding:.75rem 1rem;text-align:center;transition:background-color .3s ease;width:100%}.forecast-details-toggle:hover{background-color:var(--secondary-color)}.forecast-hourly-container{height:0;margin-top:1rem;overflow:hidden;transition:height .3s ease;width:100%}.forecast-card.expanded .forecast-hourly-container{height:150px}.forecast-hourly-scroll{-webkit-overflow-scrolling:touch;display:flex;overflow-x:auto;padding:.5rem 0;scrollbar-color:var(--primary-color) var(--background-secondary);scrollbar-width:thin}.forecast-hourly-scroll::-webkit-scrollbar{height:6px}.forecast-hourly-scroll::-webkit-scrollbar-track{background:var(--background-secondary)}.forecast-hourly-scroll::-webkit-scrollbar-thumb{background-color:var(--primary-color);border-radius:3px}.forecast-hourly-item{align-items:center;border-right:1px solid var(--border-color);display:flex;flex:0 0 auto;flex-direction:column;min-width:60px;padding:.5rem}.forecast-hourly-item:last-child{border-right:none}.hourly-time{color:var(--text-secondary);font-size:.75rem;margin-bottom:.5rem}.hourly-icon{height:32px;margin-bottom:.5rem;width:32px}.hourly-temp{font-size:.875rem;font-weight:600;margin-bottom:.25rem}.hourly-humidity,.hourly-wind{align-items:center;color:var(--text-secondary);display:flex;font-size:.75rem;margin-top:.25rem}@media (max-width:768px){.forecast-cards{grid-template-columns:1fr}}.theme-toggle{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;transition:background-color .3s ease,transform .3s ease;width:40px}.theme-toggle:hover{background-color:#fff3;transform:rotate(15deg)}.theme-toggle:focus{box-shadow:0 0 0 2px #ffffff80;outline:none}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:3rem 0}.loading-spinner{animation:spin 1s linear infinite;border:5px solid var(--background-secondary);border-radius:50%;border-top-color:var(--primary-color);height:50px;width:50px}.loading-text{color:var(--text-secondary);font-size:1rem;margin-top:1rem}@keyframes spin{to{transform:rotate(1turn)}}.error-container{align-items:center;background-color:var(--background-secondary);border-radius:12px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;justify-content:center;padding:3rem 2rem;text-align:center}.error-icon{font-size:3rem;margin-bottom:1rem}.error-message{color:var(--error-color);font-size:1.25rem;font-weight:600;margin-bottom:1rem}.error-help{color:var(--text-secondary);font-size:1rem}.api-usage-warning{bottom:0;font-size:.9rem;left:0;padding:.5rem 1rem;position:fixed;right:0;transition:all .3s ease;z-index:1000}.api-usage-warning.low{background-color:#fff3cdf2;border-top:1px solid #ffeeba;color:#856404}.api-usage-warning.medium{background-color:#ffe0c7f2;border-top:1px solid #ffd8b2;color:#8a5d3b}.api-usage-warning.high{background-color:#f8d7daf2;border-top:1px solid #f5c6cb;color:#721c24}.warning-content{align-items:center;display:flex;margin:0 auto;max-width:1200px;position:relative}.warning-icon{flex-shrink:0;font-size:1.5rem;margin-right:1rem}.warning-text{flex:1 1}.warning-text p{margin:.25rem 0}.close-button{background:none;border:none;color:inherit;cursor:pointer;font-size:1.5rem;margin-left:1rem;opacity:.7;padding:0;transition:opacity .2s ease}.close-button:hover{opacity:1}@media (max-width:768px){.api-usage-warning{font-size:.8rem}.warning-icon{font-size:1.2rem;margin-right:.5rem}}
/*# sourceMappingURL=main.501ae78f.css.map*/