/* =========================================================
   RELI Journal, style.css
   Version: 20260420a  (keep in sync with includes/config.php)
   Mobile-first. One sheet. No framework.
   ========================================================= */

/* ---------- 1. Design tokens ---------- */
:root {
    /* Palette: warm editorial notebook */
    --color-bg: #fbf7f1;
    --color-bg-alt: #f3ede2;
    --color-bg-card: #ffffff;
    --color-ink: #1a1a1a;
    --color-ink-soft: #3d3d3d;
    --color-ink-mute: #6b6b6b;
    --color-rule: #e4dccd;
    --color-rule-strong: #c9bca5;
    --color-accent: #b8552e;     /* ochre / terracotta */
    --color-accent-dark: #8c3d1c;
    --color-accent-soft: #f6e6da;
    --color-highlight: #f5d98f;
    --color-ok: #2f7d4a;
    --color-warn: #9a6a00;

    /* Typography */
    --font-serif: Georgia, 'Iowan Old Style', 'Palatino Linotype', 'Source Serif Pro', serif;
    --font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

    --fs-xxs: 0.75rem;
    --fs-xs: 0.8125rem;
    --fs-sm: 0.9375rem;
    --fs-md: 1.0625rem;
    --fs-lg: 1.1875rem;
    --fs-xl: 1.5rem;
    --fs-2xl: 2rem;
    --fs-3xl: 2.625rem;
    --fs-4xl: 3.25rem;

    --lh-tight: 1.2;
    --lh-snug: 1.35;
    --lh-body: 1.65;

    /* Spacing scale */
    --sp-1: 0.25rem;
    --sp-2: 0.5rem;
    --sp-3: 0.75rem;
    --sp-4: 1rem;
    --sp-5: 1.5rem;
    --sp-6: 2rem;
    --sp-7: 3rem;
    --sp-8: 4rem;
    --sp-9: 6rem;

    /* Layout */
    --wrap-wide: 1200px;
    --wrap-text: 720px;
    --wrap-narrow: 560px;
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 14px;

    --shadow-soft: 0 1px 2px rgba(0,0,0,.04), 0 2px 8px rgba(0,0,0,.04);
    --shadow-hover: 0 4px 20px rgba(0,0,0,.08);

    --focus-ring: 2px solid var(--color-accent);
    --focus-offset: 3px;
}

/* ---------- 2. Reset, base ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    background: var(--color-bg);
    color: var(--color-ink);
    font-family: var(--font-sans);
    font-size: var(--fs-md);
    line-height: var(--lh-body);
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
}

img, picture, svg, video {
    display: block;
    max-width: 100%;
    height: auto;
}

a {
    color: var(--color-accent-dark);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}
a:hover { color: var(--color-accent); }

:focus-visible {
    outline: var(--focus-ring);
    outline-offset: var(--focus-offset);
    border-radius: var(--radius-sm);
}

hr {
    border: 0;
    border-top: 1px solid var(--color-rule);
    margin: var(--sp-6) 0;
}

ul, ol { padding-left: 1.25rem; }
li + li { margin-top: var(--sp-2); }

blockquote {
    margin: var(--sp-5) 0;
    padding: var(--sp-4) var(--sp-5);
    border-left: 3px solid var(--color-accent);
    background: var(--color-bg-alt);
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--color-ink-soft);
}

code, kbd, samp {
    font-family: var(--font-mono);
    font-size: 0.9em;
    background: var(--color-bg-alt);
    padding: 0.1em 0.35em;
    border-radius: var(--radius-sm);
}

table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--sp-5) 0;
    font-size: var(--fs-sm);
}
th, td {
    text-align: left;
    padding: var(--sp-3) var(--sp-4);
    border-bottom: 1px solid var(--color-rule);
    vertical-align: top;
}
th {
    background: var(--color-bg-alt);
    font-family: var(--font-serif);
    font-weight: 600;
}
table caption {
    caption-side: top;
    text-align: left;
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--color-ink-mute);
    margin-bottom: var(--sp-2);
}

/* ---------- 3. Typography scale ---------- */
h1, h2, h3, h4 {
    font-family: var(--font-serif);
    line-height: var(--lh-tight);
    color: var(--color-ink);
    margin: 0 0 var(--sp-4);
    letter-spacing: -0.01em;
}
h1 { font-size: var(--fs-3xl); font-weight: 700; }
h2 { font-size: var(--fs-2xl); font-weight: 700; margin-top: var(--sp-7); }
h3 { font-size: var(--fs-xl); font-weight: 600; margin-top: var(--sp-6); }
h4 { font-size: var(--fs-lg); font-weight: 600; margin-top: var(--sp-5); }

p { margin: 0 0 var(--sp-4); }
.lead {
    font-family: var(--font-serif);
    font-size: var(--fs-lg);
    color: var(--color-ink-soft);
    line-height: var(--lh-snug);
}

@media (min-width: 768px) {
    h1 { font-size: var(--fs-4xl); }
    h2 { font-size: 2.25rem; }
}

/* ---------- 4. Layout primitives ---------- */
.skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    background: var(--color-ink);
    color: #fff;
    padding: var(--sp-3) var(--sp-4);
    z-index: 1000;
}
.skip-link:focus { left: var(--sp-3); top: var(--sp-3); }

.wrap {
    width: 100%;
    max-width: var(--wrap-wide);
    margin: 0 auto;
    padding-left: var(--sp-4);
    padding-right: var(--sp-4);
}
.wrap--text {
    max-width: var(--wrap-text);
}
.wrap--narrow {
    max-width: var(--wrap-narrow);
}

.section {
    padding-block: var(--sp-7);
}
.section--tight { padding-block: var(--sp-5); }
.section--alt { background: var(--color-bg-alt); }

/* ---------- 5. Header, primary nav ---------- */
.site-header {
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-rule);
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: saturate(120%) blur(6px);
}
.site-header__inner {
    display: flex;
    align-items: center;
    gap: var(--sp-4);
    padding-block: var(--sp-3);
}
.site-logo {
    font-family: var(--font-serif);
    font-weight: 700;
    font-size: 1.25rem;
    color: var(--color-ink);
    text-decoration: none;
    letter-spacing: -0.01em;
}
.site-logo span {
    color: var(--color-accent);
}

.primary-nav {
    margin-left: auto;
}
.primary-nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-4);
}
.primary-nav li { margin: 0; }
.primary-nav a {
    color: var(--color-ink-soft);
    font-size: var(--fs-sm);
    font-weight: 500;
    text-decoration: none;
    padding: var(--sp-2) var(--sp-1);
    border-bottom: 2px solid transparent;
}
.primary-nav a:hover,
.primary-nav a[aria-current="page"] {
    color: var(--color-accent-dark);
    border-bottom-color: var(--color-accent);
}

.nav-toggle {
    display: none;
    margin-left: auto;
    background: transparent;
    border: 1px solid var(--color-rule-strong);
    border-radius: var(--radius-sm);
    padding: var(--sp-2) var(--sp-3);
    font-family: var(--font-sans);
    font-size: var(--fs-sm);
    cursor: pointer;
    color: var(--color-ink);
}

@media (max-width: 900px) {
    .nav-toggle { display: inline-flex; }
    .primary-nav {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: var(--color-bg);
        border-bottom: 1px solid var(--color-rule);
        padding: var(--sp-4);
    }
    .primary-nav[data-open="true"] { display: block; }
    .primary-nav ul { flex-direction: column; gap: var(--sp-3); }
}

/* ---------- 6. Breadcrumbs ---------- */
.breadcrumbs {
    padding-block: var(--sp-3);
    font-size: var(--fs-xs);
    color: var(--color-ink-mute);
}
.breadcrumbs ol {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-2);
}
.breadcrumbs li { margin: 0; }
.breadcrumbs li + li::before {
    content: "›";
    margin-right: var(--sp-2);
    color: var(--color-rule-strong);
}
.breadcrumbs a {
    color: var(--color-ink-mute);
    text-decoration: none;
}
.breadcrumbs a:hover { color: var(--color-accent-dark); text-decoration: underline; }
.breadcrumbs [aria-current="page"] {
    color: var(--color-ink);
    font-weight: 500;
}

/* ---------- 7. Hero ---------- */
.hero {
    padding-block: var(--sp-6) var(--sp-5);
}
.hero__kicker {
    display: inline-block;
    font-size: var(--fs-xs);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-accent-dark);
    background: var(--color-accent-soft);
    padding: var(--sp-1) var(--sp-3);
    border-radius: 999px;
    margin-bottom: var(--sp-4);
    font-weight: 600;
}
.hero__title {
    font-size: clamp(2rem, 5vw, 3.5rem);
    line-height: 1.1;
    margin-bottom: var(--sp-4);
    max-width: 22ch;
}
.hero__lead {
    font-family: var(--font-serif);
    font-size: var(--fs-lg);
    color: var(--color-ink-soft);
    max-width: 58ch;
    margin-bottom: var(--sp-5);
}
.hero__cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-3);
    margin-bottom: var(--sp-6);
}
.hero__media {
    margin-top: var(--sp-5);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-soft);
    background: var(--color-bg-alt);
    aspect-ratio: 16 / 9;
}
.hero__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero--article .hero__title { max-width: 28ch; font-size: clamp(1.75rem, 4vw, 2.75rem); }

/* ---------- 8. Buttons ---------- */
.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    padding: var(--sp-3) var(--sp-5);
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: var(--fs-sm);
    text-decoration: none;
    border-radius: 999px;
    border: 1px solid transparent;
    cursor: pointer;
    transition: transform .08s ease, background .15s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn--primary {
    background: var(--color-accent);
    color: #fff;
}
.btn--primary:hover { background: var(--color-accent-dark); color: #fff; }
.btn--ghost {
    background: transparent;
    color: var(--color-ink);
    border-color: var(--color-rule-strong);
}
.btn--ghost:hover { border-color: var(--color-accent); color: var(--color-accent-dark); }

/* ---------- 9. TL;DR / summary box ---------- */
.tldr {
    position: relative;
    background: var(--color-bg-card);
    border: 1px solid var(--color-rule);
    border-left: 4px solid var(--color-accent);
    border-radius: var(--radius-md);
    padding: var(--sp-5) var(--sp-5) var(--sp-4);
    margin: var(--sp-5) 0 var(--sp-6);
    box-shadow: var(--shadow-soft);
}
.tldr__label {
    display: inline-block;
    font-size: var(--fs-xxs);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--color-accent-dark);
    font-weight: 700;
    margin-bottom: var(--sp-2);
}
.tldr__title {
    font-family: var(--font-serif);
    font-size: var(--fs-lg);
    margin: 0 0 var(--sp-2);
}
.tldr p {
    margin: 0;
    font-size: var(--fs-md);
    color: var(--color-ink-soft);
}

/* ---------- 10. Article body ---------- */
.article-body {
    max-width: var(--wrap-text);
    margin-inline: auto;
    font-size: 1.125rem;
    line-height: 1.7;
}
.article-body > * { margin-inline: auto; }
.article-body h2 { margin-top: var(--sp-7); }
.article-body h3 { margin-top: var(--sp-5); }
.article-body p,
.article-body ul,
.article-body ol,
.article-body blockquote,
.article-body figure,
.article-body table {
    max-width: var(--wrap-text);
}
.article-body img,
.article-body figure {
    margin-block: var(--sp-5);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.article-body figcaption {
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--color-ink-mute);
    font-size: var(--fs-sm);
    margin-top: var(--sp-2);
    text-align: center;
}
.article-body ol li::marker {
    color: var(--color-accent);
    font-weight: 600;
}

/* ---------- 11. Callouts ---------- */
.callout {
    border-radius: var(--radius-md);
    padding: var(--sp-5);
    margin: var(--sp-6) 0;
    border: 1px solid var(--color-rule);
    background: var(--color-bg-card);
}
.callout__label {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    font-size: var(--fs-xxs);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 700;
    margin-bottom: var(--sp-2);
}
.callout__title {
    font-family: var(--font-serif);
    font-size: var(--fs-lg);
    margin: 0 0 var(--sp-2);
}
.callout p:last-child { margin-bottom: 0; }

.callout--tip {
    background: #fdf6e4;
    border-color: #ead9a8;
}
.callout--tip .callout__label { color: var(--color-warn); }

.callout--avoid {
    background: #f8ebe6;
    border-color: #e7c7bc;
}
.callout--avoid .callout__label { color: #a23a1c; }

.callout--note {
    background: var(--color-bg-alt);
}
.callout--note .callout__label { color: var(--color-ink-mute); }

/* ---------- 12. Cards, grids ---------- */
.card-grid {
    display: grid;
    gap: var(--sp-5);
    grid-template-columns: 1fr;
}
@media (min-width: 640px) {
    .card-grid--2 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px) {
    .card-grid--3 { grid-template-columns: repeat(3, 1fr); }
    .card-grid--auto { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
}

.card {
    display: flex;
    flex-direction: column;
    background: var(--color-bg-card);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
    text-decoration: none;
    color: inherit;
}
.card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
    border-color: var(--color-rule-strong);
}
.card__media {
    aspect-ratio: 3 / 2;
    background: var(--color-bg-alt);
    overflow: hidden;
}
.card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.card__body {
    padding: var(--sp-4) var(--sp-5) var(--sp-5);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
}
.card__kicker {
    font-size: var(--fs-xxs);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-accent-dark);
    font-weight: 600;
}
.card__title {
    font-family: var(--font-serif);
    font-size: var(--fs-lg);
    line-height: 1.25;
    margin: 0;
}
.card__excerpt {
    color: var(--color-ink-soft);
    font-size: var(--fs-sm);
    margin: 0;
}
.card__cta {
    margin-top: auto;
    font-size: var(--fs-sm);
    font-weight: 600;
    color: var(--color-accent-dark);
}

.card--feature {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 1fr;
}
@media (min-width: 768px) {
    .card--feature { grid-template-columns: 1.1fr 1fr; }
    .card--feature .card__media { aspect-ratio: auto; height: 100%; }
}

/* ---------- 13. Category hub, sub-hub extras ---------- */
.hub-intro {
    max-width: var(--wrap-text);
    margin-inline: auto;
    font-family: var(--font-serif);
    font-size: var(--fs-lg);
    color: var(--color-ink-soft);
    line-height: var(--lh-snug);
}
.hub-spotlight {
    background: var(--color-accent-soft);
    border: 1px solid #ecd0bc;
    border-radius: var(--radius-lg);
    padding: var(--sp-6);
    margin-block: var(--sp-6);
}
.hub-spotlight__kicker {
    font-size: var(--fs-xxs);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--color-accent-dark);
    font-weight: 700;
}
.hub-spotlight__title {
    font-family: var(--font-serif);
    font-size: var(--fs-2xl);
    margin: var(--sp-2) 0 var(--sp-3);
}

/* ---------- 14. Pitch three-points ---------- */
.pitch {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-5);
}
@media (min-width: 768px) {
    .pitch { grid-template-columns: repeat(3, 1fr); }
}
.pitch__item {
    padding: var(--sp-5);
    border-left: 3px solid var(--color-accent);
    background: var(--color-bg-card);
    border-radius: var(--radius-md);
}
.pitch__title {
    font-family: var(--font-serif);
    font-size: var(--fs-lg);
    margin: 0 0 var(--sp-2);
}
.pitch__item p { margin: 0; color: var(--color-ink-soft); font-size: var(--fs-sm); }

/* ---------- 15. About block, author teaser ---------- */
.author-teaser {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-5);
    align-items: center;
    background: var(--color-bg-card);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    padding: var(--sp-6);
}
@media (min-width: 640px) {
    .author-teaser { grid-template-columns: 160px 1fr; }
}
.author-teaser__img {
    width: 160px;
    height: 160px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--color-bg-alt);
    margin-inline: auto;
}
.author-teaser__img img { width: 100%; height: 100%; object-fit: cover; }
.author-teaser__title {
    font-family: var(--font-serif);
    font-size: var(--fs-xl);
    margin: 0 0 var(--sp-2);
}

/* ---------- 16. FAQ ---------- */
.faq {
    max-width: var(--wrap-text);
    margin-inline: auto;
}
.faq details {
    background: var(--color-bg-card);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-md);
    padding: var(--sp-4) var(--sp-5);
    margin-bottom: var(--sp-3);
}
.faq details[open] { border-color: var(--color-rule-strong); }
.faq summary {
    cursor: pointer;
    font-family: var(--font-serif);
    font-weight: 600;
    font-size: var(--fs-md);
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--sp-3);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
    content: "+";
    font-size: 1.25rem;
    color: var(--color-accent);
    transition: transform .15s ease;
}
.faq details[open] summary::after { content: "–"; }
.faq details > *:not(summary) {
    margin-top: var(--sp-3);
    color: var(--color-ink-soft);
}

/* ---------- 17. Related articles ---------- */
.related {
    border-top: 1px solid var(--color-rule);
    margin-top: var(--sp-8);
    padding-top: var(--sp-6);
}
.related__title {
    font-family: var(--font-serif);
    font-size: var(--fs-xl);
    margin: 0 0 var(--sp-5);
}

/* ---------- 18. Sidelinks (hub to hub) ---------- */
.sidelinks {
    display: grid;
    gap: var(--sp-4);
    grid-template-columns: 1fr;
}
@media (min-width: 640px) {
    .sidelinks { grid-template-columns: repeat(2, 1fr); }
}
.sidelinks a {
    display: block;
    padding: var(--sp-5);
    background: var(--color-bg-card);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-md);
    text-decoration: none;
    color: inherit;
    transition: border-color .15s ease, transform .15s ease;
}
.sidelinks a:hover { border-color: var(--color-accent); transform: translateY(-2px); }
.sidelinks__kicker {
    font-size: var(--fs-xxs);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-ink-mute);
    font-weight: 600;
}
.sidelinks__title {
    font-family: var(--font-serif);
    font-size: var(--fs-lg);
    margin: var(--sp-2) 0 0;
}

/* ---------- 19. Chart block ---------- */
.chart {
    margin-block: var(--sp-6);
}
.chart__canvas-wrap {
    background: var(--color-bg-card);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-md);
    padding: var(--sp-5);
    position: relative;
    min-height: 280px;
}
.chart__title {
    font-family: var(--font-serif);
    font-size: var(--fs-lg);
    margin: 0 0 var(--sp-3);
}
.chart__caption {
    font-size: var(--fs-sm);
    color: var(--color-ink-mute);
    margin-top: var(--sp-2);
    font-style: italic;
}
.chart__fallback {
    margin-top: var(--sp-4);
}

/* ---------- 20. Comparison tool (Model E) ---------- */
.compare-table th:first-child,
.compare-table td:first-child {
    font-weight: 600;
    background: var(--color-bg-alt);
}
.compare-verdict {
    display: inline-block;
    font-size: var(--fs-sm);
    font-weight: 600;
    background: var(--color-highlight);
    color: #4a3a00;
    padding: var(--sp-2) var(--sp-3);
    border-radius: var(--radius-sm);
    margin-top: var(--sp-3);
}

/* ---------- 21. Newsletter opt-in ---------- */
.newsletter {
    background: var(--color-ink);
    color: #fbf7f1;
    border-radius: var(--radius-lg);
    padding: var(--sp-7);
    text-align: center;
}
.newsletter h2 { color: #fff; margin-top: 0; }
.newsletter p { color: #d7cfc0; max-width: 50ch; margin-inline: auto; }
.newsletter__form {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-3);
    justify-content: center;
    margin-top: var(--sp-5);
}
.newsletter input[type="email"] {
    flex: 1 1 240px;
    max-width: 320px;
    padding: var(--sp-3) var(--sp-4);
    border-radius: 999px;
    border: 1px solid #4a4a4a;
    background: #2a2a2a;
    color: #fff;
    font-size: var(--fs-sm);
}
.newsletter__consent {
    display: block;
    margin-top: var(--sp-3);
    font-size: var(--fs-xs);
    color: #a8a196;
}

/* ---------- 22. Contact form ---------- */
.contact-form {
    max-width: var(--wrap-narrow);
    margin-inline: auto;
    background: var(--color-bg-card);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    padding: var(--sp-6);
}
.field { margin-bottom: var(--sp-5); }
.field label {
    display: block;
    font-weight: 600;
    margin-bottom: var(--sp-2);
    font-size: var(--fs-sm);
}
.field input,
.field select,
.field textarea {
    width: 100%;
    padding: var(--sp-3) var(--sp-4);
    border: 1px solid var(--color-rule-strong);
    border-radius: var(--radius-sm);
    background: #fff;
    font: inherit;
    color: var(--color-ink);
}
.field textarea { min-height: 160px; resize: vertical; }
.field input:focus,
.field select:focus,
.field textarea:focus {
    border-color: var(--color-accent);
    outline: none;
    box-shadow: 0 0 0 3px var(--color-accent-soft);
}
.field--check {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-3);
    font-size: var(--fs-sm);
    color: var(--color-ink-soft);
}
.field--check input { width: auto; margin-top: 2px; }
.field--honeypot { position: absolute; left: -9999px; }
.form-error {
    color: #a23a1c;
    font-size: var(--fs-sm);
    margin-top: var(--sp-2);
}

/* ---------- 23. 404 ---------- */
.page-404 {
    text-align: center;
    padding-block: var(--sp-9);
}
.page-404 h1 { font-size: var(--fs-3xl); }
.page-404__links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--sp-3);
    margin-top: var(--sp-5);
}

/* ---------- 24. Footer ---------- */
.site-footer {
    background: #1a1a1a;
    color: #c5bfb2;
    padding-block: var(--sp-7) var(--sp-5);
    margin-top: var(--sp-8);
}
.site-footer a { color: #f1e9d9; text-decoration: none; }
.site-footer a:hover { color: #fff; text-decoration: underline; }
.site-footer__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-6);
}
@media (min-width: 768px) {
    .site-footer__grid { grid-template-columns: 1.3fr repeat(3, 1fr); }
}
.site-footer__brand .site-logo { color: #fff; }
.site-footer h4 {
    color: #fff;
    font-size: var(--fs-md);
    margin: 0 0 var(--sp-3);
}
.site-footer ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.site-footer li { margin: 0 0 var(--sp-2); font-size: var(--fs-sm); }
.site-footer__bottom {
    margin-top: var(--sp-6);
    padding-top: var(--sp-4);
    border-top: 1px solid #333;
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-3);
    justify-content: space-between;
    font-size: var(--fs-xs);
    color: #8a8477;
}
.site-footer__bottom button {
    background: transparent;
    border: 1px solid #444;
    color: #c5bfb2;
    padding: var(--sp-1) var(--sp-3);
    border-radius: var(--radius-sm);
    font-size: var(--fs-xs);
    cursor: pointer;
}
.site-footer__bottom button:hover { border-color: var(--color-accent); color: #fff; }

/* ---------- 25. Cookie banner ---------- */
.cookie-banner {
    position: fixed;
    left: var(--sp-4);
    right: var(--sp-4);
    bottom: var(--sp-4);
    max-width: 640px;
    margin-inline: auto;
    background: #1a1a1a;
    color: #f1e9d9;
    border-radius: var(--radius-lg);
    padding: var(--sp-5);
    box-shadow: 0 10px 30px rgba(0,0,0,.25);
    z-index: 100;
    display: none;
    font-size: var(--fs-sm);
    line-height: 1.5;
}
.cookie-banner[data-open="true"] { display: block; }
.cookie-banner p { margin: 0 0 var(--sp-4); color: #d7cfc0; }
.cookie-banner a { color: #fff; text-decoration: underline; }
.cookie-banner__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-3);
}
.cookie-banner .btn--primary { background: var(--color-accent); }
.cookie-banner .btn--ghost {
    background: transparent;
    color: #f1e9d9;
    border-color: #4a4a4a;
}

/* ---------- 26. Utilities ---------- */
.visually-hidden {
    position: absolute !important;
    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; }
.mt-0 { margin-top: 0 !important; }
.mb-0 { margin-bottom: 0 !important; }
.stack > * + * { margin-top: var(--sp-4); }
.stack-lg > * + * { margin-top: var(--sp-6); }

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

/* ---------- 28. Print ---------- */
@media print {
    .site-header, .site-footer, .cookie-banner, .newsletter, .related, .hero__cta { display: none; }
    body { background: #fff; color: #000; }
    a { color: #000; text-decoration: underline; }
}

/* ---------- Article helpers (batch 1) ---------- */
.article-hero { margin: var(--sp-5) 0; border-radius: var(--radius-md); overflow: hidden; }
.article-hero img { display: block; width: 100%; height: auto; }

.table-wrap { overflow-x: auto; margin: var(--sp-6) 0; }
.cmp-table { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); }
.cmp-table caption { text-align: left; caption-side: top; font-style: italic; color: var(--color-ink-mute); padding-bottom: var(--sp-3); }
.cmp-table th, .cmp-table td { border: 1px solid var(--color-rule); padding: var(--sp-3) var(--sp-4); text-align: left; vertical-align: top; }
.cmp-table thead th { background: var(--color-bg-alt); font-weight: 700; }
.cmp-table tbody tr:nth-child(even) td { background: var(--color-bg-alt); }

/* ---------- Chart helpers (batch 2) ---------- */
.chart-wrap { margin: var(--sp-6) 0; padding: var(--sp-4); background: var(--color-bg-alt); border-radius: var(--radius-md); }
.chart-wrap__caption { font-size: var(--fs-sm); color: var(--color-ink-mute); font-style: italic; margin-top: var(--sp-3); }
.chart-wrap canvas { display: block; width: 100% !important; max-width: 100%; height: auto !important; }
