@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,300;0,500;0,600;1,600;0,700&family=Bricolage+Grotesque:wght@700&display=swap";:root{--neutral-900: hsl(243, 96%, 9%);--neutral-800: hsl(243, 27%, 20%);--neutral-700: hsl(243, 23%, 24%);--neutral-600: hsl(243, 23%, 30%);--neutral-300: hsl(240, 6%, 70%);--neutral-200: hsl(250, 6%, 84%);--neutral-0: hsl(0, 0%, 100%);--orange-500: hsl(28, 100%, 52%);--blue-500: hsl(233, 67%, 56%);--blue-700: hsl(248, 70%, 36%);--font-primary: "DM Sans", sans-serif;--font-secondary: "Bricolage Grotesque", sans-serif;--font-size-base: 18px;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--radius-sm: .5rem;--radius-md: 1rem;--radius-lg: 1.5rem;--transition-fast: .2s ease;--transition-normal: .3s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:var(--font-primary);font-size:var(--font-size-base);font-weight:300;line-height:1.6;color:var(--neutral-0);background-color:var(--neutral-900);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2}h1{font-size:2rem;font-family:var(--font-secondary)}h2{font-size:1.5rem}h3{font-size:1.25rem}button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit}input{font-family:inherit;border:none;background:none;color:inherit}input:focus{outline:none}ul,ol{list-style:none}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}.container{width:100%;max-width:1440px;margin:0 auto;padding:0 var(--spacing-sm)}.visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (min-width: 768px){:root{--font-size-base: 18px}h1{font-size:3rem}h2{font-size:2rem}h3{font-size:1.5rem}}@media (min-width: 768px){.container{padding:0 var(--spacing-lg)}}@media (min-width: 1024px){.container{padding:0 var(--spacing-xl)}}.logo{display:flex;align-items:center;gap:var(--spacing-sm)}.logo__icon{width:170px}@media (min-width: 768px){.logo__icon{width:auto}}.dropdown{position:relative}.dropdown__trigger{display:flex;align-items:center;gap:var(--spacing-xs);padding:.75rem 1rem;background-color:var(--neutral-800);border-radius:var(--radius-sm);transition:all var(--transition-normal);cursor:pointer}.dropdown__trigger:hover{background-color:var(--neutral-700)}.dropdown__trigger:focus{outline:2px solid var(--blue-500);outline-offset:2px}.dropdown__icon{width:20px;height:20px}.dropdown__label{font-size:.875rem;font-weight:500;color:var(--neutral-0)}.dropdown__arrow{width:12px;height:12px;transition:transform var(--transition-normal)}.dropdown__arrow--open{transform:rotate(180deg)}.dropdown__menu{position:absolute;top:calc(100% + .5rem);right:0;min-width:220px;background-color:var(--neutral-800);border-radius:var(--radius-sm);padding:var(--spacing-sm);box-shadow:0 8px 24px #0000004d;z-index:100}.dropdown__header{width:100%;font-size:.875rem;font-weight:600;color:var(--neutral-0);padding:.5rem .75rem;margin-bottom:var(--spacing-xs);text-align:left;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);cursor:pointer}.dropdown__header:hover{background-color:var(--neutral-700)}.dropdown__section{margin-bottom:var(--spacing-sm)}.dropdown__section:last-child{margin-bottom:0}.dropdown__section-title{font-size:.75rem;font-weight:600;color:var(--neutral-400);padding:.5rem .75rem .25rem;text-transform:capitalize}.dropdown__section-list{list-style:none;padding:0;margin:0}.dropdown__item{width:100%;padding:.625rem .75rem;text-align:left;border-radius:var(--radius-sm);font-size:.875rem;transition:all var(--transition-fast);cursor:pointer;display:flex;align-items:center;justify-content:space-between;color:var(--neutral-0)}.dropdown__item:hover{background-color:var(--neutral-700)}.dropdown__item--active{color:var(--neutral-0)}.dropdown__checkmark{width:16px;height:16px;color:var(--neutral-0);flex-shrink:0}.header{padding:var(--spacing-md) 0;background-color:var(--neutral-900)}.header__content{display:flex;justify-content:space-between;align-items:center}@media (min-width: 768px){.header{padding:var(--spacing-lg) 0}}.input-wrapper{position:relative;display:flex;align-items:center;width:100%}.input-icon{position:absolute;left:1rem;display:flex;align-items:center;pointer-events:none;opacity:.6}.input{width:100%;padding:.875rem 1rem .875rem 3rem;background-color:var(--neutral-800);color:var(--neutral-0);border-radius:var(--radius-sm);font-size:1rem;transition:all var(--transition-normal)}.input::placeholder{color:var(--neutral-300);opacity:.7}.input:hover{background-color:var(--neutral-700)}.input:focus{background-color:var(--neutral-700);outline:2px solid var(--blue-500);outline-offset:2px}.btn{padding:.875rem 2rem;border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:1.1rem;transition:all var(--transition-normal);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.btn--primary{background-color:var(--blue-500);color:var(--neutral-0)}.btn--primary:hover{background-color:var(--blue-700);transform:translateY(-2px);box-shadow:0 4px 12px #6373ff4d}.btn--primary:focus{outline:2px solid var(--blue-500);outline-offset:2px}.btn--secondary{background-color:var(--neutral-700);color:var(--neutral-0)}.btn--secondary:hover{background-color:var(--neutral-600)}.btn--secondary:focus{outline:2px solid var(--neutral-600);outline-offset:2px}.search-bar-wrapper{position:relative;width:100%;max-width:700px;margin:auto}.search-bar{display:flex;flex-direction:column;gap:var(--spacing-sm);width:100%}.search-bar__input{flex:1}.search-bar__suggestions{position:absolute;top:100%;left:0;right:0;background:var(--neutral-800);border-radius:var(--radius-md);box-shadow:0 4px 20px #0000004d;list-style:none;padding:0;margin-top:4px;max-height:300px;overflow-y:auto;z-index:1000;animation:slideDown .2s ease-out;border:1px solid var(--neutral-700)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.search-bar__suggestion{padding:12px 16px;cursor:pointer;transition:background-color .2s ease;display:flex;flex-direction:column;gap:4px;border-bottom:1px solid rgba(255,255,255,.05)}.search-bar__suggestion:last-child{border-bottom:none}.search-bar__suggestion:hover,.search-bar__suggestion--selected{background-color:#ffffff0d}.search-bar__suggestion-name{font-weight:600;color:var(--neutral-0);font-size:1rem}.search-bar__suggestion-location{font-size:.875rem;color:var(--neutral-300)}@media (min-width: 768px){.search-bar{flex-direction:row;align-items:center}.search-bar__suggestions{right:auto;width:calc(100% - 120px)}}.current-weather{position:relative;margin:auto;border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-sm);overflow:hidden;margin-bottom:var(--spacing-md)}.current-weather__background{position:absolute;inset:0}.current-weather__bg{width:100%;height:100%;object-fit:cover;object-position:center}.current-weather__bg--desktop{display:none}.current-weather__content{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--spacing-md)}.current-weather__info{flex:1;text-align:center}.current-weather__location{font-size:1.5rem;font-weight:700;color:var(--neutral-0);margin-bottom:var(--spacing-xs)}.current-weather__date{font-size:1rem;color:var(--neutral-200);font-weight:500}.current-weather__weather{display:flex;align-items:center;gap:var(--spacing-md)}.current-weather__icon{width:80px!important;height:80px!important}.current-weather__temp{font-size:3.5rem;font-weight:700;color:var(--neutral-0);font-family:var(--font-secondary);line-height:1}@media (min-width: 768px){.current-weather{padding:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.current-weather__bg--mobile{display:none}.current-weather__bg--desktop{display:block}.current-weather__location{font-size:2rem}.current-weather__date{font-size:1rem}.current-weather__icon{width:120px;height:120px}.current-weather__temp{font-size:6rem}}@media (min-width: 1024px){.current-weather{height:300px}.current-weather__content{flex-direction:row;top:20%}.current-weather__info{text-align:left}}.weather-metric{background-color:var(--neutral-800);padding:var(--spacing-sm);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}@media (min-width: 768px){.weather-metric{padding:var(--spacing-md)}}.weather-metric__label{font-size:.875rem;color:var(--neutral-300);font-weight:500}.weather-metric__value{font-size:1.5rem;font-weight:500;color:var(--neutral-0)}.weather-metric__unit{font-size:1.5rem;margin-left:.25rem}.weather-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}@media (min-width: 768px){.weather-metrics{grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}}.day-forecast{background-color:var(--neutral-800);padding:var(--spacing-sm);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);min-width:90px;transition:all var(--transition-normal);cursor:pointer}@media (min-width: 768px){.day-forecast{gap:var(--spacing-sm)}}.day-forecast:hover{background-color:var(--neutral-700);transform:translateY(-4px)}.day-forecast:focus{outline:2px solid var(--blue-500);outline-offset:2px}.day-forecast--active{background-color:var(--blue-500)}.day-forecast__day{font-size:.875rem;font-weight:600;color:var(--neutral-0)}.day-forecast__temps{display:flex;gap:var(--spacing-xs);font-size:.875rem}.day-forecast__high{font-weight:600;color:var(--neutral-0)}.day-forecast__low{color:var(--neutral-300)}.daily-forecast{margin-bottom:var(--spacing-md)}.daily-forecast__title{font-size:1.125rem;font-weight:700;color:var(--neutral-0);margin-bottom:var(--spacing-sm)}.daily-forecast__list{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:var(--spacing-sm);padding-bottom:var(--spacing-sm)}@media (min-width: 768px){.daily-forecast{margin-bottom:var(--spacing-lg)}.daily-forecast__title{font-size:1.25rem;margin-bottom:var(--spacing-md)}.daily-forecast__list{gap:var(--spacing-md)}}.hourly-forecast{background-color:var(--neutral-700);padding:var(--spacing-sm);border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--spacing-sm);transition:all var(--transition-fast)}@media (min-width: 768px){.hourly-forecast{gap:var(--spacing-md)}}.hourly-forecast:hover{background-color:var(--neutral-600)}.hourly-forecast__time{font-size:.875rem;font-weight:500;color:var(--neutral-0);flex:1}.hourly-forecast__temp{font-size:1rem;font-weight:600;color:var(--neutral-0)}.hourly-forecast-section{background-color:var(--neutral-800);padding:var(--spacing-md);border-radius:var(--radius-lg);max-height:665px;overflow-y:scroll;scrollbar-width:thin;scrollbar-color:var(--neutral-700) var(--neutral-900)}.hourly-forecast-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.hourly-forecast-section__title{font-size:1.125rem;font-weight:700;color:var(--neutral-0)}.hourly-forecast-section__list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.hourly-forecast-section__list::-webkit-scrollbar{width:8px}.hourly-forecast-section__list::-webkit-scrollbar-track{background:var(--neutral-900);border-radius:var(--radius-sm)}.hourly-forecast-section__list::-webkit-scrollbar-thumb{background:var(--neutral-700);border-radius:var(--radius-sm)}.hourly-forecast-section__list::-webkit-scrollbar-thumb:hover{background:var(--neutral-600)}@media (min-width: 768px){.hourly-forecast-section{max-height:725px;padding:var(--spacing-lg)}.hourly-forecast-section__header{margin-bottom:var(--spacing-md)}.hourly-forecast-section__title{font-size:1.25rem}}.weather-page{min-height:100vh;background-color:var(--neutral-900)}.weather-page__main{padding:var(--spacing-md) 0}.weather-page__hero{text-align:center;margin-bottom:var(--spacing-lg)}.weather-page__title{font-size:3.2rem;font-weight:700;max-width:90%;color:var(--neutral-0);margin-left:auto;margin-right:auto;margin-bottom:var(--spacing-lg);font-family:var(--font-secondary);line-height:1.2}.weather-page__content{display:grid;gap:var(--spacing-md)}.weather-page__left,.weather-page__right{width:100%}.weather-page__state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl);text-align:center;min-height:400px}.weather-page__state-icon{width:64px;height:64px;opacity:.8}.weather-page__state-icon--spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.weather-page__state-text{font-size:1.125rem;color:var(--neutral-300)}.weather-page__state--error .weather-page__state-text{color:var(--orange-500)}.weather-page__retry{display:flex;align-items:center;gap:var(--spacing-xs);padding:.875rem 2rem;background-color:var(--blue-500);color:var(--neutral-0);border-radius:var(--radius-sm);font-weight:600;transition:all var(--transition-normal);cursor:pointer}.weather-page__retry:hover{background-color:var(--blue-700);transform:translateY(-2px)}.weather-page__retry:focus{outline:2px solid var(--blue-500);outline-offset:2px}@media (min-width: 768px){.weather-page__main{padding:var(--spacing-xl) 0}.weather-page__title{margin-bottom:var(--spacing-xl)}.weather-page__hero{max-width:900px;margin-left:auto;margin-right:auto;margin-bottom:var(--spacing-xl)}.weather-page__content{grid-template-columns:1fr 420px;gap:var(--spacing-xl);align-items:start}}
