:root {
    --color-twistar-purple: #9600E1;
    --color-sparkle-purple: #CC9CDF;
    --color-midnight-blue:  #000030;
    --color-royal-blue:     #0000C8;
    --color-wine-red:       #C80000;
    --color-black:          #000000;
    --color-red:            #FF0000;
    --color-blue:           #0000FF;
    --color-pure-gold:      #FFD700;
    --color-white:          #f5f5ff;
    --color-muted:          #b9b9d695;
    --color-border:         rgba(204, 156, 223, 0.35);

    /* Gradient combinations */
    --gradient-primary:  linear-gradient(135deg, var(--color-twistar-purple) 0%, var(--color-royal-blue) 100%);
    --gradient-secondary: linear-gradient(135deg, var(--color-midnight-blue) 0%, var(--color-twistar-purple) 100%);
    --gradient-subtle:   linear-gradient(135deg, rgba(150, 0, 225, 0.1) 0%, rgba(0, 0, 200, 0.1) 100%);

    /* Shadows */
    --shadow-sm:     0 2px 8px rgba(150, 0, 225, 0.1);
    --shadow-md:     0 4px 16px rgba(150, 0, 225, 0.15);
    --shadow-lg:     0 10px 40px rgba(0, 0, 48, 0.3);
    --shadow-accent: 0 4px 20px rgba(150, 0, 225, 0.4);

    /* Spacing */
    --spacing-xs: 0.5rem;
    --spacing-sm: 1rem;
    --spacing-md: 1.5rem;
    --spacing-lg: 2rem;
    --spacing-xl: 3rem;

    /* Typography */
    --font-sans:  'Segoe UI', system-ui, -apple-system, sans-serif;
    --font-mono:  'Consolas', 'Courier New', monospace;
    --text-xs:    0.75rem;
    --text-sm:    0.875rem;
    --text-base:  1rem;
    --text-lg:    1.125rem;
    --text-xl:    1.25rem;
    --text-2xl:   1.5rem;
    --text-3xl:   2rem;

    /* Radius — sharp-edge UI: all corners square by design */
    --radius-sm:  0;
    --radius-md:  0;
    --radius-lg:  0;
    --radius-xl:  0;
    --radius-full: 0;

    /* Transitions */
    --transition-fast:   0.15s ease;
    --transition-normal: 0.25s ease;
}

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

html { -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    min-height: 100vh;
    font-family: var(--font-sans);
    font-size: var(--text-base);
    line-height: 1.6;
    color: var(--color-white);
    background:
        radial-gradient(1200px 600px at 80% -10%, rgba(150, 0, 225, 0.25), transparent 60%),
        radial-gradient(1000px 500px at -10% 10%, rgba(0, 0, 200, 0.25), transparent 55%),
        var(--color-midnight-blue);
    display: flex;
    flex-direction: column;
}

a { color: var(--color-sparkle-purple); text-decoration: none; transition: color var(--transition-fast); }
a:hover { color: var(--color-white); }

h1, h2, h3 { line-height: 1.25; }

img { max-width: 100%; height: auto; }

/* Full-width container: maximize real estate with side gutters.
   Desktop 100px · tablet 40px · mobile 10px (see media queries). */
.container { width: 100%; margin-inline: auto; padding-inline: 100px; }

.muted { color: var(--color-sparkle-purple); opacity: 0.85; }

.grad-text {
    background: linear-gradient(135deg, var(--color-sparkle-purple), var(--color-pure-gold));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.ta-right { text-align: right; }
.ta-center { text-align: center; }

/* ========================================================== Header ===== */
.site-header {
    position: sticky;
    top: 0;
    z-index: 10;
    backdrop-filter: blur(10px);
    background: rgba(0, 0, 48, 0.6);
    border-bottom: 1px solid var(--color-border);
}
.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-block: var(--spacing-sm);
}
.brand { display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 700; font-size: var(--text-xl); color: var(--color-white); }
.brand__mark { color: var(--color-pure-gold); filter: drop-shadow(0 0 6px rgba(255, 215, 0, 0.6)); }
.site-nav { display: flex; align-items: center; gap: var(--spacing-md); }
.site-nav a { color: var(--color-white); font-weight: 500; }
.site-nav a:hover { color: var(--color-sparkle-purple); }

.inline-form { display: inline; margin: 0; }
.link-btn {
    background: none; border: none; cursor: pointer; padding: 0;
    color: var(--color-sparkle-purple); font: inherit; font-weight: 500;
}
.link-btn:hover { color: var(--color-white); text-decoration: underline; }
.link-btn--danger { color: #ff8a8a; }
.link-btn--danger:hover { color: var(--color-red); }
.link-btn:disabled { opacity: 0.3; cursor: default; text-decoration: none; }

.links-toolbar { display: flex; align-items: center; gap: var(--spacing-md); margin-top: var(--spacing-lg); }
.links-order { white-space: nowrap; }
.links-order .link-btn { font-size: 1.1rem; line-height: 1; padding: 0 0.15rem; }

/* =========================================================== Main ====== */
.site-main { flex: 1; padding-block: var(--spacing-xl); }

.section { margin-block: var(--spacing-xl); }
.section--narrow { width: min(720px, 92vw); margin-inline: auto; }
.section__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--spacing-sm); }
.section__title { font-size: var(--text-2xl); margin: 0 0 var(--spacing-md); }
.section__more { font-size: var(--text-sm); }
.page-title { font-size: var(--text-3xl); margin: 0 0 var(--spacing-md); }

/* =========================================================== Hero ====== */
.hero {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--spacing-lg);
    align-items: center;
    padding: var(--spacing-xl);
    border-radius: var(--radius-xl);
    background: var(--gradient-subtle);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
}
.hero__title { font-size: clamp(2rem, 5vw, 3rem); margin: 0 0 var(--spacing-xs); }
.hero__tagline { font-size: var(--text-lg); color: var(--color-sparkle-purple); margin: 0 0 var(--spacing-lg); }
.hero__actions { display: flex; gap: var(--spacing-sm); flex-wrap: wrap; }

/* ========================================================= Buttons ===== */
.btn {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 0.65rem 1.25rem; border-radius: var(--radius-md);
    font-weight: 600; cursor: pointer; border: 1px solid transparent;
    transition: transform var(--transition-fast), box-shadow var(--transition-normal), background var(--transition-normal);
}
.btn:hover { transform: translateY(-1px); }
.btn--primary { background: var(--gradient-primary); color: var(--color-white); box-shadow: var(--shadow-accent); }
.btn--primary:hover { color: var(--color-white); }
.btn--ghost { background: transparent; border-color: var(--color-border); color: var(--color-white); }
.btn--ghost:hover { background: rgba(204, 156, 223, 0.12); color: var(--color-white); }
.btn--danger { color: #ff8a8a; border-color: rgba(255, 0, 0, 0.4); }
.btn--danger:hover { background: rgba(200, 0, 0, 0.18); color: #ffd0d0; }
.btn--block { width: 100%; }

/* ====================================================== Weather card === */
.weather-card {
    display: flex; align-items: center; gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--radius-lg);
    background: rgba(0, 0, 48, 0.55);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-md);
    min-width: 240px;
}
a.weather-card { color: var(--color-white); transition: transform var(--transition-fast), box-shadow var(--transition-normal), background var(--transition-normal); }
a.weather-card:hover { transform: translateY(-2px); background: rgba(150, 0, 225, 0.18); box-shadow: var(--shadow-accent); color: var(--color-white); }
.weather-card__icon { font-size: 3rem; line-height: 1; }
.weather-card__temp { font-size: var(--text-3xl); font-weight: 700; }
.weather-card__desc { color: var(--color-sparkle-purple); }
.weather-card__meta { font-size: var(--text-xs); color: var(--color-muted); margin-top: 0.25rem; }

/* ========================================================= Cards ======= */
.card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--spacing-md);
}
.app-card {
    display: flex; flex-direction: column; gap: 0.35rem;
    padding: var(--spacing-md);
    border-radius: var(--radius-lg);
    background: rgba(150, 0, 225, 0.08);
    border: 1px solid var(--color-border);
    color: var(--color-white);
    transition: transform var(--transition-fast), box-shadow var(--transition-normal), background var(--transition-normal);
}
.app-card:hover { transform: translateY(-3px); background: rgba(150, 0, 225, 0.16); box-shadow: var(--shadow-accent); color: var(--color-white); }
.app-card__icon { font-size: 1.75rem; }
.app-card__title { font-weight: 600; font-size: var(--text-lg); }
.app-card__desc { font-size: var(--text-sm); color: var(--color-sparkle-purple); }

/* ====================================================== Post list ====== */
.post-list { display: grid; gap: var(--spacing-md); }
.post-teaser {
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--radius-lg);
    background: rgba(0, 0, 48, 0.4);
    border: 1px solid var(--color-border);
}
.post-teaser__title { margin: 0 0 0.25rem; font-size: var(--text-xl); }
.post-teaser__title a { color: var(--color-white); }
.post-teaser__title a:hover { color: var(--color-sparkle-purple); }
.post-teaser__date { font-size: var(--text-xs); color: var(--color-muted); }
.post-teaser__excerpt { margin: var(--spacing-xs) 0 0; color: var(--color-sparkle-purple); }
.read-more { display: inline-block; margin-top: var(--spacing-xs); font-weight: 600; }

.pagination { display: flex; align-items: center; justify-content: center; gap: var(--spacing-md); margin-top: var(--spacing-lg); }
.pagination__info { color: var(--color-muted); font-size: var(--text-sm); }

/* ===================================================== Single post ===== */
.post { width: min(760px, 92vw); margin-inline: auto; }
.post__header { margin-bottom: var(--spacing-lg); }
.post__title { font-size: var(--text-3xl); margin: var(--spacing-xs) 0; }
.post__date { color: var(--color-muted); font-size: var(--text-sm); }
.back-link { font-size: var(--text-sm); }

/* Custom pages reuse the post/prose typography. */
.page { width: min(760px, 92vw); margin-inline: auto; }
.page__header { margin-bottom: var(--spacing-lg); }
.page__title { font-size: var(--text-3xl); margin: var(--spacing-xs) 0; }
.field__hint { font-size: var(--text-xs); }

.prose { font-size: var(--text-lg); }
.prose h1, .prose h2, .prose h3 { margin-top: var(--spacing-lg); }
.prose a { text-decoration: underline; }
.prose code { font-family: var(--font-mono); background: rgba(204, 156, 223, 0.15); padding: 0.1em 0.35em; border-radius: var(--radius-sm); }
.prose pre { background: rgba(0, 0, 0, 0.4); border: 1px solid var(--color-border); padding: var(--spacing-md); border-radius: var(--radius-md); overflow-x: auto; }
.prose pre code { background: none; padding: 0; }
.prose blockquote { margin: var(--spacing-md) 0; padding-left: var(--spacing-md); border-left: 3px solid var(--color-twistar-purple); color: var(--color-sparkle-purple); }
.prose img { border-radius: var(--radius-md); }

/* ============================================================ Auth ===== */
.auth { display: flex; justify-content: center; padding-block: var(--spacing-xl); }
.auth__card {
    width: min(400px, 92vw);
    padding: var(--spacing-xl);
    border-radius: var(--radius-xl);
    background: rgba(0, 0, 48, 0.6);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
}
.auth__title { margin: 0 0 var(--spacing-md); text-align: center; }
.auth__reset { margin-top: var(--spacing-lg); padding-top: var(--spacing-md); border-top: 1px solid var(--color-border); }
.auth__reset-text { font-size: var(--text-xs); margin: 0; }

/* =========================================================== Forms ===== */
.form { display: grid; gap: var(--spacing-md); }
.form__section { margin: var(--spacing-md) 0 0; font-size: var(--text-xl); border-bottom: 1px solid var(--color-border); padding-bottom: var(--spacing-xs); }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-md); }
.form__actions { display: flex; gap: var(--spacing-sm); }
.field { display: grid; gap: 0.35rem; }
.field--inline { display: flex; align-items: center; gap: 0.5rem; }
.field--icon { max-width: 160px; }
.field__label { font-size: var(--text-sm); font-weight: 600; color: var(--color-sparkle-purple); }
.field__input {
    width: 100%;
    padding: 0.6rem 0.8rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    background: rgba(0, 0, 0, 0.25);
    color: var(--color-white);
    font: inherit;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.field__input:focus { outline: none; border-color: var(--color-twistar-purple); box-shadow: 0 0 0 3px rgba(150, 0, 225, 0.25); }
.field__textarea { resize: vertical; font-family: var(--font-mono); }
.card-form { padding: var(--spacing-lg); border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: rgba(0, 0, 48, 0.4); margin-bottom: var(--spacing-lg); }

.alert { padding: 0.75rem 1rem; border-radius: var(--radius-md); font-size: var(--text-sm); }
.alert--error { background: rgba(200, 0, 0, 0.18); border: 1px solid rgba(255, 0, 0, 0.4); color: #ffd0d0; }
.alert--ok { background: rgba(150, 0, 225, 0.18); border: 1px solid var(--color-border); color: var(--color-sparkle-purple); }

/* ====================================================== Admin bits ===== */
.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: var(--spacing-md); margin-block: var(--spacing-lg); }
.stat {
    padding: var(--spacing-md); text-align: center;
    border-radius: var(--radius-lg); background: var(--gradient-subtle); border: 1px solid var(--color-border);
}
.stat__num { display: block; font-size: var(--text-3xl); font-weight: 700; }
.stat__label { font-size: var(--text-sm); color: var(--color-sparkle-purple); }
.admin-actions { display: flex; flex-wrap: wrap; gap: var(--spacing-sm); }

.data-table { width: 100%; border-collapse: collapse; margin-top: var(--spacing-md); }
.data-table th, .data-table td { padding: 0.65rem 0.75rem; text-align: left; border-bottom: 1px solid var(--color-border); vertical-align: top; }
.data-table td { overflow-wrap: anywhere; }  /* long URLs wrap instead of forcing horizontal overflow */
.data-table th { font-size: var(--text-sm); color: var(--color-sparkle-purple); text-transform: uppercase; letter-spacing: 0.04em; }
.badge { display: inline-block; padding: 0.15rem 0.6rem; border-radius: var(--radius-full); font-size: var(--text-xs); font-weight: 600; }
.badge--ok { background: rgba(150, 0, 225, 0.3); color: var(--color-white); }
.badge--muted { background: rgba(185, 185, 214, 0.2); color: var(--color-sparkle-purple); }

.empty-state { text-align: center; }

/* ===================================================== Admin shell ===== */
.admin-shell {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: var(--spacing-lg);
    align-items: start;
    padding-block: var(--spacing-xl);
    flex: 1;
}
.admin-main { min-width: 0; }                /* prevents grid blowout from wide tables */
.admin-main .section { margin-top: 0; }      /* sidebar already provides top spacing */
/* In the admin grid, fill the content column left-aligned: the global
   `margin-inline:auto` + viewport-relative 92vw would otherwise centre the
   section and overflow the column's right padding. */
.admin-main .section--narrow { width: 100%; max-width: 720px; margin-inline: 0; }

.admin-sidebar {
    position: sticky;
    top: calc(var(--spacing-lg) + 56px);     /* clears the sticky site header */
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm);
    background: rgba(0, 0, 48, 0.5);
    border: 1px solid var(--color-border);
}
.admin-sidebar__label {
    margin: 0 0 var(--spacing-xs);
    padding: 0 0.6rem;
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-muted);
}
.admin-sidebar__nav { display: flex; flex-direction: column; gap: 2px; }
.admin-sidebar__link {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.55rem 0.7rem;
    color: var(--color-white);
    font-weight: 500;
    border-left: 3px solid transparent;
    transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
    /* reset for the <button> variant */
    width: 100%;
    background: none;
    border-top: none;
    border-right: none;
    border-bottom: none;
    font: inherit;
    text-align: left;
    cursor: pointer;
}
.admin-sidebar__link:hover { background: rgba(204, 156, 223, 0.12); color: var(--color-white); }
.admin-sidebar__link.is-active {
    background: var(--gradient-subtle);
    border-left-color: var(--color-twistar-purple);
    color: var(--color-white);
}
.admin-sidebar__icon { width: 1.2em; text-align: center; opacity: 0.9; }
.admin-sidebar__footer {
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-sm);
    border-top: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
    gap: 2px;
}

@media (max-width: 720px) {
    .admin-shell { grid-template-columns: 1fr; }
    .admin-sidebar { position: static; top: auto; }
    .admin-sidebar__nav { flex-direction: row; flex-wrap: wrap; }
    .admin-sidebar__footer { flex-direction: row; }
}

/* ======================================================== Footer ====== */
.site-footer { border-top: 1px solid var(--color-border); padding: 0.45rem var(--spacing-sm); text-align: center; color: var(--color-muted); font-size: var(--text-xs); line-height: 1.4; }

/* ====================================================== Responsive ===== */
/* Tablet: reduce the wide desktop gutters. */
@media (max-width: 1024px) {
    .container { padding-inline: 40px; }
}

/* Mobile: tight 10px gutters to maximize content width. */
@media (max-width: 720px) {
    .container { padding-inline: 10px; }
    .hero { grid-template-columns: 1fr; padding: var(--spacing-lg); }
    .form__row { grid-template-columns: 1fr; }
    .site-nav { gap: var(--spacing-sm); }
    .hero__actions { flex-wrap: wrap; }
}

/* ===================================================== Weather page ===== */
.btn--sm { padding: 0.35rem 0.7rem; font-size: var(--text-sm); }

/* Location tiles (index) */
.wx-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
}
.wx-tile {
    display: flex; flex-direction: column; gap: 0.5rem;
    padding: var(--spacing-md);
    background: rgba(0, 0, 48, 0.55);
    border: 1px solid var(--color-border);
    color: var(--color-white);
    transition: transform var(--transition-fast), box-shadow var(--transition-normal), background var(--transition-normal);
}
.wx-tile:hover { transform: translateY(-3px); background: rgba(150, 0, 225, 0.16); box-shadow: var(--shadow-accent); color: var(--color-white); }
.wx-tile__head { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--spacing-sm); }
.wx-tile__label { display: block; font-weight: 700; font-size: var(--text-lg); }
.wx-tile__place { display: block; font-size: var(--text-xs); }
.wx-tile__now { display: flex; align-items: center; gap: 0.4rem; white-space: nowrap; }
.wx-tile__icon { font-size: 1.8rem; line-height: 1; }
.wx-tile__temp { font-size: var(--text-xl); font-weight: 700; }
.wx-tile__desc { color: var(--color-sparkle-purple); font-size: var(--text-sm); }
.wx-strip { display: flex; gap: 0.25rem; justify-content: space-between; margin-top: 0.25rem; }
.wx-strip__day { display: flex; flex-direction: column; align-items: center; gap: 0.1rem; flex: 1; font-size: var(--text-xs); }
.wx-strip__dow { color: var(--color-muted); }
.wx-strip__icon { font-size: 1.1rem; }
.wx-strip__hi { font-weight: 600; }

/* Detail page */
.wx-back { display: inline-block; margin-bottom: var(--spacing-sm); color: var(--color-sparkle-purple); }
.wx-current { display: flex; align-items: center; gap: var(--spacing-md); margin: var(--spacing-md) 0; }
.wx-current__icon { font-size: 3.5rem; line-height: 1; }
.wx-current__temp { font-size: var(--text-3xl); font-weight: 700; }
.wx-current__desc { color: var(--color-sparkle-purple); }
.wx-now-note { margin: 0 0 var(--spacing-sm); }
.wx-figure { margin: 0 0 var(--spacing-md); }
.wx-figure figcaption { font-size: var(--text-xs); margin-top: 0.35rem; }

/* Current-conditions stat grid */
.wx-stats {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: var(--spacing-sm);
    margin: 0 0 var(--spacing-md);
}
.wx-stat {
    padding: var(--spacing-sm);
    background: rgba(0, 0, 48, 0.55);
    border: 1px solid var(--color-border);
}
.wx-stat--accent { border-color: var(--color-pure-gold); }
.wx-stat dt { font-size: var(--text-xs); color: var(--color-sparkle-purple); text-transform: uppercase; letter-spacing: 0.04em; }
.wx-stat dd { margin: 0.25rem 0 0; font-size: var(--text-xl); font-weight: 700; }
.wx-stat--accent dd { color: var(--color-pure-gold); }
.wx-stat__u { font-size: var(--text-xs); font-weight: 400; color: var(--color-muted); margin-left: 0.3rem; }

/* Weather-Network-style forecast cards */
.wx-cards {
    display: flex; gap: var(--spacing-sm);
    overflow-x: auto; padding-bottom: 0.5rem;
    margin: 0 0 var(--spacing-md);
}
.wx-card {
    flex: 0 0 auto; width: 110px; text-align: center;
    padding: var(--spacing-sm) 0.5rem;
    background: rgba(0, 0, 48, 0.55);
    border: 1px solid var(--color-border);
}
.wx-card--today { border-color: var(--color-pure-gold); background: rgba(150, 0, 225, 0.16); }
.wx-card__dow { font-weight: 700; }
.wx-card__date { font-size: var(--text-xs); color: var(--color-muted); }
.wx-card__icon { font-size: 1.8rem; line-height: 1.6; }
.wx-card__desc { font-size: var(--text-xs); color: var(--color-sparkle-purple); min-height: 2.2em; }
.wx-card__temps { margin: 0.35rem 0 0.25rem; }
.wx-card__hi { font-weight: 700; }
.wx-card__lo { color: var(--color-sparkle-purple); margin-left: 0.3rem; }
.wx-card__meta { font-size: var(--text-xs); color: var(--color-muted); }

/* Inline SVG charts */
.wx-chart {
    width: 100%; height: auto; display: block;
    background: rgba(0, 0, 48, 0.45);
    border: 1px solid var(--color-border);
    padding: 0.25rem;
}
.wx-chart__band { fill: rgba(150, 0, 225, 0.18); stroke: none; }
.wx-chart__high { fill: none; stroke: var(--color-pure-gold); stroke-width: 2; vector-effect: non-scaling-stroke; }
.wx-chart__low { fill: none; stroke: var(--color-sparkle-purple); stroke-width: 2; vector-effect: non-scaling-stroke; }
.wx-chart__today { stroke: var(--color-white); stroke-width: 1; stroke-dasharray: 3 3; opacity: 0.5; vector-effect: non-scaling-stroke; }
.wx-chart__axis { fill: var(--color-muted); font-size: 11px; }
.wx-chart__bar { fill: var(--color-twistar-purple); }
.wx-chart__barval { fill: var(--color-sparkle-purple); font-size: 10px; }
.wx-chart__val { font-size: 11px; font-weight: 700; }
.wx-chart__val--hi { fill: var(--color-pure-gold); }
.wx-chart__val--lo { fill: var(--color-sparkle-purple); }
.wx-noprecip { padding: var(--spacing-sm) 0; }

.wx-table-wrap { overflow-x: auto; }
.wx-details { margin-top: var(--spacing-sm); }
.wx-details summary { cursor: pointer; color: var(--color-sparkle-purple); }

/* Geocoding autocomplete (settings) + search */
.wx-geocode { position: relative; }
.wx-geocode__results {
    list-style: none; margin: 0.25rem 0 0; padding: 0;
    position: absolute; left: 0; right: 0; z-index: 20;
    background: var(--color-midnight-blue);
    border: 1px solid var(--color-border);
    max-height: 260px; overflow-y: auto;
}
.wx-geocode__item {
    display: block; width: 100%; text-align: left;
    padding: 0.5rem 0.75rem; background: transparent; border: 0;
    color: var(--color-white); cursor: pointer;
}
.wx-geocode__item:hover { background: rgba(150, 0, 225, 0.2); }
