:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{width:100%;margin:0 auto}html{font-size:.9rem}.section{display:flex;flex-direction:column;gap:1rem}.section-title{color:var(--white);font-size:1.25rem;font-weight:600;padding:0 .25rem}@media (min-width: 768px){.section-title{font-size:1.5rem}}.weather-footer{text-align:center;color:var(--blue-300);padding:1.5rem 0}@media (min-width: 768px){.weather-footer{padding:2rem 0}}.weather-footer-main{font-size:.875rem}@media (min-width: 768px){.weather-footer-main{font-size:1rem}}.weather-footer-attribution{font-size:.75rem;color:var(--blue-300);margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(29,78,216,.2)}@media (min-width: 768px){.weather-footer-attribution{font-size:.875rem;margin-top:1rem;padding-top:1rem}}.weather-footer-link{color:var(--blue-400);text-decoration:none;font-weight:500;transition:all .3s ease;position:relative}.weather-footer-link:hover{color:var(--white);text-shadow:0 0 8px rgba(96,165,250,.6)}.weather-footer-link:focus{outline:none;color:var(--white);text-shadow:0 0 8px rgba(96,165,250,.6)}.weather-footer-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:linear-gradient(90deg,var(--blue-400) 0%,var(--blue-300) 100%);transition:width .3s ease}.weather-footer-link:hover:after{width:100%}.weather-footer-update{font-size:.75rem;color:var(--blue-400);margin-top:.5rem}@media (min-width: 768px){.weather-footer-update{font-size:.875rem}}@media (max-width: 639px){.hidden-sm{display:none}}@media (min-width: 640px){.block-sm{display:block}.inline-sm{display:inline}}:root{--primary-blue: #1e3a8a;--secondary-blue: #1e40af;--dark-blue: #1f2937;--indigo-dark: #312e81;--blue-900: #1e3a8a;--blue-800: #1e40af;--blue-700: #1d4ed8;--blue-600: #2563eb;--blue-500: #3b82f6;--blue-400: #60a5fa;--blue-300: #93c5fd;--blue-200: #bfdbfe;--indigo-950: #1e1b4b;--indigo-900: #312e81;--indigo-800: #3730a3;--cyan-400: #22d3ee;--purple-400: #a78bfa;--orange-300: #fdba74;--orange-400: #fb923c;--yellow-300: #fcd34d;--green-400: #4ade80;--red-400: #f87171;--slate-900: #0f172a;--white: #ffffff;--white-10: rgba(255, 255, 255, .1);--white-5: rgba(255, 255, 255, .05)}.weather-app{min-height:100vh;background:linear-gradient(135deg,var(--slate-900) 0%,var(--blue-900) 50%,var(--indigo-950) 100%);position:relative}.weather-app:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(120,119,198,.1) 0%,transparent 70%);pointer-events:none}.container{position:relative;z-index:10;max-width:1200px;margin:0 auto;padding:1rem;display:flex;flex-direction:column;gap:1.5rem}@media (min-width: 768px){.container{padding:1.5rem;gap:2rem}}@media (min-width: 1024px){.container{padding:2rem}}.city-search{position:relative;overflow:hidden;border-radius:1rem;background:linear-gradient(90deg,#1e3a8acc,#312e81cc);border:1px solid rgba(29,78,216,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:1rem;box-shadow:0 25px 50px -12px #00000040;color:#fff}@media (min-width: 768px){.city-search{border-radius:1.5rem;padding:1.5rem}}.city-search-overlay{position:absolute;inset:0;background:var(--white-5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.city-search-content{position:relative;z-index:10}.city-search-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.city-search-header svg{height:1.25rem;width:1.25rem;color:var(--blue-300)}@media (min-width: 768px){.city-search-header svg{height:1.5rem;width:1.5rem}}.city-search-title{color:var(--white);font-weight:600;font-size:1.125rem}@media (min-width: 768px){.city-search-title{font-size:1.25rem}}.city-search-form{display:flex;flex-direction:column;gap:.75rem;width:100%}@media (min-width: 640px) and (max-width: 767px){.city-search-form{flex-direction:row;gap:.5rem;align-items:stretch}.city-search-button{padding:0 1rem;min-width:auto}.city-search-button-text{display:none}}@media (min-width: 768px){.city-search-form{flex-direction:row;gap:.5rem;align-items:stretch}}@media (max-width: 480px){.city-search{padding:.75rem;margin:0 .5rem}.city-search-input{height:2.75rem;padding:0 .75rem;font-size:.9rem}.city-search-button{height:2.75rem;padding:0 1rem;font-size:.9rem}.city-search-button svg{height:.875rem;width:.875rem}}.city-search-input-container{position:relative;flex:1;min-width:0}.city-search-input{width:100%;height:3rem;padding:0 1rem;background:#1e40af4d;border:1px solid rgba(37,99,235,.5);color:var(--white);border-radius:.75rem;font-size:1rem;transition:all .3s ease;box-sizing:border-box}@media (min-width: 768px){.city-search-input{height:3.5rem;padding:0 1.5rem;border-radius:1rem}}.city-search-input::placeholder{color:var(--blue-300)}.city-search-input:focus{outline:none;box-shadow:0 0 0 2px #60a5fa;border-color:transparent}.city-search-input-overlay{position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,var(--white-5) 50%,transparent 100%);border-radius:.75rem;pointer-events:none}@media (min-width: 768px){.city-search-input-overlay{border-radius:1rem}}.city-search-button{height:3rem;padding:0 1.5rem;background:linear-gradient(90deg,var(--blue-600) 0%,var(--blue-700) 100%);color:var(--white);border:none;border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;font-weight:500;flex-shrink:0;white-space:nowrap}@media (min-width: 768px){.city-search-button{height:3.5rem;padding:0 2rem;border-radius:1rem}}.city-search-button:hover{background:linear-gradient(90deg,#3b82f6 0%,var(--blue-600) 100%);box-shadow:0 20px 25px -5px #0000001a;transform:scale(1.05)}.city-search-button svg{height:1rem;width:1rem}@media (min-width: 768px){.city-search-button svg{height:1.25rem;width:1.25rem}}.city-search-button-text{display:none}@media (min-width: 640px){.city-search-button-text{display:inline}}.city-search-example{color:var(--blue-300);font-size:.75rem;margin-top:.75rem;opacity:.8}@media (min-width: 768px){.city-search-example{font-size:.875rem}}.weather-header{position:relative;overflow:hidden;border-radius:1rem;background:linear-gradient(135deg,var(--blue-900) 0%,var(--blue-800) 50%,var(--indigo-900) 100%);padding:1rem;color:var(--white);box-shadow:0 25px 50px -12px #00000040}@media (min-width: 768px){.weather-header{border-radius:1.5rem;padding:1.5rem}}@media (min-width: 1024px){.weather-header{padding:2rem}}.weather-header-bg{position:absolute;inset:0;opacity:.2}.weather-header-bg img{height:100%;width:100%;object-fit:cover}.weather-header-overlay{position:absolute;inset:0;background:var(--white-10);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.weather-header-content{position:relative;z-index:10}.weather-header-top{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}@media (min-width: 640px){.weather-header-top{flex-direction:row;align-items:center;justify-content:space-between}}@media (min-width: 768px){.weather-header-top{margin-bottom:1.5rem}}.weather-header-title{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}@media (min-width: 768px){.weather-header-title{font-size:1.875rem;margin-bottom:.5rem}}.weather-header-date{color:var(--blue-200);font-size:.875rem}@media (min-width: 768px){.weather-header-date{font-size:1rem}}.weather-header-status{display:flex;align-items:center;gap:.5rem}.weather-header-status svg{height:1.5rem;width:1.5rem;color:var(--yellow-300)}@media (min-width: 768px){.weather-header-status svg{height:2rem;width:2rem}}.weather-header-status-text{font-size:.875rem}@media (min-width: 768px){.weather-header-status-text{font-size:1.125rem}}.weather-header-main{display:flex;flex-direction:column;gap:1rem}@media (min-width: 640px){.weather-header-main{flex-direction:row;align-items:center;gap:2rem}}.weather-header-temp{display:flex;align-items:center;gap:.5rem}.weather-header-temp svg{height:2rem;width:2rem;color:var(--orange-300)}@media (min-width: 768px){.weather-header-temp svg{height:3rem;width:3rem}}.weather-header-temp-value{font-size:2.5rem;font-weight:300}@media (min-width: 768px){.weather-header-temp-value{font-size:3.75rem}}.weather-header-temp-unit{font-size:1.125rem;color:var(--blue-200);margin-left:.5rem}@media (min-width: 768px){.weather-header-temp-unit{font-size:1.5rem}}.weather-header-details{display:flex;flex-direction:column;gap:.25rem}@media (min-width: 768px){.weather-header-details{gap:.5rem}}.weather-header-detail{display:flex;flex-direction:column;gap:0}@media (min-width: 640px){.weather-header-detail{flex-direction:row;align-items:center;gap:.5rem}}.weather-header-detail-label{color:var(--blue-200);font-size:.875rem}@media (min-width: 768px){.weather-header-detail-label{font-size:1rem}}.weather-header-detail-value{font-size:.875rem}@media (min-width: 768px){.weather-header-detail-value{font-size:1rem}}.weather-details{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media (min-width: 768px){.weather-details{grid-template-columns:repeat(4,1fr);gap:1rem}}.weather-detail-card{padding:.75rem 1rem;background:linear-gradient(135deg,#1e3a8acc,#312e81cc);border:1px solid rgba(29,78,216,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:.75rem}@media (min-width: 768px){.weather-detail-card{padding:1rem 1.5rem;border-radius:1rem}}.weather-detail-content{display:flex;flex-direction:column;gap:.5rem}@media (min-width: 640px){.weather-detail-content{flex-direction:row;align-items:center;gap:.75rem}}.weather-detail-icon{height:1.5rem;width:1.5rem;margin:0 auto}@media (min-width: 640px){.weather-detail-icon{margin:0}}@media (min-width: 768px){.weather-detail-icon{height:2rem;width:2rem}}.weather-detail-icon.cyan{color:var(--cyan-400)}.weather-detail-icon.blue{color:var(--blue-400)}.weather-detail-icon.indigo{color:#a78bfa}.weather-detail-icon.purple{color:var(--purple-400)}.weather-detail-info{text-align:center}@media (min-width: 640px){.weather-detail-info{text-align:left}}.weather-detail-label{color:var(--blue-200);font-size:.75rem}@media (min-width: 768px){.weather-detail-label{font-size:.875rem}}.weather-detail-value{color:var(--white);font-weight:600;font-size:.875rem}@media (min-width: 768px){.weather-detail-value{font-size:1.125rem}}.hourly-forecast{padding:1rem;margin-top:1rem;background:linear-gradient(90deg,#1e3a8acc,#312e81cc);border:1px solid rgba(29,78,216,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:.75rem}@media (min-width: 768px){.hourly-forecast{padding:1.5rem;margin-top:1.5rem;border-radius:1rem}}.hourly-forecast-title{color:var(--white);font-size:1.125rem;font-weight:600;margin-bottom:1rem}@media (min-width: 768px){.hourly-forecast-title{font-size:1.25rem}}.hourly-forecast-scroll{width:100%;white-space:nowrap;overflow-x:auto;scrollbar-width:thin;scrollbar-color:rgba(59,130,246,.5) transparent}.hourly-forecast-scroll::-webkit-scrollbar{height:6px}.hourly-forecast-scroll::-webkit-scrollbar-track{background:transparent}.hourly-forecast-scroll::-webkit-scrollbar-thumb{background:#3b82f680;border-radius:3px}.hourly-forecast-container{display:flex;gap:.75rem;padding-bottom:.5rem}@media (min-width: 768px){.hourly-forecast-container{gap:1rem}}.hourly-forecast-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:70px;padding:.5rem;border-radius:.5rem;background:#1e40af4d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@media (min-width: 768px){.hourly-forecast-item{min-width:80px;padding:.75rem;border-radius:.75rem}}.hourly-forecast-date{color:var(--blue-400);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;margin-bottom:.125rem}@media (min-width: 768px){.hourly-forecast-date{font-size:.75rem}}.hourly-forecast-time{color:var(--blue-200);font-size:.75rem}@media (min-width: 768px){.hourly-forecast-time{font-size:.875rem}}.hourly-forecast-icon{height:1.25rem;width:1.25rem;color:var(--yellow-300)}@media (min-width: 768px){.hourly-forecast-icon{height:1.5rem;width:1.5rem}}.hourly-forecast-temp{color:var(--white);font-weight:600;font-size:.875rem}@media (min-width: 768px){.hourly-forecast-temp{font-size:1rem}}.hourly-forecast-desc{color:var(--blue-300);font-size:.75rem;text-align:center;display:none}@media (min-width: 640px){.hourly-forecast-desc{display:block}}.activities-section{display:flex;flex-direction:column;gap:1.5rem}.activities-title{color:var(--white);font-size:1.25rem;font-weight:600}@media (min-width: 768px){.activities-title{font-size:1.5rem}}.activities-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 640px){.activities-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.activities-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem}}.activity-card{position:relative;overflow:hidden;border-radius:1rem;background:linear-gradient(135deg,#1e3a8acc,#312e81cc);border:1px solid rgba(29,78,216,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:1rem;transition:transform .3s ease}@media (min-width: 768px){.activity-card{padding:1.5rem}}.activity-card:hover{transform:scale(1.05)}.activity-card-bg{position:absolute;inset:0;opacity:.15}.activity-card-bg img{height:100%;width:100%;object-fit:cover}.activity-card-overlay{position:absolute;inset:0;opacity:.2}.activity-card-overlay.green{background:linear-gradient(to top,#10b981,#059669)}.activity-card-overlay.orange{background:linear-gradient(to top,#f97316,#dc2626)}.activity-card-overlay.blue{background:linear-gradient(to top,#3b82f6,#8b5cf6)}.activity-card-overlay.cyan{background:linear-gradient(to top,#06b6d4,#0d9488)}.activity-card-content{position:relative;z-index:10}.activity-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.activity-card-icon{height:1.25rem;width:1.25rem;color:var(--blue-300)}@media (min-width: 768px){.activity-card-icon{height:1.5rem;width:1.5rem}}.activity-card-title{color:var(--white);font-weight:600;font-size:.875rem}@media (min-width: 768px){.activity-card-title{font-size:1rem}}.activity-card-description{color:var(--blue-200);font-size:.75rem;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@media (min-width: 768px){.activity-card-description{font-size:.875rem}}.activity-card-details{display:flex;flex-direction:column;gap:.5rem}.activity-card-detail{display:flex;align-items:center;gap:.5rem}.activity-card-detail svg{height:.75rem;width:.75rem}@media (min-width: 768px){.activity-card-detail svg{height:1rem;width:1rem}}.activity-card-detail svg.temp{color:var(--orange-400)}.activity-card-detail svg.clock{color:var(--blue-400)}.activity-card-detail-text{color:var(--white);font-size:.75rem}@media (min-width: 768px){.activity-card-detail-text{font-size:.875rem}}.activity-card-detail-text.secondary{color:var(--blue-200)}.activity-card-footer{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(29,78,216,.3)}.activity-card-footer-content{display:flex;align-items:center;justify-content:space-between}.activity-card-difficulty{color:var(--blue-300);font-size:.75rem}.activity-card-badge{padding:.25rem .5rem;background:#1e40af66;border-radius:9999px}.activity-card-badge-text{color:#4ade80;font-size:.75rem}.activity-card-reason{color:var(--blue-300);font-size:.75rem;margin-top:.75rem;font-style:italic}.weather-cards{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 768px){.weather-cards{grid-template-columns:repeat(3,1fr);gap:1.5rem}}.weather-info-card{position:relative;overflow:hidden;border-radius:.75rem;background:linear-gradient(135deg,#1e3a8acc,#312e81cc);border:1px solid rgba(29,78,216,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:1rem}@media (min-width: 768px){.weather-info-card{border-radius:1rem;padding:1.5rem}}.weather-info-card-bg{position:absolute;inset:0;opacity:.1}.weather-info-card-bg img{height:100%;width:100%;object-fit:cover}.weather-info-card-content{position:relative;z-index:10}.weather-info-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.weather-info-card-icon{height:1.25rem;width:1.25rem;color:var(--blue-300)}@media (min-width: 768px){.weather-info-card-icon{height:1.5rem;width:1.5rem}}.weather-info-card-title{color:var(--white);font-weight:600;font-size:.875rem}@media (min-width: 768px){.weather-info-card-title{font-size:1rem}}.sun-times{display:flex;flex-direction:column;gap:.75rem}.sun-time{display:flex;align-items:center;justify-content:space-between}.sun-time-label{display:flex;align-items:center;gap:.5rem}.sun-time-label svg{height:1rem;width:1rem}@media (min-width: 768px){.sun-time-label svg{height:1.25rem;width:1.25rem}}.sun-time-label svg.sunrise,.sunrise{color:var(--orange-400)}.sun-time-label svg.sunset,.sunset{color:var(--red-400)}.sun-time-label-text{color:var(--blue-200);font-size:.875rem}@media (min-width: 768px){.sun-time-label-text{font-size:1rem}}.sun-time-value{color:var(--white);font-weight:600;font-size:.875rem}@media (min-width: 768px){.sun-time-value{font-size:1rem}}.air-quality{display:flex;flex-direction:column;gap:.75rem}.air-quality-main{display:flex;align-items:center;justify-content:space-between}.air-quality-label{color:var(--blue-200);font-size:.875rem}@media (min-width: 768px){.air-quality-label{font-size:1rem}}.air-quality-value{color:var(--green-400);font-weight:600;font-size:.875rem}@media (min-width: 768px){.air-quality-value{font-size:1rem}}.air-quality-details{display:flex;flex-direction:column;gap:.5rem}.air-quality-detail{display:flex;justify-content:space-between;font-size:.75rem}@media (min-width: 768px){.air-quality-detail{font-size:.875rem}}.air-quality-detail-label{color:var(--blue-300)}.air-quality-detail-value{color:var(--white)}.cloudiness{display:flex;flex-direction:column;gap:.75rem}.cloudiness-main{text-align:center}.cloudiness-value{font-size:1.5rem;font-weight:700;color:var(--blue-400);margin-bottom:.5rem}@media (min-width: 768px){.cloudiness-value{font-size:1.875rem}}.cloudiness-level{color:var(--blue-300);font-weight:600;font-size:.875rem}@media (min-width: 768px){.cloudiness-level{font-size:1rem}}.cloudiness-details{display:flex;flex-direction:column;gap:.5rem}.cloudiness-advice{color:var(--blue-200);font-size:.75rem}@media (min-width: 768px){.cloudiness-advice{font-size:.875rem}}.cloudiness-bar{background:linear-gradient(90deg,var(--blue-600) 0%,var(--blue-400) 25%,var(--blue-300) 50%,rgba(255,255,255,.3) 100%);height:.5rem;border-radius:9999px;position:relative}.cloudiness-indicator{height:100%;background:linear-gradient(90deg,#fff3,#fff6);position:relative;border-radius:9999px;transition:width .3s ease}.cloudiness-pointer{position:absolute;right:0;top:50%;width:.5rem;height:.5rem;background:var(--white);border:2px solid var(--blue-400);border-radius:50%;transform:translate(50%,-50%);box-shadow:0 2px 4px #0003}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.loading-spinner{width:50px;height:50px;border:4px solid var(--white-10);border-top:4px solid var(--blue-400);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:var(--blue-300);font-size:1rem;font-weight:500}.not-found-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;background:var(--white-5);border-radius:16px;border:1px solid var(--white-10);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin:1rem 0}.not-found-icon{font-size:4rem;margin-bottom:1rem;opacity:.8}.not-found-container h3{color:var(--white);font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.not-found-container p{color:var(--blue-300);font-size:1rem;line-height:1.5;max-width:400px}@media (min-width: 768px){.not-found-container{padding:4rem 2rem}.not-found-icon{font-size:5rem}.not-found-container h3{font-size:1.75rem}.not-found-container p{font-size:1.125rem}}
