/* =============================================================
 * JoWeather - Public stylesheet
 * Semantic design tokens (shadcn-inspired), Arabic RTL, no
 * external dependencies. Built for accessibility and speed.
 * ============================================================= */

*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
        scroll-behavior: auto !important;
    }
}

body {
    margin: 0;
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
    color: var(--color-text);
    background:
        radial-gradient(circle at 88% -10%, rgba(128, 202, 216, .32), transparent 36%),
        radial-gradient(circle at 6% 0%, rgba(245, 184, 75, .16), transparent 30%),
        linear-gradient(180deg, #f7fbff 0%, var(--color-bg) 36%, #edf3f9 100%);
    min-height: 100vh;
}

img, svg { max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; color: inherit; }

:focus-visible {
    outline: 3px solid var(--color-focus);
    outline-offset: 2px;
    border-radius: 6px;
}

.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;
}

/* ====== Layout primitives ====== */
.container {
    width: min(1180px, calc(100% - 32px));
    margin-inline: auto;
}

.stack > * + * { margin-block-start: var(--space-4); }
.stack-lg > * + * { margin-block-start: var(--space-7); }

.section { padding-block: var(--space-7); }
.section--soft { background: var(--color-surface-soft); border-radius: var(--radius-xl); padding: var(--space-7); }
.section-title { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-4); margin-block-end: var(--space-5); }
.section-title h2 { margin: 0; font-size: var(--font-size-2xl); }
.section-title a { color: var(--color-primary); font-weight: var(--font-weight-bold); }

.divider { height: 1px; background: var(--color-border); border: 0; margin-block: var(--space-6); }

.grid { display: grid; gap: var(--space-5); }
.grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid--locations { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }

@media (max-width: 980px) {
    .grid--3, .grid--4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
    .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; }
}

.flex { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.flex-col { display: flex; flex-direction: column; gap: var(--space-3); }
.between { display: flex; justify-content: space-between; align-items: center; gap: var(--space-3); }
.muted { color: var(--color-muted); }
.tiny { font-size: var(--font-size-xs); }
.center { text-align: center; }

/* ====== Header ====== */
.site-header {
    position: sticky;
    inset-block-start: 0;
    z-index: 20;
    background: rgba(247, 251, 255, .86);
    backdrop-filter: saturate(160%) blur(14px);
    -webkit-backdrop-filter: saturate(160%) blur(14px);
    border-block-end: 1px solid var(--color-border-soft);
}

.site-header__row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--space-5);
    align-items: center;
    padding-block: var(--space-4);
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
}

.brand .brand-mark {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-md);
    background: linear-gradient(160deg, var(--color-secondary) 0%, var(--color-primary) 100%);
    color: #fff;
    display: inline-grid;
    place-items: center;
}

.brand .brand-mark svg { width: 22px; height: 22px; }

.site-nav {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
    justify-content: center;
}

.site-nav a {
    padding: 9px 14px;
    border-radius: var(--radius-pill);
    color: var(--color-text);
    font-weight: var(--font-weight-medium);
    border: 1px solid transparent;
    transition: background .15s ease, color .15s ease, border-color .15s ease;
}

.site-nav a:hover,
.site-nav a[aria-current="page"] {
    background: var(--color-primary-soft);
    color: var(--color-primary);
    border-color: var(--color-border-soft);
}

.site-tools {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.site-tools .icon-btn,
.site-tools .btn {
    height: 40px;
    padding-inline: 14px;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}

.icon-btn {
    display: inline-grid;
    place-items: center;
    width: 40px;
    height: 40px;
    border-radius: var(--radius-pill);
    border: 1px solid var(--color-border-soft);
    background: var(--color-surface);
    color: var(--color-primary);
    cursor: pointer;
    transition: background .15s ease, transform .12s ease;
}

.icon-btn:hover { background: var(--color-primary-soft); }
.icon-btn--accent { background: var(--color-primary); color: #fff; border-color: transparent; }
.icon-btn--accent:hover { background: var(--color-primary); filter: brightness(1.08); transform: translateY(-1px); }
.icon-btn svg { width: 20px; height: 20px; }

.menu-toggle { display: none; }

@media (max-width: 880px) {
    .site-header__row { grid-template-columns: auto 1fr auto; }
    .site-nav { display: none; }
    .menu-toggle { display: inline-grid; }
    .site-header.is-open .site-nav {
        display: flex;
        position: absolute;
        inset-inline: 16px;
        inset-block-start: calc(100% + 8px);
        background: var(--color-surface);
        border-radius: var(--radius-lg);
        padding: var(--space-3);
        box-shadow: var(--shadow-strong);
        flex-direction: column;
        align-items: stretch;
    }
    .site-header.is-open .site-nav a { width: 100%; }
    .site-header.is-open .site-tools { display: none; }
}

/* ====== Buttons ====== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    height: 44px;
    padding-inline: 18px;
    border: 0;
    border-radius: var(--radius-pill);
    background: linear-gradient(180deg, var(--color-primary), var(--color-primary-hover));
    color: #fff;
    font-weight: var(--font-weight-bold);
    cursor: pointer;
    box-shadow: 0 14px 28px rgba(36, 107, 151, .24);
    transition: transform .12s ease, filter .15s ease, box-shadow .15s ease;
}

.btn:hover { filter: brightness(1.04); transform: translateY(-1px); }
.btn--ghost { background: var(--color-surface); color: var(--color-primary); border: 1px solid var(--color-border); box-shadow: none; }
.btn--ghost:hover { background: var(--color-primary-soft); }
.btn--sm { height: 36px; padding-inline: 14px; font-size: var(--font-size-sm); }
.btn svg { width: 18px; height: 18px; }

.link-arrow { color: var(--color-primary); font-weight: var(--font-weight-bold); display: inline-flex; gap: 6px; align-items: center; }
.link-arrow svg { width: 16px; height: 16px; transition: transform .15s ease; }
.link-arrow:hover svg { transform: translateX(2px); }

/* ====== Cards / Panels ====== */
.panel {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft);
    padding: var(--space-6);
}

.panel--soft { background: var(--color-surface-soft); box-shadow: none; }
.panel--hero {
    background:
        radial-gradient(circle at 88% 12%, rgba(245, 184, 75, .28), transparent 22%),
        linear-gradient(180deg, rgba(128, 202, 216, .18), rgba(255, 255, 255, .98));
    border-color: var(--color-border-soft);
}
.panel--ink {
    background: linear-gradient(170deg, var(--color-night) 0%, var(--color-primary) 100%);
    color: #f7fbff;
    border-color: transparent;
}
.panel--ink .muted, .panel--ink .tiny { color: rgba(247, 251, 255, .74); }

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: var(--radius-pill);
    background: var(--color-primary-soft);
    color: var(--color-primary);
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-sm);
}
.panel--ink .eyebrow { background: rgba(255, 255, 255, .12); color: #fff; }

/* ====== Forms ====== */
.field { display: flex; flex-direction: column; gap: 6px; }
.field > span { font-size: var(--font-size-sm); color: var(--color-muted); }

.input,
.textarea,
.select {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-surface);
    color: var(--color-text);
    transition: border-color .15s ease, box-shadow .15s ease;
}

.input:focus,
.textarea:focus,
.select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-secondary-soft);
    outline: none;
}

.search-bar {
    display: flex;
    align-items: stretch;
    gap: 0;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    padding: 6px 6px 6px 18px;
    box-shadow: var(--shadow-soft);
    min-width: 0;
}

.search-bar .input {
    border: 0;
    background: transparent;
    box-shadow: none;
    padding-inline: 0;
    flex: 1;
    min-width: 0;
}

.search-bar:focus-within { box-shadow: 0 0 0 3px var(--color-secondary-soft); border-color: var(--color-primary); }

.search-bar .btn { height: 40px; }
.search-bar svg { width: 18px; height: 18px; color: var(--color-muted); margin-inline-end: 8px; }

/* Search page header: simple stacked block, not a stretching grid. */
.search-hero { padding-block: var(--space-7) var(--space-5); }
.search-hero h1 { font-size: var(--font-size-3xl); margin: var(--space-3) 0 var(--space-2); color: var(--color-text); }
.search-hero .search-bar { max-width: 560px; margin-block-start: var(--space-4); }

/* ====== Hero ====== */
.hero {
    display: grid;
    grid-template-columns: 1.35fr .9fr;
    gap: var(--space-6);
    padding-block: var(--space-8) var(--space-7);
    align-items: stretch;
}

.hero__intro h1 {
    font-size: var(--font-size-4xl);
    line-height: var(--line-height-tight);
    letter-spacing: -.01em;
    margin: var(--space-4) 0 var(--space-3);
    color: var(--color-text);
}

.hero__intro p { color: var(--color-muted); margin: 0 0 var(--space-5); max-width: 56ch; }

.hero__quicklinks {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-block-start: var(--space-4);
}

.hero__quicklinks a {
    padding: 7px 12px;
    border-radius: var(--radius-pill);
    background: var(--color-primary-soft);
    color: var(--color-primary);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
}

.hero__now {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.hero__now .temp {
    font-size: clamp(46px, 6vw, 64px);
    line-height: 1;
    font-weight: var(--font-weight-bold);
}

.hero__now .meta { color: rgba(247, 251, 255, .85); display: flex; flex-wrap: wrap; gap: var(--space-4); }
.hero__now .meta span { display: inline-flex; align-items: center; gap: 6px; }
.hero__now .meta svg { width: 18px; height: 18px; }

.hero__now .grid--daynight {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
    margin-block-start: var(--space-4);
}

.temp-pill {
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .10);
}

.temp-pill--day { background: linear-gradient(180deg, rgba(245, 184, 75, .22), rgba(245, 184, 75, .08)); border-color: rgba(245, 184, 75, .22); }
.temp-pill--night { background: linear-gradient(180deg, rgba(23, 50, 74, .35), rgba(23, 50, 74, .12)); border-color: rgba(23, 50, 74, .35); }

.temp-pill span { display: block; font-size: var(--font-size-sm); }
.temp-pill strong { font-size: 28px; }

@media (max-width: 980px) { .hero { grid-template-columns: 1fr; padding-block: var(--space-7) var(--space-6); } }

/* ====== Location card ====== */
.loc-card {
    display: flex;
    flex-direction: column;
    min-height: 200px;
    padding: var(--space-5);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft);
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
    color: inherit;
}
.loc-card--gov { min-height: 0; }
.loc-card__foot { margin-block-start: auto; }
.loc-card__foot strong { font-size: var(--font-size-lg); color: var(--color-text); }
.loc-card .chip .icon { width: 18px; height: 18px; }

.loc-card:hover { transform: translateY(-2px); border-color: var(--color-border-soft); box-shadow: var(--shadow-strong); }

.loc-card__head { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--space-3); }
.loc-card__title { font-size: var(--font-size-lg); font-weight: var(--font-weight-bold); }
.loc-card__sub { color: var(--color-muted); font-size: var(--font-size-sm); margin-block-start: 2px; }

.loc-card--gov .loc-card__chevron {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--color-primary-soft);
    color: var(--color-primary);
    flex-shrink: 0;
    transition: transform .15s ease, background .15s ease;
}
.loc-card--gov:hover .loc-card__chevron { transform: translateX(-4px); background: var(--color-primary); color: #fff; }
.loc-card--gov .loc-card__chevron .icon { width: 18px; height: 18px; }

.chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: var(--radius-pill);
    background: var(--color-surface-soft);
    color: var(--color-text);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    border: 1px solid var(--color-border-soft);
    white-space: nowrap;
}

.chip svg { width: 14px; height: 14px; }
.chip--sunny { color: var(--color-sun-text); background: var(--color-sun-soft); border-color: rgba(245, 184, 75, .35); }
.chip--partly-cloudy, .chip--cloudy, .chip--fog { color: var(--color-night-text); background: var(--color-cloud); }
.chip--rain, .chip--drizzle { color: #16669d; background: var(--color-rain-soft); }
.chip--snow, .chip--storm { color: #24546f; background: rgba(114, 198, 212, .18); }
.chip--neutral { color: var(--color-muted); }

.loc-card__daynight { display: flex; gap: var(--space-2); margin-block: var(--space-4) var(--space-3); }

.daynight { display: flex; gap: var(--space-2); flex: 1; }
.daynight div { flex: 1; padding: 10px 12px; border-radius: var(--radius-md); border: 1px solid transparent; }
.daynight div span { display: block; font-size: var(--font-size-xs); }
.daynight div strong { font-size: var(--font-size-lg); }
.daynight .day { background: var(--color-sun-soft); border-color: rgba(245, 184, 75, .35); color: var(--color-sun-text); }
.daynight .night { background: var(--color-night-soft); border-color: rgba(23, 50, 74, .15); color: var(--color-night-text); }

.loc-card__foot { display: flex; justify-content: space-between; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); color: var(--color-muted); }

/* ====== Indicators grid (current weather) ====== */
.indicators {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-3);
}

@media (max-width: 880px) { .indicators { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

.indicator {
    background: var(--color-surface-soft);
    border: 1px solid var(--color-border-soft);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.indicator .label { color: var(--color-muted); font-size: var(--font-size-sm); display: inline-flex; align-items: center; gap: 6px; }
.indicator .label svg { width: 16px; height: 16px; }
.indicator .value { font-size: var(--font-size-xl); font-weight: var(--font-weight-bold); }
.indicator .sub { color: var(--color-muted); font-size: var(--font-size-xs); }

/* ====== Hours strip ====== */
.hours {
    display: flex;
    gap: var(--space-2);
    overflow-x: auto;
    padding-block: var(--space-3);
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}

.hours__item {
    flex: 0 0 88px;
    background: var(--color-surface);
    border: 1px solid var(--color-border-soft);
    border-radius: var(--radius-md);
    padding: var(--space-3);
    text-align: center;
    scroll-snap-align: start;
}

.hours__item time { display: block; font-size: var(--font-size-xs); color: var(--color-muted); }
.hours__item svg { width: 26px; height: 26px; margin-block: 4px; }
.hours__item strong { display: block; font-size: var(--font-size-lg); font-weight: var(--font-weight-bold); }
.hours__item small { color: var(--color-muted); font-size: var(--font-size-xs); }
.hours__item--now { background: var(--color-primary-soft); border-color: var(--color-border-soft); }

/* ====== Forecast table ====== */
.forecast {
    overflow-x: auto;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-surface);
}

.forecast table { width: 100%; border-collapse: collapse; min-width: 640px; }
.forecast th, .forecast td { padding: 14px 12px; text-align: start; border-block-end: 1px solid var(--color-border-soft); }
.forecast thead th { background: var(--color-surface-soft); font-size: var(--font-size-sm); color: var(--color-muted); font-weight: var(--font-weight-bold); }
.forecast tbody tr:last-child td { border-block-end: 0; }
.forecast .icon { width: 22px; height: 22px; vertical-align: middle; }

.forecast .date { font-weight: var(--font-weight-bold); }
.forecast .date small { display: block; color: var(--color-muted); font-size: var(--font-size-xs); font-weight: var(--font-weight-normal); }

/* ====== Seasonal ====== */
.seasonal {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-3);
    margin-block-start: var(--space-4);
}

@media (max-width: 880px) { .seasonal { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

.seasonal__week {
    background: var(--color-surface);
    border: 1px solid var(--color-border-soft);
    border-radius: var(--radius-md);
    padding: var(--space-4);
}

.seasonal__week h3 { margin: 0 0 6px; font-size: var(--font-size-base); }
.seasonal__week .delta { font-size: var(--font-size-xl); font-weight: var(--font-weight-bold); }
.seasonal__week .delta--up { color: #c97124; }
.seasonal__week .delta--down { color: #1c5779; }
.seasonal__week .delta--flat { color: var(--color-muted); }
.seasonal__week .sub { color: var(--color-muted); font-size: var(--font-size-xs); }

/* ====== FAQ ====== */
.faq { display: flex; flex-direction: column; gap: var(--space-3); }
.faq details {
    background: var(--color-surface);
    border: 1px solid var(--color-border-soft);
    border-radius: var(--radius-md);
    padding: var(--space-4) var(--space-5);
}
.faq summary {
    cursor: pointer;
    font-weight: var(--font-weight-bold);
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-3);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-size: 22px; color: var(--color-primary); transition: transform .2s ease; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq p { margin: var(--space-3) 0 0; color: var(--color-muted); }

/* ====== Footer ====== */
.site-footer {
    margin-block-start: var(--space-9);
    padding-block: var(--space-7);
    border-block-start: 1px solid var(--color-border-soft);
    background: linear-gradient(180deg, transparent, var(--color-surface-deep));
}

.site-footer__grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: var(--space-6);
}

.site-footer .footer-heading { margin: 0 0 var(--space-3); color: var(--color-text); font-size: var(--font-size-base); font-weight: 800; }
.site-footer p, .site-footer a { color: var(--color-muted); }
.site-footer a:hover { color: var(--color-primary); }
.site-footer nav { display: flex; flex-direction: column; gap: 8px; }

@media (max-width: 760px) {
    .site-footer__grid { grid-template-columns: 1fr; }
}

.copy { font-size: var(--font-size-xs); color: var(--color-muted); text-align: center; padding-block: var(--space-4); }

/* ====== Breadcrumbs ====== */
.crumbs {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    color: var(--color-muted);
    font-size: var(--font-size-sm);
    padding-block: var(--space-4) 0;
}
.crumbs a:hover { color: var(--color-primary); }
.crumbs span[aria-hidden="true"] { color: var(--color-border); }

/* ====== Notice / Empty state ====== */
.notice {
    padding: var(--space-4);
    border-radius: var(--radius-md);
    background: var(--color-sun-soft);
    border: 1px solid rgba(245, 184, 75, .35);
    color: var(--color-sun-text);
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
}

.empty {
    padding: var(--space-6);
    border-radius: var(--radius-md);
    background: var(--color-surface-soft);
    border: 1px dashed var(--color-border);
    text-align: center;
    color: var(--color-muted);
}

/* ====== City page hero ====== */
.city-hero {
    display: grid;
    grid-template-columns: 1.3fr .9fr;
    gap: var(--space-6);
    padding-block: var(--space-7) var(--space-6);
    align-items: stretch;
}

.city-hero h1 { font-size: var(--font-size-4xl); margin: var(--space-3) 0; line-height: var(--line-height-tight); }
.city-hero p { color: var(--color-muted); }

@media (max-width: 980px) { .city-hero { grid-template-columns: 1fr; } }

/* ====== KPI mini cards ====== */
.kpis { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--space-3); }
@media (max-width: 880px) { .kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.kpi {
    background: var(--color-surface-soft);
    border: 1px solid var(--color-border-soft);
    border-radius: var(--radius-md);
    padding: var(--space-4);
}
.kpi span { color: var(--color-muted); font-size: var(--font-size-sm); display: block; }
.kpi strong { display: block; margin-block-start: 6px; font-size: var(--font-size-xl); font-weight: var(--font-weight-bold); }

/* ====== Misc ====== */
.icon { width: 22px; height: 22px; vertical-align: middle; }
.icon--sm { width: 16px; height: 16px; }
.icon--lg { width: 36px; height: 36px; }

.skip-link {
    position: absolute;
    inset-inline-start: var(--space-3);
    inset-block-start: var(--space-3);
    padding: 8px 12px;
    background: var(--color-primary);
    color: #fff;
    border-radius: var(--radius-md);
    transform: translateY(-150%);
    transition: transform .15s ease;
    z-index: 50;
}
.skip-link:focus { transform: translateY(0); }

.geolocate-banner {
    margin-block-start: var(--space-4);
    background: var(--color-primary-soft);
    border: 1px solid var(--color-border-soft);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    display: none;
    gap: var(--space-3);
    align-items: center;
    flex-wrap: wrap;
}
.geolocate-banner[data-state="ready"]:not([hidden]) { display: flex; }
.geolocate-banner strong { color: var(--color-primary); }

/* ====== Weather alerts ====== */
.alerts { display: flex; flex-direction: column; gap: var(--space-2); margin-block: var(--space-3); }
.alert { display: flex; align-items: center; gap: var(--space-3); padding: 12px 16px; border-radius: var(--radius-md); border: 1px solid; font-weight: var(--font-weight-bold); }
.alert .icon { width: 22px; height: 22px; flex: 0 0 auto; }
.alert--danger { background: #fdecec; border-color: #f5b5b5; color: #9b1c1c; }
.alert--warn { background: #fff4e0; border-color: #f3cf8c; color: #8a5a00; }
.alert--cold { background: #e8f1fb; border-color: #b7d3ef; color: #1c4a7a; }
.alert--info { background: var(--color-primary-soft); border-color: var(--color-border-soft); color: var(--color-primary); }

/* ====== Map embed ====== */
.map-embed { border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; background: var(--color-surface); }
.map-embed iframe { width: 100%; height: 320px; border: 0; display: block; }
.map-embed__link { display: inline-block; padding: 10px 14px; font-size: var(--font-size-sm); color: var(--color-primary); }

/* ====== Share row ====== */
.share { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2); }
.share__label { color: var(--color-muted); font-size: var(--font-size-sm); }
.share__btn { padding: 8px 14px; border-radius: var(--radius-pill); border: 1px solid var(--color-border); background: var(--color-surface); color: var(--color-text); font-size: var(--font-size-sm); cursor: pointer; }
.share__btn:hover { border-color: var(--color-primary); }
.share__btn--wa { background: #25d366; color: #fff; border-color: transparent; }
.share__btn--tg { background: #2aabee; color: #fff; border-color: transparent; }
.share__btn--x { background: #111; color: #fff; border-color: transparent; }
.share__btn--fb { background: #1877f2; color: #fff; border-color: transparent; }

/* ====== Saved location bar ====== */
.saved-loc { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); flex-wrap: wrap; padding: 10px 16px; margin-block-start: var(--space-4); background: var(--color-primary-soft); border: 1px solid var(--color-border-soft); border-radius: var(--radius-md); }

/* ====== Dark mode (overrides runtime theme tokens) ====== */
html[data-theme="dark"] {
    --color-bg: #0f1720;
    --color-surface: #16212e;
    --color-surface-soft: #1c2a39;
    --color-surface-deep: #0c131b;
    --color-text: #e8eef5;
    --color-muted: #9fb2c5;
    --color-border: #243443;
    --color-border-soft: #2d4051;
    --color-primary-soft: #15324a;
}
html[data-theme="dark"] body { background: var(--color-bg); }
html[data-theme="dark"] .alert--danger { background: #3a1d1d; color: #ffb4b4; border-color: #5e2b2b; }
html[data-theme="dark"] .alert--warn { background: #3a2e16; color: #f5cf8c; border-color: #5e4a1f; }
html[data-theme="dark"] .alert--cold { background: #16263a; color: #b7d3ef; border-color: #244563; }

/* ====== Period tabs (city/area) ====== */
.tabs__list {
    display: flex;
    gap: var(--space-2);
    overflow-x: auto;
    padding-block-end: var(--space-2);
    margin-block-end: var(--space-5);
    border-bottom: 1px solid var(--color-border);
    scrollbar-width: thin;
}
.tab {
    flex: 0 0 auto;
    padding: 10px 18px;
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-bold);
    color: var(--color-muted);
    white-space: nowrap;
    transition: background .15s ease, color .15s ease;
}
.tab:hover { color: var(--color-text); background: var(--color-surface); }
.tab.is-active { color: #fff; background: var(--color-primary); }
.tabpanel + .tabpanel { margin-block-start: var(--space-6); }
/* With JS only the active panel is shown; without JS all panels render (SEO). */
.js .tabpanel:not(.is-active) { display: none; }

/* ====== Compact location rows (homepage) ====== */
.loc-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 10px;
}
.loc-row {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    align-items: center;
    gap: var(--space-3);
    padding: 10px 14px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: inherit;
    transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.loc-row:hover { border-color: var(--color-primary); box-shadow: var(--shadow-soft); transform: translateY(-1px); }
.loc-row__icon {
    width: 38px; height: 38px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: var(--color-primary-soft);
    color: var(--color-primary);
    flex: 0 0 auto;
}
.loc-row__icon svg { width: 22px; height: 22px; }
.loc-row__name strong { display: block; font-weight: var(--font-weight-bold); }
.loc-row__name small { color: var(--color-muted); font-size: var(--font-size-xs); }
.loc-row__dn { font-size: var(--font-size-sm); white-space: nowrap; }
.loc-row__dn b { color: var(--color-sun-text); }
.loc-row__dn span { color: var(--color-muted); }
.loc-row__now { font-size: var(--font-size-xl); font-weight: var(--font-weight-bold); min-width: 46px; text-align: end; }

/* ====== Hourly temperature curve ====== */
.temp-chart { width: 100%; margin: 0; }
.temp-chart svg { width: 100%; height: auto; display: block; }
.temp-chart__area { fill: var(--color-primary-soft); opacity: .55; }
.temp-chart__line { fill: none; stroke: var(--color-primary); stroke-width: 2.5; stroke-linejoin: round; stroke-linecap: round; }
.temp-chart__dot { fill: var(--color-surface); stroke: var(--color-primary); stroke-width: 2; }
.temp-chart__dot--now { fill: var(--color-primary); }
.temp-chart__tval { fill: var(--color-text); font-size: 13px; font-weight: 700; text-anchor: middle; }
.temp-chart__tlabel { fill: var(--color-muted); font-size: 12px; text-anchor: middle; }

/* ====== Day mini-cards (week / 16-day / tomorrow) ====== */
.day-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
    gap: var(--space-3);
}
.day-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 6px;
    padding: var(--space-4) var(--space-3);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-soft);
    transition: transform .15s ease, box-shadow .15s ease;
}
.day-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-strong); }
.day-card--today { border-color: var(--color-primary); }
.day-card__day strong { display: block; font-size: var(--font-size-sm); }
.day-card__day small { color: var(--color-muted); font-size: var(--font-size-xs); }
.day-card__icon { width: 40px; height: 40px; color: var(--color-primary); }
.day-card__label { font-size: var(--font-size-xs); color: var(--color-muted); }
.day-card__temps { display: flex; gap: 8px; align-items: baseline; }
.day-card__temps strong { font-size: var(--font-size-xl); }
.day-card__temps span { color: var(--color-muted); }
.day-card__meta { display: flex; gap: var(--space-3); font-size: var(--font-size-xs); color: var(--color-muted); }
.day-card__meta span { display: inline-flex; align-items: center; gap: 4px; }
.day-card__meta svg { width: 14px; height: 14px; }

/* Unified primary weather card on home, city and area pages. */
.weather-card__title {
    margin: 8px 0 0;
    font-size: var(--font-size-3xl);
    line-height: var(--line-height-tight);
}
.weather-card__subtitle { margin: 4px 0 0; }
.weather-card__condition {
    background: rgba(255, 255, 255, .12);
    color: #fff;
    border-color: transparent;
}
.weather-card__link { color: #fff; margin-block-start: auto; }
