.search-page__search-container{margin-bottom:2rem}.search-page__dropdown{max-width:600px;margin:0 auto}.search-page__search-form{display:flex;align-items:stretch;gap:.5rem;max-width:720px;margin:0 auto}.search-page__submit-btn{white-space:nowrap;height:48px;padding:0 1.25rem;display:inline-flex;align-items:center;gap:.5rem}@media (max-width: 640px){.search-page__search-form{flex-direction:column}.search-page__submit-btn{width:100%;justify-content:center}}.search-page__help-text{margin-top:12px;text-align:center;font-size:14px;color:#6b7280;line-height:1.4}.header__search-dropdown{width:100%}.nav__search-dropdown{width:100%;margin-top:0}.explore-more-btn{transition:all .2s ease-in-out;background:#4f7fff!important;color:#fff;padding:.75rem 1.25rem;font-size:.95rem;max-width:90%;width:fit-content;margin:0 auto}@media (min-width: 640px){.explore-more-btn{padding:.8rem 1.5rem;font-size:1rem}}.explore-more-btn:hover{background:#3b6beb!important;transform:translateY(-1px);box-shadow:0 4px 12px #00000014!important}.explore-more-btn:active{transform:translateY(0);box-shadow:0 2px 8px #0000000a!important}.search-results__current,.search-results__forecast{scroll-margin-top:80px}.header{background:var(--color-background-secondary);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header__container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;height:64px;overflow:hidden}.header--search-active .header__container{overflow:visible}.header__brand{display:flex;align-items:center}.header__logo{display:flex;align-items:center;gap:.5rem;color:var(--color-primary);font-weight:600;font-size:1.25rem;text-decoration:none}.header__brand-text{font-weight:700}.header__search{flex:1;max-width:500px;margin:0 2rem}.search-form{position:relative;display:flex;align-items:center;gap:.5rem}.search-form__input-group{position:relative;display:flex;align-items:center;flex:1}.search-form__icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);z-index:2;cursor:pointer;transition:color .2s ease,transform .2s ease,left .2s ease}.search-form__icon:hover{color:var(--color-primary)}.search-form__input{width:100%;padding:.75rem .75rem .75rem 2.5rem;border:1px solid var(--color-border);border-radius:9999px;background:var(--color-background);color:var(--color-text-primary);font-size:.875rem;transition:all .2s ease;cursor:text}.header .search-form__input{padding-right:2.25rem}.search-form__input::placeholder{color:transparent;transition:color .2s ease}.search-form__input:focus::placeholder,.header--search-active .search-form__input::placeholder{color:var(--color-text-tertiary)}.search-form__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a;outline:none;cursor:text}.search-form__input-group:hover,.search-form__input-group:hover .search-form__input{cursor:pointer}.search-form__input-group:hover .search-form__input:focus{cursor:text}.search-form__input--large{padding:1rem 1rem 1rem 3rem;font-size:1rem}.search-form__submit{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:background-color .2s ease;white-space:nowrap;flex-shrink:0}.search-form__submit:hover{background:var(--color-primary-dark)}.header .search-form__submit{transition:background-color .2s ease;opacity:0;transform:translate(-6px) scale(.98);max-width:0;overflow:hidden;padding-left:0;padding-right:0;pointer-events:none}.header--search-active .search-form__submit{transition:background-color .2s ease,opacity .2s cubic-bezier(.22,1,.36,1),transform .22s cubic-bezier(.22,1,.36,1),max-width .22s cubic-bezier(.22,1,.36,1),padding .2s cubic-bezier(.22,1,.36,1),margin .2s cubic-bezier(.22,1,.36,1);opacity:1;transform:translate(0) scale(1);max-width:200px;padding:.75rem 1rem;pointer-events:auto}.search-form__submit--large{padding:1rem 1.5rem;font-size:1rem}.search-form__clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%) scale(.96);display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--color-text-tertiary);border-radius:9999px;cursor:pointer;z-index:2;opacity:0;pointer-events:none;transition:color .15s ease,background-color .15s ease,opacity .18s ease,transform .18s ease}.search-form__clear:hover{color:var(--color-text-primary);background:var(--color-background-tertiary)}.search-form__clear:focus{outline:none;box-shadow:0 0 0 2px #3b82f640}.header--search-active .search-form__clear{opacity:1;pointer-events:auto;transform:translateY(-50%) scale(1)}.header__nav--desktop{display:flex}.header__nav--mobile{display:none;position:absolute;top:100%;left:0;right:0;background:var(--color-background-secondary);border-bottom:1px solid var(--color-border);padding:1rem}.nav__search{margin:1rem auto 0;width:min(92vw,720px);max-width:720px}.header__nav--mobile .search-form{display:flex;align-items:stretch;gap:.5rem;flex-direction:row}.header__nav--mobile .search-form__icon{left:1rem;transform:translateY(-50%)}.header__nav--mobile .search-form__input{flex:1 1 auto;height:48px;padding:.75rem 2.75rem .75rem 3rem;border:1px solid var(--color-border);border-radius:9999px;background:var(--color-background);box-shadow:0 0 #3b82f626;transition:border-color .18s ease,box-shadow .18s ease}.header__nav--mobile .search-form__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #3b82f626;outline:none}.header__nav--mobile .search-form__submit{opacity:1;transform:none;max-width:none;height:48px;padding:0 1.25rem;pointer-events:auto}.header__nav--mobile .search-form__clear{opacity:1;pointer-events:auto;transform:translateY(-50%) scale(1);right:.75rem}.header__nav--mobile .search-form__input::placeholder{color:var(--color-text-secondary)}.nav__list{display:flex;align-items:center;list-style:none;margin:0;padding:0;gap:.5rem}.nav__list--mobile{flex-direction:column;gap:.5rem}.nav__item{margin:0}.nav__link{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all .2s ease;font-size:.875rem;font-weight:500}.nav__link:hover{background:var(--color-background-tertiary);color:var(--color-text-primary)}.nav__link--active{background:var(--color-primary);color:#fff}.nav__link--active:hover{background:var(--color-primary-dark)}.nav__link-text{display:inline;white-space:nowrap}.header__actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0;transition:transform .22s cubic-bezier(.22,1,.36,1)}.header-weather__link{text-decoration:none}.header-weather{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .5rem;border-radius:9999px;background:var(--color-background);border:1px solid var(--color-border);color:var(--color-text-primary);font-size:.8rem;line-height:1}.header-weather--loading,.header-weather__icon{color:var(--color-text-secondary)}.header-weather__temp{font-weight:700}.header-weather__city{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-weather__sep{color:var(--color-text-tertiary)}.header-weather__dot{width:8px;height:8px;border-radius:999px;background:var(--color-primary);animation:pulse 1s infinite ease-in-out}.header__theme-toggle,.header__menu-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.header__theme-toggle:hover,.header__menu-toggle:hover{background:var(--color-background-tertiary);color:var(--color-text-primary)}.header__menu-toggle{display:none}.footer{background:var(--color-background-secondary);border-top:1px solid var(--color-border);margin-top:auto;padding:2rem 0 1rem}.footer__container{max-width:1200px;margin:0 auto;padding:0 1rem}.footer__content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem}.footer__section-title{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--color-text-primary)}.footer__description,.footer__text{color:var(--color-text-secondary);line-height:1.6;margin-bottom:.5rem}.footer__version{font-size:.75rem;color:var(--color-text-tertiary)}.footer__links{list-style:none;padding:0;margin:0}.footer__link{color:var(--color-text-secondary);text-decoration:none;transition:color .2s ease;font-size:.875rem}.footer__link:hover{color:var(--color-primary)}.footer__external-link{display:inline-flex;align-items:center;gap:.25rem;color:var(--color-primary);text-decoration:none}.footer__social{display:flex;gap:.5rem;margin-top:1rem}.footer__social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);background:var(--color-background-tertiary);color:var(--color-text-secondary);text-decoration:none;transition:all .2s ease}.footer__social-link:hover{background:var(--color-primary);color:#fff}.footer__bottom{border-top:1px solid var(--color-border);padding-top:1rem}.footer__bottom-content{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.footer__copyright{color:var(--color-text-secondary);font-size:.875rem}.footer__heart{color:var(--color-error);display:inline-block;vertical-align:top}.footer__text--small{font-size:.75rem}.footer__version,.footer__bottom-links{display:none}.weather-card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.weather-card:hover{box-shadow:var(--shadow-md)}.weather-card--compact{padding:1rem}.focus-highlight.is-active .weather-card{animation:focus-glow .75s ease-out 1}#integration-summary{scroll-margin-top:80px}@keyframes focus-glow{0%{box-shadow:0 0 0 6px #3b82f603,var(--shadow-sm)}to{box-shadow:var(--shadow-sm)}}.weather-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.weather-card__location{display:flex;align-items:center;gap:.5rem}.weather-card__location-name{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0}.weather-card__country{color:var(--color-text-secondary);font-weight:400}.weather-card__favorite-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:var(--radius-md);background:var(--color-background-secondary);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.weather-card__favorite-btn:hover{background:var(--color-error);color:#fff}.weather-card__favorited{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);color:var(--color-error);background:var(--color-background-secondary)}.weather-card__main{margin-bottom:1.5rem}.weather-card__current{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.weather-card__temperature{display:flex;align-items:center;gap:1rem}.weather-card__temp-value{font-size:3rem;font-weight:700;color:var(--color-text-primary);line-height:1}.weather-card__weather-info{display:flex;flex-direction:column;align-items:center;gap:.25rem}.weather-card__icon{width:64px;height:64px}.weather-card__description{font-size:.875rem;color:var(--color-text-secondary);text-transform:capitalize;text-align:center}.weather-card__feels-like{display:flex;align-items:center;gap:.5rem;color:var(--color-text-secondary);font-size:.875rem}.weather-card__details{margin-bottom:1.5rem}.weather-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.weather-detail{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem;background:var(--color-background-secondary);border-radius:var(--radius-md);text-align:center}.weather-detail__label{font-size:.75rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.weather-detail__value{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.weather-card__sun-times{display:flex;justify-content:space-around;padding:1rem;background:var(--color-background-secondary);border-radius:var(--radius-md);margin-bottom:1rem}.sun-time{display:flex;flex-direction:column;align-items:center;gap:.25rem}.sun-time__label{font-size:.75rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.sun-time__value{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.weather-card__actions{display:flex;justify-content:center}.forecast-card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.forecast-card:hover{box-shadow:var(--shadow-md)}.forecast-card--compact{padding:.75rem}.forecast-card__header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.forecast-card__location-name{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.forecast-card__content{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.forecast-card__weather{display:flex;align-items:center;gap:.5rem}.forecast-card__icon{width:48px;height:48px}.forecast-card__temp{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.forecast-card__description{font-size:.875rem;color:var(--color-text-secondary);text-transform:capitalize}.forecast-card__details{display:flex;justify-content:space-between;font-size:.75rem;color:var(--color-text-tertiary)}.forecast-card__loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--color-text-secondary)}.error-message{background:var(--color-background);border:1px solid var(--color-error);border-radius:var(--radius-lg);padding:1rem;margin:1rem 0}.error-message--compact{padding:.75rem}.error-message--banner{border-radius:var(--radius-md);margin:0}.error-message__content{display:flex;gap:.75rem;margin-bottom:1rem}.error-message__icon{color:var(--color-error);flex-shrink:0}.error-message__title{font-size:1rem;font-weight:600;color:var(--color-error);margin:0 0 .25rem}.error-message__description{color:var(--color-text-primary);margin:0 0 .5rem}.error-message__suggestion{color:var(--color-text-secondary);font-size:.875rem;margin:0}.error-message__actions{display:flex;gap:.5rem;justify-content:flex-end}.error-message__action{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);color:var(--color-text-primary);cursor:pointer;transition:all .2s ease;font-size:.875rem}.error-message__retry{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.error-message__retry:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.error-message__dismiss:hover{background:var(--color-background-secondary)}.error-message--network{border-color:var(--color-warning)}.error-message--network .error-message__title,.error-message--network .error-message__icon{color:var(--color-warning)}.error-message--not-found{border-color:var(--color-secondary)}.error-message--not-found .error-message__title,.error-message--not-found .error-message__icon{color:var(--color-secondary)}.loading-spinner--small{gap:.25rem;font-size:.875rem}.loading-spinner--large{gap:.75rem;font-size:1.125rem}.loading-spinner__message{color:var(--color-text-secondary)}@media (min-width: 768px){.header__search{display:block}}@media (max-width: 767px){.header__container{padding:0 1rem}.header__search{display:none}.search-form{flex-direction:column;gap:.5rem}.search-form__input-group,.search-form__submit{width:100%}.header__nav--desktop{display:none}.header__menu-toggle{display:flex}.header__nav--mobile{display:block}.nav__list--mobile .nav__link{padding:1rem .75rem;justify-content:flex-start}.weather-card__current{flex-direction:column;align-items:center;gap:1rem}.header-weather{padding:.3rem .45rem;font-size:.78rem}.weather-card__temp-value{font-size:2.5rem}.weather-details-grid{grid-template-columns:repeat(2,1fr)}.footer__content{grid-template-columns:1fr;gap:1.5rem}.footer__bottom-content{flex-direction:column;text-align:center}}@media (max-width: 480px){.header__container{height:56px;padding:0 .75rem}.header__brand-text{display:none}.weather-card,.forecast-card{padding:1rem}.weather-card__temp-value{font-size:2rem}.weather-details-grid{grid-template-columns:1fr}}@media (min-width: 768px){.header__search{flex:0 0 48px;max-width:64px;transition:none}.header--search-active .header__search{flex-basis:420px;max-width:420px;transition:flex-basis .2s ease,max-width .2s ease}.header__nav--desktop{transition:opacity .16s ease,max-width .2s ease;flex:0 1 auto}.header--search-active .header__nav--desktop{opacity:0;max-width:0;overflow:hidden}.header__actions .header-weather,.header__actions .header-weather__link{order:1}.header__actions .header__theme-toggle{order:2}.header__actions .header__search{order:3}.header__actions .header__menu-toggle{order:4}.header__theme-toggle+.header__search{margin-left:.375rem}}@media (min-width: 1140px){.header__container{display:grid;grid-template-columns:auto 1fr auto;align-items:center;column-gap:1.5rem}.header__nav--desktop{justify-self:center}.header__nav--desktop .nav__list{justify-content:center;gap:1.25rem}.header--search-active .header__nav--desktop{opacity:0;max-width:0;overflow:hidden}.header__actions{justify-self:end;gap:.75rem}.header--search-active .header__actions{grid-column:3 / 4;justify-self:end;transform:translate(-8px)}.header--search-active .header__search{flex-basis:560px;max-width:560px;transition:flex-basis .2s ease,max-width .2s ease}.header__actions .header-weather,.header__actions .header-weather__link{order:1}.header__actions .header__theme-toggle{order:2}.header__actions .header__search{order:3}.header__actions .header__menu-toggle{order:4}.header__theme-toggle+.header__search{margin-left:.5rem}}@media (max-width: 1139px){.header__nav--desktop{display:none}.header__menu-toggle{display:flex}.header__nav--mobile{display:block}.header__search{display:none}.header__nav--mobile .search-form__submit{width:auto;flex:0 0 auto}.header:not(.header--search-active) .header__search .search-form__icon{left:50%;transform:translate(-50%,-50%)}.header:not(.header--search-active) .header__search .search-form__input{padding-left:.75rem;padding-right:.75rem}.header__nav--mobile .search-form__icon{left:1rem;transform:translateY(-50%)}.header__nav--mobile .search-form__input{padding-left:3rem}.header.header--search-active .search-form__icon{left:.75rem;transform:translateY(-50%)}}.toast{position:fixed;right:1rem;bottom:1rem;display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:8px;font-size:.9rem;box-shadow:0 4px 12px #0000001f;z-index:1000}.toast--success{background:#e7f7ef;color:#0f5132;border:1px solid #badbcc}.inline-status{display:inline-flex;align-items:center;gap:.5rem;margin:.5rem 0 .75rem;color:var(--color-text-secondary);font-size:.9rem}.inline-status__dot{width:8px;height:8px;border-radius:999px;background:var(--color-primary);display:inline-block;animation:pulse 1s infinite ease-in-out}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.connection-status{position:fixed;top:60px;right:20px;z-index:1000;background:var(--card-background);border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026;transform:translateY(-10px);opacity:0;animation:slideInStatus .3s ease-out forwards}.connection-status.offline{border-color:#ef4444;background:#fef2f2}.connection-status.online{border-color:#10b981;background:#f0fdf4}.connection-status__content{display:flex;align-items:center;gap:8px}.connection-status__icon{display:flex;align-items:center}.connection-status.offline .connection-status__icon{color:#ef4444}.connection-status.online .connection-status__icon{color:#10b981}.connection-status__text{font-size:.875rem;font-weight:500}.connection-status.offline .connection-status__text{color:#dc2626}.connection-status.online .connection-status__text{color:#059669}.connection-status__retry{background:#ef4444;color:#fff;border:none;padding:4px 8px;border-radius:4px;font-size:.75rem;cursor:pointer;transition:background-color .2s ease}.connection-status__retry:hover:not(:disabled){background:#dc2626}.connection-status__retry:disabled{opacity:.6;cursor:not-allowed}@keyframes slideInStatus{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.icon--spinning{animation:spin 1s linear infinite}.search-dropdown,.search-dropdown__input-container{position:relative;width:100%}.search-dropdown__input-wrapper{position:relative;display:flex;align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;transition:all .2s ease}.search-dropdown__input-wrapper:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-dropdown__icon{position:absolute;left:12px;color:#6b7280;z-index:1;pointer-events:none}.search-dropdown__input{width:100%;padding:12px 16px 12px 44px;border:none;outline:none;font-size:16px;font-weight:400;color:#1f2937;background:transparent;border-radius:12px}.search-dropdown__input::placeholder{color:#9ca3af}.search-dropdown__input:disabled{opacity:.6;cursor:not-allowed}.search-dropdown__loading{position:absolute;right:44px;color:#3b82f6;animation:spin 1s linear infinite}.search-dropdown__clear{position:absolute;right:12px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#f3f4f6;border:none;border-radius:50%;color:#6b7280;cursor:pointer;transition:all .2s ease;z-index:1}.search-dropdown__clear:hover{background:#e5e7eb;color:#374151}.search-dropdown__error{margin-top:6px;padding:6px 12px;font-size:14px;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px}.search-dropdown__suggestions{position:absolute;top:100%;left:0;right:0;z-index:1000;margin-top:4px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 25px -3px #0000001a,0 4px 6px -2px #0000000d;max-height:320px;overflow-y:auto;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.search-dropdown__loading-message{display:flex;align-items:center;gap:8px;padding:12px 16px;color:#6b7280;font-size:14px}.search-dropdown__loading-icon{animation:spin 1s linear infinite}.search-dropdown__suggestion{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;background:transparent;text-align:left;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f3f4f6}.search-dropdown__suggestion:last-child{border-bottom:none}.search-dropdown__suggestion:hover,.search-dropdown__suggestion--selected{background:#f8fafc}.search-dropdown__suggestion--selected{background:#eff6ff;border-color:#dbeafe}.search-dropdown__suggestion-icon{color:#6b7280;flex-shrink:0}.search-dropdown__suggestion--us .search-dropdown__suggestion-icon{color:#3b82f6}.search-dropdown__suggestion-content{display:flex;align-items:center;justify-content:space-between;width:100%;gap:8px}.search-dropdown__suggestion-name{font-size:14px;font-weight:500;color:#1f2937;flex:1;text-align:left}.search-dropdown__suggestion-badge{padding:2px 6px;font-size:11px;font-weight:600;color:#3b82f6;background:#eff6ff;border:1px solid #dbeafe;border-radius:4px;flex-shrink:0}@media (max-width: 768px){.search-dropdown__suggestions{max-height:240px}.search-dropdown__suggestion{padding:10px 12px}.search-dropdown__suggestion-name{font-size:13px}}@media (prefers-color-scheme: dark){:root:not(.theme-light) .search-dropdown__input-wrapper{background:#1f2937;border-color:#374151}:root:not(.theme-light) .search-dropdown__input-wrapper:focus-within{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}:root:not(.theme-light) .search-dropdown__input{color:#f9fafb}:root:not(.theme-light) .search-dropdown__input::placeholder{color:#6b7280}:root:not(.theme-light) .search-dropdown__clear{background:#374151;color:#9ca3af}:root:not(.theme-light) .search-dropdown__clear:hover{background:#4b5563;color:#d1d5db}:root:not(.theme-light) .search-dropdown__suggestions{background:#1f2937;border-color:#374151}:root:not(.theme-light) .search-dropdown__suggestion{border-color:#374151}:root:not(.theme-light) .search-dropdown__suggestion:hover{background:#374151}:root:not(.theme-light) .search-dropdown__suggestion--selected{background:#1e3a8a;border-color:#3b82f6}:root:not(.theme-light) .search-dropdown__suggestion-name{color:#f9fafb}}.header-search-dropdown{position:relative;width:100%}.header-search-dropdown__suggestions{position:absolute;top:100%;left:0;right:0;z-index:9999;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 25px -3px #0000001a,0 4px 6px -2px #0000000d;max-height:320px;overflow-y:auto;animation:slideDown .2s ease-out;margin-top:8px}.header-search-dropdown__loading-message{display:flex;align-items:center;gap:8px;padding:12px 16px;color:#6b7280;font-size:14px}.header-search-dropdown__loading-icon{animation:spin 1s linear infinite}.header-search-dropdown__suggestion{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;background:transparent;text-align:left;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f3f4f6}.header-search-dropdown__suggestion:last-child{border-bottom:none}.header-search-dropdown__suggestion:hover,.header-search-dropdown__suggestion--selected{background:#f8fafc}.header-search-dropdown__suggestion--selected{background:#eff6ff;border-color:#dbeafe}.header-search-dropdown__suggestion-icon{color:#6b7280;flex-shrink:0}.header-search-dropdown__suggestion--us .header-search-dropdown__suggestion-icon{color:#3b82f6}.header-search-dropdown__suggestion-content{display:flex;align-items:center;justify-content:space-between;width:100%;gap:8px}.header-search-dropdown__suggestion-name{color:#374151;font-weight:500;font-size:14px;line-height:1.5;text-align:left;flex:1}.header-search-dropdown__suggestion-badge{background:#eff6ff;color:#3b82f6;border:1px solid #dbeafe;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.search-form__loading{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);animation:spin 1s linear infinite;z-index:2}.search-form__error{position:absolute;top:100%;left:0;right:0;margin-top:4px;padding:8px 12px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:6px;font-size:12px;z-index:999}[data-theme=dark] .header-search-dropdown__suggestions{background:#1f2937;border-color:#374151;box-shadow:0 10px 25px -3px #0000004d,0 4px 6px -2px #0003}[data-theme=dark] .header-search-dropdown__suggestion{border-color:#374151}[data-theme=dark] .header-search-dropdown__suggestion:hover,[data-theme=dark] .header-search-dropdown__suggestion--selected{background:#374151}[data-theme=dark] .header-search-dropdown__suggestion--selected{background:#1e3a8a;border-color:#3b82f6}[data-theme=dark] .header-search-dropdown__suggestion-name{color:#f9fafb}[data-theme=dark] .header-search-dropdown__loading-message{color:#9ca3af}[data-theme=dark] .search-form__error{background:#422006;color:#fbbf24;border-color:#a16207}.page{min-height:calc(100vh - 140px);padding:2rem 0}.page__container{max-width:1200px;margin:0 auto;padding:0 1rem}.page__header{text-align:center;margin-bottom:3rem}.page__title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:var(--color-text-primary)}.page__subtitle{font-size:1.125rem;color:var(--color-text-secondary);max-width:600px;margin:0 auto;line-height:1.6}.home-page{min-height:calc(100vh - 140px)}.home-page__container{max-width:1200px;margin:0 auto;padding:0 1rem}.home-hero{text-align:center;padding:3rem 0;background:linear-gradient(135deg,var(--color-background) 0%,var(--color-background-secondary) 100%);border-radius:var(--radius-xl);margin-bottom:3rem;box-shadow:7px 3px 16px -8px #0003}@media (prefers-color-scheme: dark){:root:not(.theme-light) .home-hero{box-shadow:7px 3px 16px -8px #f8fafc38}}.theme-dark .home-hero{box-shadow:11px 5px 16px -8px #f8fafcd1}.home-hero__content{max-width:600px;margin:0 auto}.home-hero__title{font-size:3rem;font-weight:800;margin-bottom:1rem;color:var(--color-text-primary);line-height:1.2}.home-hero__subtitle{font-size:1.25rem;color:var(--color-text-secondary);margin-bottom:2rem;line-height:1.6}.home-hero__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.home-weather{margin-bottom:4rem}.location-status{display:flex;justify-content:center;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.location-status__item{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:var(--radius-lg);font-size:.875rem;font-weight:500}.location-status__item--success{background:#10b9811a;color:var(--color-success);border:1px solid rgb(16 185 129 / .2)}.location-status__item--error{background:#ef44441a;color:var(--color-error);border:1px solid rgb(239 68 68 / .2)}.location-status__item--info{background:#3b82f61a;color:var(--color-primary);border:1px solid rgb(59 130 246 / .2)}.home-weather__content{max-width:800px;margin:0 auto}@media (max-width: 1024px){#current-weather-data{scroll-margin-top:80px}}.weather-loading{text-align:center;padding:3rem;color:var(--color-text-secondary)}.weather-loading p{margin-top:1rem}.weather-display{margin:0 auto}.weather-empty{text-align:center;padding:3rem;color:var(--color-text-secondary)}.weather-empty svg{color:var(--color-text-tertiary);margin-bottom:1rem}.weather-empty h3{margin-bottom:.5rem;color:var(--color-text-primary)}.weather-empty p{margin-bottom:2rem}.home-favorites{margin-bottom:4rem}.section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.section__actions{display:flex;align-items:center;gap:.5rem}.section__title{font-size:2rem;font-weight:700;color:var(--color-text-primary);margin:0}.section__link{display:flex;align-items:center;gap:.5rem;color:var(--color-primary);text-decoration:none;font-weight:500;transition:color .2s ease}.section__link:hover{color:var(--color-primary-dark)}.favorites-slider{position:relative}.favorites-slider__viewport{overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;padding:0 .5rem .5rem}.favorites-slider__track{display:flex;gap:1.5rem}.favorites-slider__track .favorite-item{flex:0 0 calc((100% - 1.5rem * 2) / 3);scroll-snap-align:start}@media (max-width: 1024px){.favorites-slider__track .favorite-item{flex-basis:calc((100% - 1.5rem)/2)}}@media (max-width: 640px){.favorites-slider__track .favorite-item{flex-basis:100%}}.favorites-slider__controls{display:flex;justify-content:center;align-items:center;gap:.75rem;margin-top:1.25rem}.favorites-slider__nav{position:static;border:none;width:44px;height:44px;border-radius:50%;background:var(--color-background);color:var(--color-text-primary);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.favorites-slider__nav svg{display:block;margin:0 auto}.favorites-slider__nav:hover:not(:disabled),.favorites-slider__nav:focus:not(:disabled){background:var(--color-background-secondary);box-shadow:var(--shadow-lg)}.favorites-slider__nav:disabled{opacity:.4;cursor:default}.favorites-slider__nav--prev{left:auto}.favorites-slider__nav--next{right:auto}@media (prefers-color-scheme: dark){:root:not(.theme-light) .favorites-slider__nav{box-shadow:0 0 0 1px #f8fafc66,0 10px 24px #f8fafc38,0 0 18px #f8fafc2e}:root:not(.theme-light) .favorites-slider__nav:hover:not(:disabled),:root:not(.theme-light) .favorites-slider__nav:focus:not(:disabled){box-shadow:0 0 0 1px #f8fafc8c,0 12px 28px #f8fafc4d,0 0 22px #f8fafc3d}}.theme-dark .favorites-slider__nav{box-shadow:0 0 0 1px #f8fafc66,0 10px 24px #f8fafc38,0 0 18px #f8fafc2e}.theme-dark .favorites-slider__nav:hover:not(:disabled),.theme-dark .favorites-slider__nav:focus:not(:disabled){box-shadow:0 0 0 1px #f8fafc8c,0 12px 28px #f8fafc4d,0 0 22px #f8fafc3d}@media (max-width: 640px){.favorites-slider__viewport{padding:0 .5rem .5rem}.favorites-slider__nav{width:40px;height:40px}}.favorite-item{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .2s ease}.home-features{padding:3.5rem 3rem;margin-bottom:4rem;background:var(--color-background-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);box-shadow:0 3px 8px #0003}@media (max-width: 640px){.home-features{padding:2.5rem 1.5rem;margin-bottom:3rem}}.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:2rem}@media (max-width: 1024px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.features-grid{grid-template-columns:1fr;gap:1.5rem}}.feature-card{text-align:center;padding:2rem 1rem;background:var(--color-background);border-radius:var(--radius-lg);border:1px solid var(--color-border);transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.feature-card__icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--color-primary);color:#fff;border-radius:var(--radius-lg);margin:0 auto 1rem}.feature-card__title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--color-text-primary)}.feature-card__description{color:var(--color-text-secondary);line-height:1.6}.search-page{min-height:calc(100vh - 140px);padding:2rem 0}.search-page__container{max-width:1200px;margin:0 auto;padding:0 1rem}.search-header{text-align:center;margin-bottom:3rem}.search-header__title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:var(--color-text-primary)}.search-header__subtitle{font-size:1.125rem;color:var(--color-text-secondary);max-width:600px;margin:0 auto}.search-form--page{max-width:600px;margin:0 auto 3rem;display:flex;gap:1rem}.search-form--page .search-form__input-group{flex:1}.search-form--page .search-form__input{padding-right:2.5rem}.search-form--page .search-form__clear{opacity:1;pointer-events:auto;transform:translateY(-50%) scale(1)}.search-form--page .search-form__input::placeholder,.search-form--page .search-form__input:focus::placeholder{color:var(--color-text-secondary)}.search-results{max-width:1000px;margin:0 auto}.search-results__loading{text-align:center;padding:3rem}.search-results__error{margin-bottom:2rem}.search-results__content>*+*{margin-top:3rem}.search-results__current,.search-results__forecast{margin-bottom:3rem}.forecast-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}.forecast-day{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;transition:box-shadow .2s ease}.forecast-day:hover{box-shadow:var(--shadow-md)}.forecast-day__header{margin-bottom:1rem}.forecast-day__date{font-size:1rem;font-weight:600;margin:0 0 .25rem;color:var(--color-text-primary)}.forecast-day__date-full{font-size:.875rem;color:var(--color-text-secondary)}.forecast-day__weather{display:flex;flex-direction:column;align-items:center;margin-bottom:1rem}.forecast-day__icon{width:64px;height:64px;margin-bottom:.5rem}.forecast-day__temps{display:flex;gap:.5rem;align-items:center}.forecast-day__temp-max{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.forecast-day__temp-min{font-size:1.125rem;color:var(--color-text-secondary)}.forecast-day__description{font-size:.875rem;color:var(--color-text-secondary);text-transform:capitalize}.forecast-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--color-border)}@media (max-width: 1024px){.forecast-section{scroll-margin-top:80px}}.forecast-section__title{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:var(--color-text-primary)}.forecast-item{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem;text-align:center;transition:box-shadow .2s ease}.forecast-item:hover{box-shadow:var(--shadow-sm)}.forecast-item__date{font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--color-text-secondary)}.forecast-item__icon{width:48px;height:48px;margin:.5rem auto}.forecast-item__temps{display:flex;justify-content:center;gap:.5rem;margin:.5rem 0}.forecast-item__temp-high{font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.forecast-item__temp-low{font-size:1rem;color:var(--color-text-secondary)}.forecast-item__description{font-size:.75rem;color:var(--color-text-secondary);text-transform:capitalize}.search-results__empty{text-align:center;padding:3rem}.search-results__empty svg{color:var(--color-text-tertiary);margin-bottom:1rem}.search-results__empty h3{margin-bottom:1rem;color:var(--color-text-primary)}.search-results__empty p{color:var(--color-text-secondary);margin-bottom:2rem}.search-suggestions{margin-top:2rem}.search-suggestions h4{margin-bottom:1rem;color:var(--color-text-primary)}.search-suggestions__tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin:0 0 1rem}.regions-slider{position:relative}.regions-slider__controls{display:none;justify-content:center;align-items:center;gap:.75rem;margin:1.25rem 0 2rem}.regions-slider__nav{position:static;border:none;width:44px;height:44px;border-radius:50%;background:var(--color-background);color:var(--color-text-primary);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.regions-slider__nav svg{display:block;margin:0 auto}.regions-slider__nav:hover:not(:disabled),.regions-slider__nav:focus:not(:disabled){background:var(--color-background-secondary);box-shadow:var(--shadow-lg)}.regions-slider__nav:disabled{opacity:.4;cursor:default}.regions-slider__nav--prev{left:auto}.regions-slider__nav--next{right:auto}@media (prefers-color-scheme: dark) and (max-width: 768px){:root:not(.theme-light) .regions-slider__nav{box-shadow:0 0 0 1px #f8fafc66,0 10px 24px #f8fafc38,0 0 18px #f8fafc2e}:root:not(.theme-light) .regions-slider__nav:hover:not(:disabled),:root:not(.theme-light) .regions-slider__nav:focus:not(:disabled){box-shadow:0 0 0 1px #f8fafc8c,0 12px 28px #f8fafc4d,0 0 22px #f8fafc3d}}@media (max-width: 768px){.theme-dark .regions-slider__nav{box-shadow:0 0 0 1px #f8fafc66,0 10px 24px #f8fafc38,0 0 18px #f8fafc2e}.theme-dark .regions-slider__nav:hover:not(:disabled),.theme-dark .regions-slider__nav:focus:not(:disabled){box-shadow:0 0 0 1px #f8fafc8c,0 12px 28px #f8fafc4d,0 0 22px #f8fafc3d}}@media (max-width: 768px){.search-suggestions__tabs{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.5rem;gap:.5rem;scrollbar-width:thin;scroll-behavior:smooth;scroll-snap-type:x mandatory}.search-suggestions__tabs .btn{white-space:nowrap;scroll-snap-align:start}.regions-slider__controls{display:flex}}@media (max-width: 640px){.regions-slider__nav{width:40px;height:40px}.regions-slider__controls{margin:1rem 0 1.75rem}}.search-suggestions__controls{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin:0 0 1rem}.search-suggestions__list{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;align-items:stretch}@media (min-width: 640px){.search-suggestions__list{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.875rem}}.search-suggestion{display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;padding:.625rem 1rem;background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:999px;color:var(--color-text-primary);cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .08s ease;font-size:.95rem}.search-suggestion:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff;transform:translateY(-1px)}.search-suggestions__more{display:flex;justify-content:center;margin-top:.75rem}.search-suggestions__more-btn{min-width:160px}.favorites-page{min-height:calc(100vh - 140px);padding:2rem 0}.favorites-page__container{max-width:1200px;margin:0 auto;padding:0 1rem}.favorites-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:3rem;flex-wrap:wrap;gap:1rem}.favorites-header__title{display:flex;align-items:center;gap:.75rem;font-size:2.5rem;font-weight:700;color:var(--color-text-primary);margin:0}.favorites-header__subtitle{font-size:1.125rem;color:var(--color-text-secondary);margin:.5rem 0 0}.favorites-header__subtitle_tip{font-size:.975rem;margin-top:.25rem}.favorites-content{margin-top:2rem}.favorites-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.favorite-item{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .2s ease;max-width:350px;margin:0 auto;width:100%}.favorite-item:hover{box-shadow:var(--shadow-md)}.favorite-item__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1rem 0}.favorite-item__draghandle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;margin-right:.25rem;color:var(--color-text-tertiary);cursor:grab;-webkit-user-select:none;user-select:none}.favorite-item--dragging{opacity:.6;box-shadow:var(--shadow-md)}.favorite-item--dragover{outline:2px dashed var(--color-primary);outline-offset:-2px}.favorite-item__location{display:flex;align-items:center;gap:.5rem}.favorite-item__name{font-weight:600;color:var(--color-text-primary)}.favorite-item__remove{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-tertiary);cursor:pointer;transition:all .2s ease}.favorite-item__remove:hover{background:var(--color-error);color:#fff}.favorite-item__actions{padding:0 1rem 1rem;display:flex;justify-content:center}.favorites-empty{text-align:center;padding:4rem 2rem;color:var(--color-text-secondary)}.favorites-empty>svg{color:var(--color-text-tertiary);margin-bottom:1.5rem}.favorites-empty h3{margin-bottom:1rem;color:var(--color-text-primary)}.favorites-empty p{margin-bottom:2rem;max-width:400px;margin-left:auto;margin-right:auto;line-height:1.6}.favorites-clear-all{display:flex;justify-content:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.settings-page{min-height:calc(100vh - 140px);padding:2rem 0}.settings-page__container{max-width:800px;margin:0 auto;padding:0 1rem}.settings-header{text-align:center;margin-bottom:3rem}.settings-header__title{display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:2.5rem;font-weight:700;color:var(--color-text-primary);margin:0 0 1rem}.settings-header__subtitle{font-size:1.125rem;color:var(--color-text-secondary);margin:0}.settings-form{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-sm)}.settings-section{margin-bottom:2.5rem}.settings-section:last-of-type{margin-bottom:0}.settings-section__header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.settings-section__title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0}.settings-group{display:flex;flex-direction:column;gap:1rem}.radio-group,.checkbox-group{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.radio-group:hover,.checkbox-group:hover{background:var(--color-background-secondary);border-color:var(--color-primary)}.radio-group input[type=radio],.checkbox-group input[type=checkbox]{display:none}.radio-button,.checkbox{width:20px;height:20px;border:2px solid var(--color-border);background:var(--color-background);transition:all .2s ease;flex-shrink:0;margin-top:.125rem}.radio-button{border-radius:50%}.checkbox{border-radius:var(--radius-sm)}.radio-group input[type=radio]:checked+.radio-button{border-color:var(--color-primary);background:var(--color-primary);box-shadow:inset 0 0 0 3px var(--color-background)}.checkbox-group input[type=checkbox]:checked+.checkbox{border-color:var(--color-primary);background:var(--color-primary);background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='m13.854 3.646-7.5 7.5a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6 10.293l7.146-7.147a.5.5 0 0 1 .708.708z'/%3e%3c/svg%3e")}.radio-label,.checkbox-label{flex:1}.radio-label strong,.checkbox-label strong{display:block;color:var(--color-text-primary);font-weight:600;margin-bottom:.25rem}.radio-label small{color:var(--color-text-secondary);font-size:.875rem}.settings-form__actions{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border);text-align:center;display:flex;flex-direction:column;align-items:center}.settings-form__note{margin-top:1rem;font-size:.875rem;color:var(--color-text-tertiary)}.settings-form__actions-buttons{display:flex;align-items:center;justify-content:center}.settings-form__actions-buttons .btn+.btn{margin-left:.75rem}@media (max-width: 768px){.settings-form__actions-buttons{flex-direction:column}.settings-form__actions-buttons .btn+.btn{margin-left:0;margin-top:.75rem}}@media (max-width: 1024px) and (min-width: 769px){.favorites-header{flex-direction:column;align-items:center;text-align:center;gap:1.5rem}.favorites-header__title{font-size:2.25rem}.favorites-content{text-align:center}.favorites-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));justify-items:center;gap:1.25rem}}@media (max-width: 768px){.page{padding:1rem 0}.page__title{font-size:2rem}.home-hero__title{font-size:2.5rem}.home-hero__subtitle{font-size:1.125rem}.home-hero__actions{flex-direction:column;align-items:center}.section__header{flex-direction:column;align-items:center;text-align:center;gap:1rem}.section__title{font-size:1.75rem}.section__actions{justify-content:center;flex-wrap:wrap}.location-status{justify-content:center;align-items:center;text-align:center;flex-direction:column;gap:1.5rem;min-height:140px;padding:1rem 0}.location-status__item{max-width:95%;text-align:center;justify-content:center;margin:0;width:100%;box-sizing:border-box}.favorites-header{flex-direction:column;align-items:center;text-align:center;gap:1.5rem}.favorites-header__title,.search-header__title,.settings-header__title{font-size:2rem}.search-form--page{flex-direction:column}.search-form--page .search-form__input-group,.search-form--page .search-form__submit{width:100%}.forecast-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.features-grid{grid-template-columns:1fr}.favorites-grid{grid-template-columns:1fr;justify-items:center}.favorites-content{text-align:center}}@media (max-width: 480px){.page__container{padding:0 .75rem}.home-hero{padding:2rem 1rem;margin-bottom:2rem}.home-hero__title{font-size:2rem}.home-hero__subtitle{font-size:1rem}.settings-form{padding:1.5rem}.radio-group,.checkbox-group{padding:.75rem}.forecast-day{padding:1rem}.favorites-empty{padding:3rem 1rem}}.test-city-container{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.test-city-input-wrapper{display:flex;align-items:center}.test-city-buttons{display:flex;align-items:center;gap:.5rem}.test-city-btn{white-space:nowrap}.test-control-buttons{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.test-control-btn{white-space:nowrap}.test-control-help{text-align:left;margin-top:1rem}@media (max-width: 640px){.test-city-container{flex-direction:column;align-items:stretch;gap:1rem}.test-city-input-wrapper{width:100%;justify-content:center}.test-city-input-wrapper label{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%}.test-city-input{margin-left:0!important;margin-top:.5rem!important;width:100%;max-width:300px;padding:8px 12px!important;font-size:16px;border:2px solid #ddd;border-radius:8px}.test-city-buttons{justify-content:center;flex-wrap:wrap;gap:.75rem}.test-city-btn{margin-left:0!important;padding:10px 16px!important;font-size:14px;min-width:120px;border-radius:6px!important}.test-control-buttons{justify-content:center;flex-direction:column;align-items:center;gap:1rem;margin-top:2.5rem}.test-control-btn{margin:0!important;padding:12px 20px!important;font-size:16px;min-width:200px;border-radius:8px!important;text-align:center}.test-control-help{text-align:center!important;margin-top:1.5rem!important;padding:0 1rem}}.app{min-height:100vh;display:flex;flex-direction:column}.topbar-progress{position:fixed;top:0;left:0;right:0;height:3px;background:transparent;z-index:200;overflow:hidden}.topbar-progress__bar{position:absolute;left:-40%;top:0;height:100%;width:40%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-dark));animation:topbar-indeterminate 1.1s ease-in-out infinite;border-radius:0 2px 2px 0}@keyframes topbar-indeterminate{0%{left:-40%;width:40%}50%{left:20%;width:60%}to{left:100%;width:20%}}.main-content{flex:1;padding:2rem 0}.loading-spinner{display:flex;align-items:center;justify-content:center;gap:.5rem;color:var(--color-primary)}.loading-spinner__icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-boundary{min-height:50vh;display:flex;align-items:center;justify-content:center;padding:2rem}.error-boundary__container{text-align:center;max-width:500px}.error-boundary__icon{color:var(--color-error);margin-bottom:1rem}.error-boundary__title{margin-bottom:1rem;color:var(--color-text-primary)}.error-boundary__actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease}.btn svg{color:inherit;flex-shrink:0}.btn--primary{background-color:var(--color-primary);color:#fff}.btn--primary:hover{background-color:var(--color-primary-dark);color:#fff}.btn--secondary{background-color:var(--color-background-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn--small{padding:.5rem .75rem;font-size:.75rem}.section__title{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:var(--color-text-primary)}.section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.weather-card,.forecast-card{background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:.75rem;padding:1.5rem;margin-bottom:1rem}@media (max-width: 768px){.main-content{padding:1rem 0}.container{padding:0 .75rem}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-primary: #3b82f6;--color-primary-dark: #2563eb;--color-primary-light: #93c5fd;--color-secondary: #64748b;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-background: #ffffff;--color-background-secondary: #f8fafc;--color-background-tertiary: #f1f5f9;--color-text-primary: #1e293b;--color-text-secondary: #64748b;--color-text-tertiary: #94a3b8;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem}@media (prefers-color-scheme: dark){:root:not(.theme-light){--color-background: #0f172a;--color-background-secondary: #1e293b;--color-background-tertiary: #334155;--color-text-primary: #f8fafc;--color-text-secondary: #cbd5e1;--color-text-tertiary: #94a3b8;--color-border: #334155;--color-border-light: #475569}}.theme-dark{--color-background: #0f172a;--color-background-secondary: #1e293b;--color-background-tertiary: #334155;--color-text-primary: #f8fafc;--color-text-secondary: #cbd5e1;--color-text-tertiary: #94a3b8;--color-border: #334155;--color-border-light: #475569}.theme-light{--color-background: #ffffff;--color-background-secondary: #f8fafc;--color-background-tertiary: #f1f5f9;--color-text-primary: #1e293b;--color-text-secondary: #64748b;--color-text-tertiary: #94a3b8;--color-border: #e2e8f0;--color-border-light: #f1f5f9}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}html.no-theme-transition,html.no-theme-transition *{transition:none!important}*{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100vh;background-color:var(--color-background);color:var(--color-text-primary);transition:background-color .3s ease,color .3s ease}body{margin:0;min-width:320px}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.25;color:var(--color-text-primary)}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{margin:0;line-height:1.6;color:var(--color-text-secondary)}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-dark)}input,select,textarea{font-family:inherit;font-size:inherit;background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem;color:var(--color-text-primary);transition:border-color .2s ease,box-shadow .2s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}button{font-family:inherit;cursor:pointer;border:none;background:none;padding:0;transition:all .2s ease}button:disabled{opacity:.5;cursor:not-allowed}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.hidden{display:none}@media (max-width: 768px){h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}
