/**
 * Fruehchen Portal - Stylesheet
 *
 * Persoenlich, warm, empathisch.
 * Kein generischer KI-Look — das hier ist Ramonas Seite.
 *
 * Farben (aus dem Logo):
 * - Pflaume:         #6B3A6B
 * - Pflaume hell:    #7D4E7D
 * - Pflaume hover:   #5A2D5A
 * - Rosa:            #C48BA5
 * - Rosa hell:       #E8C4D6
 * - Rosa blass:      #F5E6EE
 * - Lavendel:        #8B7EB8
 * - Lavendel hell:   #C5BDD8
 * - Lavendel blass:  #EDEAF4
 * - Salbei:          #8FB996
 * - Gold:            #C4A265
 * - Text:            #2C2C2A
 * - Text hell:       #5A5A56
 * - Text muted:      #8A8A84
 * - Cream:           #FBF8F5
 * - Warm White:      #FEFDFB
 * - Warm Gray:       #F0EDE9
 *
 * Fonts: Lora (Headings) + Source Sans 3 (Body)
 */

/* ============================================================
   Lokale Fonts (DSGVO-konform — kein Request an Google)
   Lora = Variable Font (400-700 in einer Datei)
   Source Sans 3 = Variable Font (300-700 in einer Datei)
   ============================================================ */

/* Lora — latin-ext (Umlaute, Sonderzeichen) */
@font-face {
    font-family: 'Lora';
    font-style: normal;
    font-weight: 400 700;
    font-display: swap;
    src: url('../fonts/lora-v37-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7,
                   U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF,
                   U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB,
                   U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Lora — latin (Basis) */
@font-face {
    font-family: 'Lora';
    font-style: normal;
    font-weight: 400 700;
    font-display: swap;
    src: url('../fonts/lora-v37-latin-regular.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
                   U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F,
                   U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215,
                   U+FEFF, U+FFFD;
}

/* Source Sans 3 — latin-ext (Umlaute, Sonderzeichen) */
@font-face {
    font-family: 'Source Sans 3';
    font-style: normal;
    font-weight: 300 700;
    font-display: swap;
    src: url('../fonts/source-sans-3-v19-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7,
                   U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF,
                   U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB,
                   U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Source Sans 3 — latin (Basis) */
@font-face {
    font-family: 'Source Sans 3';
    font-style: normal;
    font-weight: 300 700;
    font-display: swap;
    src: url('../fonts/source-sans-3-v19-latin-regular.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6,
                   U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F,
                   U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215,
                   U+FEFF, U+FFFD;
}

/* ============================================================
   CSS Custom Properties
   ============================================================ */

:root {
    /* Primaerfarben */
    --plum:            #6B3A6B;
    --plum-light:      #7D4E7D;
    --plum-hover:      #5A2D5A;
    --rose:            #C48BA5;
    --rose-light:      #E8C4D6;
    --rose-pale:       #F5E6EE;
    --lavender:        #8B7EB8;
    --lavender-light:  #C5BDD8;
    --lavender-pale:   #EDEAF4;

    /* Akzentfarben */
    --sage:            #8FB996;
    --sage-light:      #D4E8D8;
    --gold:            #C4A265;
    --gold-light:      #F0E6D0;

    /* Neutraltoene */
    --cream:           #FBF8F5;
    --warm-white:      #FEFDFB;
    --warm-gray:       #F0EDE9;
    --warm-gray-dark:  #E3DED8;
    --text:            #2C2C2A;
    --text-light:      #5A5A56;
    --text-muted:      #737370;

    /* Aliase (Abwaertskompatibilitaet mit bestehenden Templates) */
    --plum-dark:       var(--plum-hover);
    --bg:              var(--cream);
    --bg-alt:          var(--warm-gray);
    --white:           #FFFFFF;
    --shadow-soft:     var(--shadow-sm);
    --shadow-hover:    var(--shadow-lg);

    /* Typografie */
    --font-heading: 'Lora', Georgia, 'Times New Roman', serif;
    --font-body:    'Source Sans 3', 'Source Sans Pro', -apple-system, BlinkMacSystemFont, sans-serif;

    /* Schatten */
    --shadow-sm:   0 1px 3px rgba(44, 44, 42, 0.06);
    --shadow-md:   0 4px 16px rgba(44, 44, 42, 0.08);
    --shadow-lg:   0 8px 32px rgba(44, 44, 42, 0.1);

    /* Radien */
    --radius:      12px;
    --radius-sm:   8px;
    --radius-md:   12px;
    --radius-lg:   20px;

    /* Abstande */
    --space-xs:    8px;
    --space-sm:    12px;
    --space-md:    20px;
    --space-lg:    32px;
    --space-xl:    48px;
    --space-2xl:   64px;

    /* Semantische Farben */
    --bg-warm:     #FBF8F5;
    --border:      #E3DED8;

    /* Transition */
    --transition:  0.25s ease;
}

/* ============================================================
   Reset & Basics
   ============================================================ */

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

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

body {
    font-family: var(--font-body);
    font-size: 17px;
    color: var(--text);
    background-color: var(--warm-white);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Scroll-Lock wenn Mobile-Menu offen */
body.menu-open {
    overflow: hidden;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 600;
    line-height: 1.3;
    color: var(--plum);
}

a {
    color: var(--plum);
    text-decoration: none;
    transition: color var(--transition);
}

a:hover {
    color: var(--lavender);
    text-decoration: underline;
}

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

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

/* ============================================================
   Skip-to-Content (Barrierefreiheit)
   ============================================================ */

.skip-link {
    position: absolute;
    top: -100%;
    left: 1rem;
    z-index: 1000;
    padding: 0.75rem 1.5rem;
    background: var(--plum);
    color: var(--white);
    font-weight: 600;
    border-radius: 0 0 var(--radius) var(--radius);
    transition: top 0.2s;
}

.skip-link:focus {
    top: 0;
    text-decoration: none;
    color: var(--white);
}

/* ============================================================
   Layout
   ============================================================ */

.container {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

/* ============================================================
   Buttons — Bewusst warm, nicht "tech"
   ============================================================ */

.btn {
    display: inline-block;
    padding: 14px 28px;
    border-radius: 10px;
    font-size: 16px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    border: none;
    text-decoration: none;
    line-height: 1.4;
    transition: transform var(--transition), box-shadow var(--transition),
                background var(--transition), color var(--transition);
    min-height: 44px;
}

.btn:hover {
    text-decoration: none;
    transform: translateY(-1px);
}

.btn-primary {
    background: var(--plum);
    color: var(--white);
    box-shadow: 0 2px 8px rgba(107, 58, 107, 0.2);
}

.btn-primary:hover {
    background: var(--plum-hover);
    color: var(--white);
    box-shadow: 0 4px 16px rgba(107, 58, 107, 0.25);
}

.btn-secondary {
    background: var(--white);
    color: var(--plum);
    border: 2px solid var(--warm-gray-dark);
}

.btn-secondary:hover {
    background: var(--cream);
    color: var(--plum-hover);
    border-color: var(--rose);
}

.btn-white {
    background: var(--white);
    color: var(--plum);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.btn-white:hover {
    background: var(--cream);
    color: var(--plum-hover);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

/* ============================================================
   Site Header — Weiss, sticky, mit Rosa-Akzent
   ============================================================ */

.site-header {
    background: var(--warm-white);
    padding: 0;
    position: sticky;
    top: 0;
    z-index: 100;
    border-bottom: 3px solid var(--rose);
    box-shadow: var(--shadow-sm);
}

.site-header .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    gap: 1rem;
    height: 60px;
}

.site-logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.site-logo img {
    height: 42px;
    width: auto;
}

.site-logo:focus-visible {
    outline-color: var(--plum);
}

/* ============================================================
   Main Navigation — Mobile-First: Overlay-Slide-in
   ============================================================ */

.main-nav {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(300px, 85vw);
    background: var(--white);
    padding: 5rem 2rem 2rem;
    transform: translateX(100%);
    transition: transform 0.35s ease;
    z-index: 150;
    overflow-y: auto;
    box-shadow: -4px 0 24px rgba(0, 0, 0, 0.1);
}

.main-nav.is-open {
    transform: translateX(0);
}

.main-nav ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.main-nav a {
    display: block;
    color: var(--text);
    font-weight: 500;
    font-size: 1.1rem;
    padding: 0.85rem 0;
    border-bottom: 1px solid var(--warm-gray);
    border-radius: 0;
    transition: color var(--transition), background var(--transition);
}

.main-nav a:hover,
.main-nav a:focus-visible {
    border-bottom-color: var(--warm-gray);
    color: var(--plum);
    background: var(--rose-pale);
    text-decoration: none;
}

.main-nav a.is-active {
    border-bottom-color: var(--warm-gray);
    color: var(--plum);
    background: var(--rose-pale);
    font-weight: 600;
}

/* Overlay-Hintergrund */
.nav-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 140;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.35s ease;
}

.nav-overlay.is-visible {
    opacity: 1;
    pointer-events: auto;
}

/* ============================================================
   Hamburger Button (mobil) — Dunkel (Header ist weiss)
   ============================================================ */

.nav-toggle {
    display: flex; /* Mobile-First: sichtbar, ab Desktop versteckt */
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    width: 44px;
    height: 44px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    z-index: 200;
    position: relative;
    border-radius: 8px;
    transition: background var(--transition);
}

.nav-toggle:hover {
    background: var(--warm-gray);
}

.nav-toggle__bar {
    display: block;
    width: 24px;
    height: 2.5px;
    background: var(--text);
    border-radius: 2px;
    transition: transform 0.3s ease, opacity 0.3s ease;
    transform-origin: center;
}

/* Hamburger -> X Animation */
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) {
    transform: translateY(7.5px) rotate(45deg);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) {
    opacity: 0;
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) {
    transform: translateY(-7.5px) rotate(-45deg);
}

/* ============================================================
   Site Main
   ============================================================ */

.site-main {
    min-height: 60vh;
}

/* Innere Seiten (Artikel, Lexikon etc.) behalten ihren Abstand */
.site-main--inner {
    padding: 2.5rem 0;
}

/* ============================================================
   Hero (Startseite) — Heller Gradient, 2-Spalten, persoenlich
   ============================================================ */

.hero {
    background: linear-gradient(165deg, var(--cream) 0%, var(--warm-gray) 40%, var(--rose-pale) 100%);
    padding: 48px 20px 40px;
    position: relative;
    overflow: hidden;
}

/* Dekorative Kreise */
.hero::before {
    content: '';
    position: absolute;
    top: -80px;
    right: -80px;
    width: 300px;
    height: 300px;
    border-radius: 50%;
    background: rgba(196, 139, 165, 0.1);
    pointer-events: none;
}

.hero::after {
    content: '';
    position: absolute;
    bottom: -60px;
    left: -40px;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: rgba(139, 126, 184, 0.08);
    pointer-events: none;
}

.hero__inner {
    max-width: 1140px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    align-items: center;
    text-align: center;
    position: relative;
    z-index: 1;
}

.hero h1 {
    color: var(--text);
    font-size: 24px;
    margin-bottom: 1rem;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.5px;
}

.hero h1 em {
    color: var(--plum);
    font-style: normal;
}

.hero__emphasis {
    display: block;
    color: var(--plum);
    font-style: normal;
}

.hero__text {
    font-size: 17px;
    line-height: 1.7;
    color: var(--text-light);
    max-width: 540px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1.5rem;
}

.hero__buttons {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
}

/* ============================================================
   SSW-Finder (Schwangerschaftswoche) — Weisse Box
   ============================================================ */

.ssw-finder {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: 24px;
    box-shadow: var(--shadow-lg);
}

.ssw-finder h2 {
    font-size: 20px;
    margin-bottom: 8px;
}

.ssw-finder p {
    font-size: 15px;
    color: var(--text-muted);
    margin-bottom: 20px;
}

.ssw-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
}

.ssw-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 6px;
    border-radius: 8px;
    border: 1px solid var(--warm-gray);
    background: var(--white);
    font-size: 14px;
    font-weight: 500;
    color: var(--text);
    cursor: pointer;
    font-family: inherit;
    transition: all var(--transition);
    min-height: 44px;
    text-decoration: none;
}

.ssw-btn:hover {
    border-color: var(--plum);
    color: var(--plum);
    background: var(--rose-pale);
    text-decoration: none;
}

.ssw-btn.critical {
    border-color: var(--rose);
    background: rgba(196, 139, 165, 0.08);
    color: var(--plum);
}

.ssw-btn.critical:hover {
    background: var(--rose-pale);
}

.ssw-btn.moderate {
    border-color: var(--lavender-light);
    background: rgba(139, 126, 184, 0.06);
}

.ssw-btn.moderate:hover {
    background: var(--lavender-pale);
}

.ssw-note {
    font-size: 13px;
    color: var(--text-muted);
    text-align: center;
    font-style: italic;
    margin-top: 12px;
}

/* ============================================================
   SSW-Landingpages (/ssw/24/ etc.)
   Warm, luftig, nicht klinisch. Fuer besorgte Eltern.
   ============================================================ */

.ssw-page {
    max-width: 780px;
    margin: 0 auto;
}

/* --- Header --- */
.ssw-header {
    text-align: center;
    margin-bottom: var(--space-xl);
    padding-bottom: var(--space-lg);
    border-bottom: 2px solid var(--rose-pale);
}

.ssw-header__badge {
    display: inline-block;
    background: var(--plum);
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    padding: 8px 22px;
    border-radius: 24px;
    margin-bottom: 20px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.ssw-header h1 {
    font-size: 26px;
    margin-bottom: 12px;
    line-height: 1.3;
}

.ssw-header__subtitle {
    font-size: 20px;
    color: var(--plum-light);
    font-family: var(--font-heading);
    font-style: italic;
    margin: 0;
}

/* --- Redaktioneller Inhalt --- */
.ssw-content {
    font-size: 17px;
    line-height: 1.85;
    margin-bottom: var(--space-xl);
    max-width: 46rem;
    margin-left: auto;
    margin-right: auto;
}

.ssw-content > p {
    margin-bottom: var(--space-lg);
}

.ssw-week-range {
    display: block;
    font-size: 15px;
    color: var(--text-muted);
    font-style: italic;
    margin-bottom: var(--space-md);
    padding-bottom: var(--space-sm);
    border-bottom: 1px solid var(--warm-gray);
}

/* --- Faktenbox --- */
.ssw-facts {
    background: var(--bg-warm);
    border: 1px solid var(--warm-gray);
    border-left: 5px solid var(--plum);
    border-radius: var(--radius-md);
    padding: var(--space-lg) var(--space-md) var(--space-lg) var(--space-lg);
    margin: var(--space-lg) 0;
    box-shadow: var(--shadow-sm);
}

.ssw-facts h3 {
    font-family: var(--font-heading);
    font-size: 20px;
    margin-bottom: var(--space-md);
    color: var(--plum);
    padding-bottom: var(--space-sm);
    border-bottom: 1px solid var(--rose-pale);
}

.ssw-facts ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ssw-facts li {
    padding: 10px 0;
    border-bottom: 1px solid rgba(107, 58, 107, 0.08);
    line-height: 1.6;
}

.ssw-facts li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

/* --- Tipps-Karte --- */
.ssw-tips {
    background: #fff;
    border: 1px solid var(--rose-pale);
    border-radius: var(--radius-md);
    padding: var(--space-lg) var(--space-md);
    margin: var(--space-lg) 0;
    box-shadow: var(--shadow-sm);
    position: relative;
}

.ssw-tips::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--rose), var(--rose-light));
    border-radius: var(--radius-md) var(--radius-md) 0 0;
}

.ssw-tips h3 {
    font-family: var(--font-heading);
    font-size: 20px;
    margin-bottom: var(--space-md);
    color: var(--plum);
    padding-bottom: var(--space-sm);
    border-bottom: 1px solid var(--rose-pale);
}

.ssw-tips ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ssw-tips li {
    padding: 10px 0 10px 24px;
    position: relative;
    line-height: 1.65;
}

.ssw-tips li::before {
    content: "\2665";
    color: var(--rose);
    position: absolute;
    left: 0;
    top: 10px;
    font-size: 14px;
}

/* Ermutigungssatz in der Tipps-Box */
.ssw-encouragement {
    font-style: italic;
    color: var(--plum);
    margin-top: var(--space-lg);
    margin-bottom: 0;
    font-weight: 500;
    font-size: 17px;
    padding-top: var(--space-md);
    border-top: 1px solid var(--rose-pale);
    line-height: 1.7;
}

/* --- Ausblick-Karte --- */
.ssw-outlook {
    background: linear-gradient(145deg, var(--lavender-pale) 0%, #fff 70%);
    border: 1px solid var(--lavender-light);
    border-radius: var(--radius-md);
    padding: var(--space-lg) var(--space-md);
    margin: var(--space-lg) 0;
    box-shadow: var(--shadow-sm);
}

.ssw-outlook h3 {
    font-family: var(--font-heading);
    font-size: 20px;
    margin-bottom: var(--space-md);
    color: var(--lavender);
    padding-bottom: var(--space-sm);
    border-bottom: 1px solid var(--lavender-light);
}

.ssw-outlook p {
    line-height: 1.8;
}

/* --- SSW Navigation (vor/zurueck) --- */
.ssw-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-md) 0;
    margin: var(--space-xl) 0;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}

.ssw-nav a {
    color: var(--plum);
    font-weight: 600;
    text-decoration: none;
    padding: 10px 20px;
    border-radius: var(--radius-sm);
    transition: background var(--transition), color var(--transition);
    border: 1px solid transparent;
}

.ssw-nav a:hover {
    background: var(--rose-pale);
    border-color: var(--rose-light);
}

/* --- Passende Artikel --- */
.ssw-articles {
    margin-top: var(--space-2xl);
}

.ssw-articles h2 {
    font-size: 24px;
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-sm);
    border-bottom: 2px solid var(--plum);
}

/* --- Haftungshinweis --- */
.ssw-disclaimer {
    font-size: 13px;
    color: var(--text-muted);
    font-style: italic;
    text-align: center;
    max-width: 38rem;
    margin: var(--space-2xl) auto 0;
    padding-top: var(--space-lg);
    border-top: 1px solid var(--border);
    line-height: 1.7;
}

/* Artikel-Grid innerhalb SSW-Seite */
.ssw-articles__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

.ssw-articles__grid .article-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    background: #fff;
    border: 1px solid var(--warm-gray);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: box-shadow var(--transition), border-color var(--transition);
}

.ssw-articles__grid .article-card:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--rose-light);
}

.ssw-articles__grid .article-card__image {
    width: 100%;
    height: 180px;
    min-height: 140px;
    object-fit: cover;
    flex-shrink: 0;
}

.ssw-articles__grid .article-card__content {
    padding: var(--space-md);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.ssw-articles__grid .article-card__title a {
    color: var(--text);
    text-decoration: none;
    font-size: 18px;
    line-height: 1.4;
}

.ssw-articles__grid .article-card__title a:hover {
    color: var(--plum);
}

.ssw-articles__grid .article-card__excerpt {
    font-size: 15px;
    color: var(--text-light);
    line-height: 1.6;
    margin-top: 8px;
}

.ssw-articles__grid .article-card__date {
    font-size: 13px;
    color: var(--text-muted);
    margin-top: 8px;
}

.ssw-articles__empty {
    background: var(--bg-warm);
    padding: var(--space-lg);
    border-radius: var(--radius-md);
    text-align: center;
    color: var(--text-light);
    line-height: 1.7;
}

@media (min-width: 769px) {
    .ssw-articles__grid .article-card {
        flex-direction: row;
    }
    .ssw-articles__grid .article-card__image {
        width: 180px;
        height: auto;
    }
}

/* ============================================================
   Trust-Bar — Dezente Vertrauensindikatoren
   ============================================================ */

.trust-bar {
    border-bottom: 1px solid var(--warm-gray);
    padding: 20px 24px;
}

.trust-bar .container {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    flex-wrap: wrap;
}

.trust-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: var(--text-muted);
    font-weight: 500;
}

.trust-item__icon {
    font-size: 16px;
    flex-shrink: 0;
}

/* ============================================================
   Section Headers — Zentriert, mit Label und Beschreibung
   ============================================================ */

.section-header {
    text-align: center;
    margin-bottom: 48px;
}

.section-header .label {
    display: block;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--plum-light);
    font-weight: 600;
    margin-bottom: 8px;
}

.section-header h2 {
    font-family: var(--font-heading);
    font-size: 26px;
    line-height: 1.2;
    margin-bottom: 12px;
}

.section-header p {
    font-size: 16px;
    color: var(--text-light);
    max-width: 560px;
    margin: 0 auto;
    line-height: 1.6;
}

/* ============================================================
   Themen-Grid (Startseite) — Wegweiser-Karten
   ============================================================ */

.topics-section {
    background: var(--cream);
    padding: 48px 20px;
}

.topics-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
    max-width: 1140px;
    margin: 0 auto;
}

.topic-card {
    background: var(--white);
    border-radius: var(--radius);
    padding: 28px 24px;
    position: relative;
    transition: transform var(--transition), box-shadow var(--transition);
    text-decoration: none;
    color: var(--text);
    display: block;
}

/* Top-Border Akzent (erscheint on hover) */
.topic-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--rose);
    border-radius: var(--radius) var(--radius) 0 0;
    opacity: 0;
    transition: opacity var(--transition);
}

.topic-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
    text-decoration: none;
    color: var(--text);
}

.topic-card:hover::before {
    opacity: 1;
}

.topic-card__icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    margin-bottom: 16px;
    flex-shrink: 0;
}

.icon-plum {
    background: var(--rose-pale);
    color: var(--plum);
}

.icon-rose {
    background: rgba(196, 139, 165, 0.15);
    color: var(--rose);
}

.icon-lavender {
    background: var(--lavender-pale);
    color: var(--lavender);
}

.icon-sage {
    background: var(--sage-light);
    color: var(--sage);
}

.icon-gold {
    background: var(--gold-light);
    color: var(--gold);
}

.topic-card h3 {
    font-size: 18px;
    margin-bottom: 6px;
    line-height: 1.3;
}

.topic-card p {
    font-size: 15px;
    color: var(--text-light);
    line-height: 1.55;
    margin-bottom: 12px;
}

.topic-card__count {
    font-size: 14px;
    color: var(--plum-light);
    font-weight: 600;
    margin-top: auto;
}

/* ============================================================
   Erfahrungsberichte (Startseite) — Persoenlich, emotional
   ============================================================ */

.stories-section {
    padding: 48px 20px;
}

.stories-grid {
    display: grid;
    grid-template-columns: 1fr;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
    gap: 24px;
    max-width: 1140px;
    margin: 0 auto;
}

.story-card {
    border-radius: var(--radius-lg);
    border: 1px solid var(--warm-gray);
    overflow: hidden;
    background: var(--white);
    transition: transform var(--transition), box-shadow var(--transition);
    text-decoration: none;
    color: var(--text);
    display: block;
}

.story-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    text-decoration: none;
    color: var(--text);
}

.story-card__image {
    width: 100%;
    height: 180px;
    object-fit: cover;
    display: block;
}

.story-card__image-placeholder {
    width: 100%;
    height: 180px;
    background: linear-gradient(135deg, var(--rose-pale) 0%, var(--lavender-pale) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 40px;
}

.story-card__body {
    padding: 20px 24px;
    position: relative;
}

.story-card__badge {
    display: inline-block;
    background: var(--white);
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    color: var(--plum);
    box-shadow: var(--shadow-sm);
    position: absolute;
    bottom: calc(100% - 14px);
    left: 20px;
}

.story-card h3 {
    font-size: 17px;
    margin-bottom: 8px;
    line-height: 1.4;
    margin-top: 8px;
}

.story-card p {
    font-size: 15px;
    color: var(--text-light);
    line-height: 1.55;
}

/* ============================================================
   CTA-Band — Plum-Gradient, einladend
   ============================================================ */

.cta-band {
    background: linear-gradient(135deg, var(--plum) 0%, var(--plum-light) 100%);
    padding: 48px 20px;
    text-align: center;
    color: var(--white);
}

.cta-band h2 {
    font-family: var(--font-heading);
    color: var(--white);
    font-size: 24px;
    margin-bottom: 12px;
}

.cta-band p {
    font-size: 18px;
    opacity: 0.9;
    margin-bottom: 24px;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}

/* ============================================================
   Artikel-Section (Startseite) — 2-Spalten mit Datum-Box
   ============================================================ */

.articles-section {
    padding: 48px 20px;
    background: var(--cream);
}

.articles-section-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    max-width: 1140px;
    margin: 0 auto;
}

.article-home-card {
    display: flex;
    gap: 16px;
    background: var(--white);
    border-radius: var(--radius);
    padding: 20px;
    transition: transform var(--transition), box-shadow var(--transition);
    text-decoration: none;
    color: var(--text);
}

.article-home-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    text-decoration: none;
    color: var(--text);
}

.article-home-card__date {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    background: var(--lavender-pale);
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.article-home-card__day {
    font-size: 22px;
    font-weight: 700;
    color: var(--plum);
}

.article-home-card__month {
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.article-home-card__body h3 {
    font-size: 16px;
    margin-bottom: 4px;
    line-height: 1.35;
}

.article-home-card__category {
    display: inline-block;
    font-size: 12px;
    color: var(--plum-light);
    background: var(--rose-pale);
    padding: 2px 8px;
    border-radius: 4px;
    margin-bottom: 6px;
}

.article-home-card__excerpt {
    font-size: 14px;
    color: var(--text-light);
    line-height: 1.5;
}

/* ============================================================
   About / Gemeinschaft (Startseite)
   ============================================================ */

.about-section {
    padding: 48px 20px;
}

.about-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    max-width: 1140px;
    margin: 0 auto;
    align-items: center;
}

.about-visual {
    background: linear-gradient(135deg, var(--rose-pale) 0%, var(--lavender-pale) 100%);
    border-radius: var(--radius-lg);
    padding: 48px 32px;
    text-align: center;
}

.about-avatar {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: 20px;
    border: 3px solid var(--white);
    box-shadow: var(--shadow-md);
}

.about-avatar-placeholder {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: var(--white);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
    font-size: 40px;
    box-shadow: var(--shadow-md);
}

.about-visual h3 {
    font-size: 22px;
    margin-bottom: 4px;
}

.about-visual__role {
    font-size: 14px;
    color: var(--text-muted);
    margin-bottom: 16px;
}

.about-visual blockquote,
.about-quote {
    font-style: italic;
    color: var(--text-light);
    font-size: 15px;
    line-height: 1.6;
    border-left: 3px solid var(--plum-light);
    padding-left: 16px;
    text-align: left;
    margin-top: 16px;
}

.about-text h2 {
    font-size: 30px;
    margin-bottom: 16px;
}

.about-text > p {
    font-size: 17px;
    color: var(--text-light);
    line-height: 1.7;
    margin-bottom: 20px;
}

.about-disclaimer {
    background: var(--rose-pale);
    border-left: 3px solid var(--rose);
    padding: 12px 16px;
    border-radius: 0 8px 8px 0;
    font-size: 14px;
    color: var(--text-light);
    line-height: 1.55;
    margin-bottom: 24px;
}

.about-stats {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    justify-content: center;
}

.about-stat {
    text-align: center;
}

.about-stat__number {
    display: block;
    font-family: var(--font-heading);
    font-size: 24px;
    font-weight: 700;
    color: var(--plum);
    line-height: 1;
}

.about-stat__label {
    font-size: 13px;
    color: var(--text-muted);
    margin-top: 4px;
}

/* ============================================================
   Schnellzugriff (Startseite) — Wegweiser-Boxen (Legacy)
   ============================================================ */

.quick-access {
    margin-bottom: 3rem;
}

.quick-access__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.quick-access__box {
    display: flex;
    flex-direction: row;
    align-items: center;
    text-align: left;
    padding: 1.25rem;
    gap: 1rem;
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    border: 2px solid transparent;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
    text-decoration: none;
    color: var(--text);
}

.quick-access__box:hover,
.quick-access__box:focus-visible {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
    border-color: var(--rose-light);
    text-decoration: none;
    color: var(--text);
}

.quick-access__icon {
    font-size: 1.75rem;
    margin-bottom: 0;
    flex-shrink: 0;
    display: block;
    line-height: 1;
}

.quick-access__title {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    color: var(--plum);
    margin-bottom: 0.4rem;
}

.quick-access__desc {
    font-size: 0.9rem;
    color: var(--text-light);
    line-height: 1.5;
}

/* ============================================================
   Article Cards — Weiche Schatten, warme Farben
   ============================================================ */

.article-grid h2 {
    margin-bottom: 0.5rem;
}

.articles-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin: 1.5rem 0;
}

.articles-list--compact {
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
}

.article-card {
    background: var(--white);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition);
}

.article-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.article-card--sponsored {
    border-left: 4px solid var(--rose);
}

.article-card__image {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

.article-card__content {
    padding: 1.25rem;
}

.article-card__category {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--lavender);
}

.article-card__category a {
    color: var(--lavender);
}

.article-card__category a:hover {
    color: var(--plum);
}

.article-card__title {
    font-size: 1.15rem;
    margin: 0.5rem 0;
    line-height: 1.35;
}

.article-card__title a {
    color: var(--plum);
}

.article-card__title a:hover {
    color: var(--lavender);
}

.article-card__excerpt {
    font-size: 0.9rem;
    color: var(--text-light);
    margin-bottom: 0.75rem;
    line-height: 1.55;
}

.article-card__date {
    font-size: 0.8rem;
    color: #999;
}

.article-card__badge {
    display: inline-block;
    background: var(--rose);
    color: var(--white);
    font-size: 0.7rem;
    padding: 0.15rem 0.5rem;
    border-radius: 3px;
    margin-left: 0.5rem;
}

.article-card--small h3 {
    font-size: 1rem;
    margin: 0.5rem 0 0.25rem;
}

.article-card--small time {
    font-size: 0.8rem;
    color: #999;
}

/* ============================================================
   Article Single — Grosszuegige Typografie, Ruhe, Struktur
   ============================================================ */

.article-single {
    max-width: 780px;
    margin: 0 auto;
}

/* --- Artikel-Karten-Effekt ---
   Artikelseiten: leicht abgesetzter Hintergrund hinter dem Content,
   damit der Artikel nicht im Weiss "schwimmt".
   Erkennung rein per CSS (:has), kein Template-Markup noetig. */

/* Mobil: randlos, kein Karteneffekt — volle Breite nutzen */
.site-main:has(.article-single) {
    background: var(--cream);
    padding-bottom: 1.5rem;
}

.site-main:has(.article-single) > .container {
    background: var(--warm-white);
    max-width: 100%;
    padding: 1.25rem 1.25rem 1.5rem;
    margin-top: 0;
    border-radius: 0;
    border: 1px solid var(--warm-gray-dark);
    border-top: none;
    box-shadow: none;
}

/* Tablet: Karte mit kleinem Rand */
@media (min-width: 769px) {
    .site-main:has(.article-single) {
        padding-bottom: 3rem;
    }

    .site-main:has(.article-single) > .container {
        max-width: calc(100% - 2rem);
        padding: 2rem 2rem 2.5rem;
        border-radius: 0 0 var(--radius-md) var(--radius-md);
        box-shadow: 0 4px 20px rgba(44, 44, 42, 0.07),
                    0 1px 4px rgba(44, 44, 42, 0.04);
    }
}

/* Desktop: volle Karte, grosszuegig */
@media (min-width: 901px) {
    .site-main:has(.article-single) > .container {
        max-width: 860px;
        padding: 2.5rem 2.5rem 3rem;
        border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    }
}

/* ============================================================
   Card-Effekt fuer Lexikon, SSW und statische Seiten
   Gleiche Optik wie Artikel — Cream-Hintergrund, weisser Container
   ============================================================ */

/* Mobil: randlos, kein Karteneffekt — volle Breite nutzen */
.site-main:has(.lexikon-entry),
.site-main:has(.ssw-page),
.site-main:has(.static-page) {
    background: var(--cream);
    padding-bottom: 1.5rem;
}

.site-main:has(.lexikon-entry) > .container,
.site-main:has(.ssw-page) > .container,
.site-main:has(.static-page) > .container {
    background: var(--warm-white);
    max-width: 100%;
    padding: 1.25rem 1.25rem 1.5rem;
    margin-top: 0;
    border-radius: 0;
    border: 1px solid var(--warm-gray-dark);
    border-top: none;
    box-shadow: none;
}

/* Tablet: Karte mit kleinem Rand */
@media (min-width: 769px) {
    .site-main:has(.lexikon-entry),
    .site-main:has(.ssw-page),
    .site-main:has(.static-page) {
        padding-bottom: 3rem;
    }

    .site-main:has(.lexikon-entry) > .container,
    .site-main:has(.ssw-page) > .container,
    .site-main:has(.static-page) > .container {
        max-width: calc(100% - 2rem);
        padding: 2rem 2rem 2.5rem;
        border-radius: 0 0 var(--radius-md) var(--radius-md);
        box-shadow: 0 4px 20px rgba(44, 44, 42, 0.07),
                    0 1px 4px rgba(44, 44, 42, 0.04);
    }
}

/* Desktop: volle Karte, grosszuegig */
@media (min-width: 901px) {
    .site-main:has(.lexikon-entry) > .container,
    .site-main:has(.ssw-page) > .container,
    .site-main:has(.static-page) > .container {
        max-width: 860px;
        padding: 2.5rem 2.5rem 3rem;
        border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    }
}

/* ============================================================
   Card-Effekt fuer Listen-Seiten (Kategorie, Tag, Lexikon-Index, SSW-Index)
   Breiterer Container (1060px) fuer Card-Grids
   ============================================================ */

/* Mobil: randlos, Cream-Hintergrund */
.site-main:has(.category-page),
.site-main:has(.tag-page),
.site-main:has(.lexikon-overview),
.site-main:has(.ssw-overview) {
    background: var(--cream);
    padding-bottom: 1.5rem;
}

.site-main:has(.category-page) > .container,
.site-main:has(.tag-page) > .container,
.site-main:has(.lexikon-overview) > .container,
.site-main:has(.ssw-overview) > .container {
    background: var(--warm-white);
    max-width: 100%;
    padding: 1.25rem 1.25rem 1.5rem;
    margin-top: 0;
    border-radius: 0;
    border: 1px solid var(--warm-gray-dark);
    border-top: none;
    box-shadow: none;
}

/* Tablet: Karte mit kleinem Rand */
@media (min-width: 769px) {
    .site-main:has(.category-page),
    .site-main:has(.tag-page),
    .site-main:has(.lexikon-overview),
    .site-main:has(.ssw-overview) {
        padding-bottom: 3rem;
    }

    .site-main:has(.category-page) > .container,
    .site-main:has(.tag-page) > .container,
    .site-main:has(.lexikon-overview) > .container,
    .site-main:has(.ssw-overview) > .container {
        max-width: calc(100% - 2rem);
        padding: 2rem 2rem 2.5rem;
        border-radius: 0 0 var(--radius-md) var(--radius-md);
        box-shadow: 0 4px 20px rgba(44, 44, 42, 0.07),
                    0 1px 4px rgba(44, 44, 42, 0.04);
    }
}

/* Desktop: breitere Karte fuer Card-Grids */
@media (min-width: 901px) {
    .site-main:has(.category-page) > .container,
    .site-main:has(.tag-page) > .container,
    .site-main:has(.lexikon-overview) > .container,
    .site-main:has(.ssw-overview) > .container {
        max-width: 1060px;
        padding: 2.5rem 2.5rem 3rem;
        border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    }
}

/* ============================================================
   SSW-Uebersicht: Intro, Legende, Grid und Karten
   ============================================================ */

.ssw-overview__intro {
    font-size: 1.0625rem;
    color: var(--text-light);
    margin-bottom: 1.75rem;
    max-width: 56rem;
}

/* Legende */
.ssw-overview__legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.625rem 1.25rem;
    margin-bottom: 1.5rem;
}

.ssw-legend__item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: var(--text-light);
}

.ssw-legend__item::before {
    content: '';
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}

.ssw-legend__item--critical::before { background: #C0392B; }
.ssw-legend__item--moderate::before { background: #D97706; }
.ssw-legend__item--late::before     { background: #059669; }

/* Grid — Mobile-First: 1 Spalte */
.ssw-overview__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    margin-bottom: 2rem;
}

@media (min-width: 481px) {
    .ssw-overview__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 769px) {
    .ssw-overview__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Karte */
.ssw-card {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    background: var(--warm-white);
    border: 1px solid var(--warm-gray-dark);
    border-left-width: 4px;
    border-radius: var(--radius-md);
    padding: 1.25rem;
    text-decoration: none;
    color: var(--text);
    transition: transform var(--transition), box-shadow var(--transition);
}

.ssw-card:hover,
.ssw-card:focus-visible {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    text-decoration: none;
}

.ssw-card:focus-visible {
    outline: 3px solid var(--plum);
    outline-offset: 2px;
}

/* Linker Rand nach Risk-Klasse */
.ssw-card--critical { border-left-color: #C0392B; }
.ssw-card--moderate { border-left-color: #D97706; }
.ssw-card--late     { border-left-color: #059669; }

/* Badge: Wochennummer */
.ssw-card__week {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.15em 0.55em;
    border-radius: var(--radius-sm);
    align-self: flex-start;
    line-height: 1.5;
}

.ssw-card--critical .ssw-card__week {
    background: #FDECEA;
    color: #9B2220;
}

.ssw-card--moderate .ssw-card__week {
    background: #FEF3C7;
    color: #92400E;
}

.ssw-card--late .ssw-card__week {
    background: #D1FAE5;
    color: #065F46;
}

/* Kartenüberschrift */
.ssw-card__title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 600;
    margin: 0.25rem 0 0;
    line-height: 1.35;
    color: var(--text);
}

/* Untertitel */
.ssw-card__subtitle {
    font-size: 0.875rem;
    color: var(--text-muted);
    margin: 0;
    line-height: 1.45;
}

/* Artikel-Anzahl */
.ssw-card__count {
    margin-top: auto;
    padding-top: 0.625rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--plum);
}

/* ============================================================
   Card-Effekt fuer Suche und 404
   Schmaler Container (860px) wie Artikel
   ============================================================ */

/* Mobil: randlos, Cream-Hintergrund */
.site-main:has(.search-page),
.site-main:has(.error-page) {
    background: var(--cream);
    padding-bottom: 1.5rem;
}

.site-main:has(.search-page) > .container,
.site-main:has(.error-page) > .container {
    background: var(--warm-white);
    max-width: 100%;
    padding: 1.25rem 1.25rem 1.5rem;
    margin-top: 0;
    border-radius: 0;
    border: 1px solid var(--warm-gray-dark);
    border-top: none;
    box-shadow: none;
}

/* Tablet: Karte mit kleinem Rand */
@media (min-width: 769px) {
    .site-main:has(.search-page),
    .site-main:has(.error-page) {
        padding-bottom: 3rem;
    }

    .site-main:has(.search-page) > .container,
    .site-main:has(.error-page) > .container {
        max-width: calc(100% - 2rem);
        padding: 2rem 2rem 2.5rem;
        border-radius: 0 0 var(--radius-md) var(--radius-md);
        box-shadow: 0 4px 20px rgba(44, 44, 42, 0.07),
                    0 1px 4px rgba(44, 44, 42, 0.04);
    }
}

/* Desktop: schmale Karte wie Artikel */
@media (min-width: 901px) {
    .site-main:has(.search-page) > .container,
    .site-main:has(.error-page) > .container {
        max-width: 860px;
        padding: 2.5rem 2.5rem 3rem;
        border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    }
}

/* Kategorie-Badge ueber der Ueberschrift */
.article-header__category {
    display: inline-block;
    background: var(--lavender-pale);
    color: var(--plum);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    padding: 0.3rem 0.75rem;
    border-radius: 20px;
    margin-bottom: 0.75rem;
    text-decoration: none;
    transition: background var(--transition);
}

.article-header__category:hover {
    background: var(--lavender-light);
    text-decoration: none;
}

.article-header h1 {
    font-size: 1.5rem;
    margin-bottom: 0.75rem;
    line-height: 1.3;
}

.article-meta {
    color: var(--text-light);
    font-size: 0.82rem;
    margin-bottom: 1.5rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.15rem;
}

.article-meta__separator {
    margin: 0 0.35rem;
    color: var(--text-muted);
}

.article-meta__updated {
    color: var(--text-muted);
}

.article-meta__reading-time {
    color: var(--text-muted);
}

/* Featured Image: begrenzte Hoehe, kein endloses Scrollen */
.article-featured-image {
    margin: 0 -1.25rem 1.5rem;
    border-radius: 0;
    overflow: hidden;
    max-height: 280px;
}

.article-featured-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Inhaltsverzeichnis (TOC) */
.article-toc {
    background: var(--cream);
    border: 1px solid var(--warm-gray);
    border-radius: var(--radius);
    padding: 1rem;
    margin-bottom: 2rem;
}

.article-toc summary {
    font-family: var(--font-heading);
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--plum);
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.article-toc summary::before {
    content: '';
    display: inline-block;
    width: 3px;
    height: 1em;
    background: var(--plum);
    border-radius: 2px;
}

.article-toc summary::-webkit-details-marker {
    display: none;
}

.article-toc details[open] summary {
    margin-bottom: 0.75rem;
}

.article-toc ol {
    list-style: none;
    counter-reset: toc;
    padding: 0;
    margin: 0;
}

.article-toc li {
    counter-increment: toc;
    padding: 0.3rem 0;
    border-bottom: 1px solid var(--warm-gray);
}

.article-toc li:last-child {
    border-bottom: none;
}

.article-toc li::before {
    content: counter(toc) ".";
    color: var(--text-muted);
    font-size: 0.85rem;
    margin-right: 0.5rem;
    min-width: 1.5rem;
    display: inline-block;
}

.article-toc a {
    color: var(--text);
    text-decoration: none;
    font-size: 0.95rem;
}

.article-toc a:hover {
    color: var(--plum);
}

/* Article Content: Grosszuegig, lesbar, nicht gedraengt */
.article-content {
    font-size: 1rem;
    line-height: 1.85;
}

.article-content h2 {
    margin-top: 2.5rem;
    margin-bottom: 0.75rem;
    padding-top: 0.5rem;
    padding-bottom: 0.4rem;
    border-bottom: 2px solid var(--rose-light);
    color: var(--plum);
    font-size: 1.25rem;
}

.article-content h3 {
    margin-top: 2rem;
    margin-bottom: 0.5rem;
    color: var(--plum-light);
    font-size: 1.2rem;
}

.article-content p {
    margin-bottom: 1.25rem;
}

.article-content ul,
.article-content ol {
    margin: 1rem 0 1.25rem 2rem;
}

.article-content li {
    margin-bottom: 0.35rem;
}

.article-content blockquote {
    border-left: 4px solid var(--rose);
    padding: 1rem 1.5rem;
    margin: 1.5rem 0;
    background: var(--rose-pale);
    border-radius: 0 var(--radius) var(--radius) 0;
    font-style: italic;
    color: var(--text-light);
}

.article-content img {
    border-radius: var(--radius);
    margin: 1rem 0;
    max-width: 100%;
    height: auto;
}

.article-content a {
    color: var(--plum);
    text-decoration: underline;
    text-decoration-color: var(--rose-light);
    text-underline-offset: 2px;
}

.article-content a:hover {
    text-decoration-color: var(--plum);
}

/* ============================================================
   Content-Typography fuer SSW, Lexikon und statische Seiten
   Gleiche Lesbarkeit wie article-content
   ============================================================ */

/* Basis-Typography (font-size, line-height, Absatz-Margins) */
.ssw-content,
.page-content {
    font-size: 1rem;
    line-height: 1.85;
}

/* Lexikon hat bereits 1.05rem/1.85 — hier nicht ueberschreiben */

/* H2-Styling: Rosa Border-Bottom wie bei Artikeln */
.ssw-content h2,
.lexikon-entry__content h2,
.page-content h2 {
    margin-top: 2.5rem;
    margin-bottom: 0.75rem;
    padding-top: 0.5rem;
    padding-bottom: 0.4rem;
    border-bottom: 2px solid var(--rose-light);
    color: var(--plum);
    font-size: 1.25rem;
}

/* H3-Styling */
.ssw-content h3,
.lexikon-entry__content h3,
.page-content h3 {
    margin-top: 2rem;
    margin-bottom: 0.5rem;
    color: var(--plum-light);
    font-size: 1.2rem;
}

/* Absaetze */
.page-content p {
    margin-bottom: 1.25rem;
}

/* Listen */
.ssw-content ul,
.ssw-content ol,
.lexikon-entry__content ul,
.lexikon-entry__content ol,
.page-content ul,
.page-content ol {
    margin: 1rem 0 1.25rem 2rem;
}

.ssw-content li,
.lexikon-entry__content li,
.page-content li {
    margin-bottom: 0.35rem;
}

/* Blockquotes */
.ssw-content blockquote,
.lexikon-entry__content blockquote,
.page-content blockquote {
    border-left: 4px solid var(--rose);
    padding: 1rem 1.5rem;
    margin: 1.5rem 0;
    background: var(--rose-pale);
    border-radius: 0 var(--radius) var(--radius) 0;
    font-style: italic;
    color: var(--text-light);
}

/* Bilder im Content */
.ssw-content img,
.lexikon-entry__content img,
.page-content img {
    border-radius: var(--radius);
    margin: 1rem 0;
    max-width: 100%;
    height: auto;
}

/* Links im Content */
.ssw-content a,
.lexikon-entry__content a,
.page-content a {
    color: var(--plum);
    text-decoration: underline;
    text-decoration-color: var(--rose-light);
    text-underline-offset: 2px;
}

.ssw-content a:hover,
.lexikon-entry__content a:hover,
.page-content a:hover {
    text-decoration-color: var(--plum);
}

/* WordPress Legacy Alignment (122 Artikel betroffen)
   Mobile-First: Kein Float auf kleinen Screens,
   Float erst ab 769px aktiviert. */

.article-content .aligncenter,
.ssw-content .aligncenter,
.lexikon-entry__content .aligncenter,
.page-content .aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.article-content .alignnone,
.ssw-content .alignnone,
.lexikon-entry__content .alignnone,
.page-content .alignnone {
    max-width: 100%;
}

/* Auf Mobile: alignleft/alignright werden zentriert (kein Float) */
.article-content .alignright,
.ssw-content .alignright,
.lexikon-entry__content .alignright,
.page-content .alignright,
.article-content .alignleft,
.ssw-content .alignleft,
.lexikon-entry__content .alignleft,
.page-content .alignleft {
    display: block;
    margin: 1em auto;
    max-width: 100%;
}

/* WordPress [caption] -> <figure class="wp-caption"> */
.wp-caption {
    max-width: 100%;
    margin: 1.5rem 0;
}

.wp-caption img {
    display: block;
    border-radius: var(--radius);
}

.wp-caption figcaption {
    font-size: 0.85rem;
    color: var(--text-muted);
    margin-top: 0.4rem;
    line-height: 1.5;
    font-style: italic;
}

/* Clearfix fuer Content-Bereiche mit floated Elementen */
.article-content::after,
.ssw-content::after,
.lexikon-entry__content::after,
.page-content::after {
    content: '';
    display: table;
    clear: both;
}

/* Haftungshinweis */
.article-disclaimer {
    background: var(--warm-gray);
    border-left: 3px solid var(--rose);
    padding: 1rem 1.25rem;
    margin: 2.5rem 0 1.5rem;
    font-size: 0.88rem;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    line-height: 1.6;
    color: var(--text-light);
}

.article-sponsored-notice {
    background: #fef8f2;
    border: 1px solid var(--rose);
    padding: 0.75rem 1rem;
    border-radius: var(--radius);
    margin-bottom: 1rem;
    font-size: 0.85rem;
    color: var(--plum);
}

/* Tags */
.article-tags {
    margin-top: 2rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--warm-gray);
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.article-tags .tag {
    display: inline-block;
    background: var(--rose-pale);
    color: var(--plum);
    padding: 0.25rem 0.7rem;
    border-radius: 20px;
    font-size: 0.82rem;
    text-decoration: none;
    transition: background var(--transition);
}

.article-tags .tag:hover {
    background: var(--rose-light);
    text-decoration: none;
}

/* Verwandte Artikel */
.related-articles {
    max-width: 780px;
    margin: 3rem auto 0;
    padding-top: 2rem;
    border-top: 2px solid var(--warm-gray);
}

.related-articles h2 {
    font-size: 1.35rem;
    margin-bottom: 1.25rem;
    color: var(--plum);
}

.related-articles__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}

.related-card {
    display: block;
    background: var(--white);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    text-decoration: none;
    color: var(--text);
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.related-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
    text-decoration: none;
}

.related-card__image {
    width: 100%;
    height: 160px;
    object-fit: cover;
    display: block;
}

.related-card__body {
    padding: 1rem;
}

.related-card__title {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.35;
    margin: 0 0 0.4rem;
    color: var(--text);
}

.related-card__excerpt {
    font-size: 0.85rem;
    color: var(--text-light);
    line-height: 1.5;
    margin: 0;
}

/* ============================================================
   Breadcrumb
   ============================================================ */

.breadcrumb ol {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    font-size: 0.85rem;
    margin-bottom: 1.5rem;
}

.breadcrumb li:not(:last-child)::after {
    content: ' / ';
    margin-left: 0.25rem;
    color: #bbb;
}

.breadcrumb a {
    color: var(--lavender);
}

.breadcrumb a:hover {
    color: var(--plum);
}

.breadcrumb [aria-current="page"] {
    color: var(--text-light);
}

/* ============================================================
   Lexikon
   ============================================================ */

.lexikon-intro {
    font-size: 1.1rem;
    color: var(--text-light);
    margin-bottom: 1.5rem;
}

.lexikon-az ul {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 2rem;
}

.lexikon-az a,
.lexikon-az .disabled {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.75rem;
    min-height: 2.75rem;
    text-align: center;
    border-radius: var(--radius);
    font-weight: 600;
    font-size: 0.95rem;
    transition: background var(--transition), color var(--transition);
}

.lexikon-az a {
    background: var(--rose-pale);
    color: var(--plum);
}

.lexikon-az a:hover {
    background: var(--plum);
    color: var(--white);
    text-decoration: none;
}

.lexikon-az a.active {
    background: var(--plum);
    color: var(--white);
}

.lexikon-az .disabled {
    background: var(--warm-gray);
    color: #ccc;
}

.lexikon-group__letter {
    font-size: 1.5rem;
    border-bottom: 2px solid var(--plum);
    padding-bottom: 0.25rem;
    margin: 1.5rem 0 0.75rem;
}

.lexikon-list {
    list-style: none;
}

.lexikon-list li {
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--warm-gray);
}

.lexikon-list__excerpt {
    color: #888;
    font-size: 0.9rem;
}

.lexikon-entry {
    max-width: 780px;
    margin: 0 auto;
}

.lexikon-entry__header {
    display: flex;
    align-items: baseline;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.lexikon-entry__letter {
    font-size: 2.5rem;
    font-family: var(--font-heading);
    color: var(--rose);
    opacity: 0.5;
}

.lexikon-entry__content {
    font-size: 1.05rem;
    line-height: 1.85;
    margin-bottom: 2rem;
}

.lexikon-entry__content p {
    margin-bottom: 1rem;
}

.lexikon-entry__nav {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    align-items: center;
    padding: 1.5rem 0;
    border-top: 1px solid var(--warm-gray);
    margin-top: 2rem;
}

.lexikon-entry__prev,
.lexikon-entry__next {
    flex: 1;
}

.lexikon-entry__prev,
.lexikon-entry__next,
.lexikon-entry__back {
    text-align: center;
}

/* ============================================================
   Static Pages (Impressum, Datenschutz, etc.)
   ============================================================ */

.static-page {
    max-width: 780px;
    margin: 0 auto;
}

.static-page header {
    margin-bottom: 1.5rem;
}

.child-pages {
    margin-top: 2.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--warm-gray-dark);
}

.child-pages h2 {
    margin-bottom: 0.75rem;
    font-size: 1.15rem;
}

.child-pages ul {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.child-pages li a {
    display: inline-block;
    padding: 0.5rem 1rem;
    background: var(--cream);
    border: 1px solid var(--warm-gray-dark);
    border-radius: var(--radius-sm);
    font-size: 0.95rem;
    transition: background var(--transition), border-color var(--transition);
}

.child-pages li a:hover {
    background: var(--rose-pale);
    border-color: var(--rose);
    text-decoration: none;
}

/* ============================================================
   Search
   ============================================================ */

.search-form {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin: 1.5rem 0;
    max-width: 600px;
}

.search-form__input {
    flex: 1;
    padding: 0.75rem 1rem;
    border: 2px solid var(--warm-gray);
    border-radius: var(--radius);
    font-size: 1rem;
    font-family: inherit;
    transition: border-color var(--transition);
}

.search-form__input:focus {
    outline: 2px solid var(--lavender);
    outline-offset: 2px;
    border-color: var(--lavender);
}

.search-form__button {
    padding: 0.75rem 1.5rem;
    background: var(--plum);
    color: var(--white);
    border: none;
    border-radius: var(--radius);
    font-size: 1rem;
    cursor: pointer;
    font-family: inherit;
    font-weight: 600;
    width: 100%;
    min-width: 44px;
    min-height: 44px;
    transition: background var(--transition);
}

.search-form__button:hover {
    background: var(--lavender);
}

.search-form__button:focus-visible {
    outline: 3px solid var(--lavender);
    outline-offset: 2px;
}

.search-result-count {
    color: var(--text-light);
    margin-bottom: 1rem;
}

.search-result {
    padding: 1.25rem 0;
    border-bottom: 1px solid var(--warm-gray);
}

.search-result__type {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--lavender);
    font-weight: 600;
}

.search-result__title {
    font-size: 1.2rem;
    margin: 0.25rem 0;
}

.search-result__excerpt {
    color: var(--text-light);
    font-size: 0.95rem;
}

.search-result__date {
    font-size: 0.8rem;
    color: #999;
}

/* ============================================================
   Pagination
   ============================================================ */

.pagination {
    margin: 2rem 0;
    text-align: center;
}

.pagination ul {
    list-style: none;
    display: inline-flex;
    gap: 0.25rem;
}

.pagination a,
.pagination__current {
    display: inline-block;
    padding: 0.5rem 0.85rem;
    border-radius: var(--radius);
    font-size: 0.9rem;
    min-width: 44px;
    min-height: 44px;
    line-height: 1.8;
    text-align: center;
    transition: background var(--transition), color var(--transition);
}

.pagination a {
    background: var(--rose-pale);
    color: var(--plum);
}

.pagination a:hover {
    background: var(--plum);
    color: var(--white);
    text-decoration: none;
}

.pagination__current {
    background: var(--plum);
    color: var(--white);
    font-weight: 600;
}

.pagination__dots {
    padding: 0.5rem 0.25rem;
    color: #999;
}

/* ============================================================
   Error Page
   ============================================================ */

.error-page {
    text-align: center;
    padding: 3rem 0;
}

.error-page h1 {
    font-size: 2.5rem;
    margin-bottom: 1rem;
}

.error-page__actions {
    margin: 2rem 0;
}

.error-page__actions ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    margin-top: 0.75rem;
}

.error-page__search {
    margin-top: 2rem;
}

.error-page__search .search-form {
    margin: 1rem auto;
}

/* ============================================================
   Category
   ============================================================ */

.category-header {
    margin-bottom: 1.5rem;
}

.category-description {
    font-size: 1.05rem;
    color: var(--text-light);
    margin: 0.5rem 0;
}

.category-count {
    font-size: 0.9rem;
    color: #999;
}

.subcategories ul {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 0.75rem 0 1.5rem;
}

.subcategories a {
    display: inline-block;
    background: var(--rose-pale);
    padding: 0.4rem 0.8rem;
    border-radius: var(--radius);
    font-size: 0.9rem;
    transition: background var(--transition);
}

.subcategories a:hover {
    background: var(--rose-light);
    text-decoration: none;
}

/* ============================================================
   Site Footer — Dunkel, 4-Spalten, strukturiert
   ============================================================ */

.site-footer {
    background: #2C2A2E;
    color: rgba(255, 255, 255, 0.7);
    padding: 0;
    margin-top: 0;
}

.footer-main {
    padding: 40px 0 24px;
}

.footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}

.footer-brand {
    font-family: var(--font-heading);
    font-size: 20px;
    color: var(--white);
    margin-bottom: 12px;
    font-weight: 600;
}

.footer-brand span {
    color: var(--rose);
}

.footer-brand-text {
    font-size: 15px;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.5);
    margin-bottom: 16px;
}

.footer-column h4 {
    text-transform: uppercase;
    font-size: 14px;
    font-family: var(--font-body);
    font-weight: 600;
    letter-spacing: 0.5px;
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: 16px;
}

.footer-column ul {
    list-style: none;
}

.footer-column li {
    margin-bottom: 0;
}

.footer-column a {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.6);
    transition: color var(--transition), opacity var(--transition);
    display: inline-block;
    padding: 10px 0;
    min-height: 44px;
    line-height: 1.7;
}

.footer-column a:hover {
    color: var(--white);
    opacity: 1;
    text-decoration: none;
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding: 20px 0;
    display: flex;
    flex-direction: column;
    text-align: center;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}

.footer-copyright {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.4);
}

.footer-bottom-links {
    display: flex;
    gap: 20px;
    justify-content: center;
}

.footer-bottom-links a {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.4);
}

.footer-bottom-links a:hover {
    color: var(--white);
    text-decoration: none;
}

/* Legacy-Footer-Styles (Abwaertskompatibilitaet) */
.site-footer > .container > a {
    color: var(--rose);
}

.site-footer > .container > a:hover {
    color: var(--rose-light);
}

.footer-nav ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    margin: 1rem 0;
}

.footer-nav a {
    color: rgba(255, 255, 255, 0.6);
}

.footer-nav a:hover {
    color: var(--white);
}

.footer-disclaimer {
    font-size: 0.85rem;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    padding: 1.25rem 0;
    margin-bottom: 0;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.65);
    text-align: center;
    max-width: 48rem;
    margin-left: auto;
    margin-right: auto;
}

/* ============================================================
   Utility
   ============================================================ */

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

/* ============================================================
   Responsive: Ab 481px (Kleine Smartphones -> Normale Smartphones)
   ============================================================ */

@media (min-width: 481px) {

    .hero h1 {
        font-size: 28px;
    }

    .ssw-grid {
        gap: 8px;
    }

    .about-stats {
        gap: 32px;
    }

    .about-stat__number {
        font-size: 28px;
    }

    .cookie-banner {
        padding: 20px 24px;
    }

    .cookie-banner__inner {
        gap: 24px;
    }

    .cookie-banner__text {
        flex: 1 1 400px;
        flex-basis: auto;
        font-size: 15px;
    }

    .cookie-banner__actions {
        width: auto;
    }

    .cookie-banner__btn {
        flex: none;
        font-size: 15px;
        padding: 10px 20px;
    }
}

/* ============================================================
   Responsive: Ab 769px (Tablet)
   ============================================================ */

@media (min-width: 769px) {

    /* --- Header: Desktop --- */
    .site-header .container {
        height: 80px;
    }

    .site-logo img {
        height: 56px;
    }

    /* Hamburger verstecken */
    .nav-toggle {
        display: none;
    }

    /* Navigation: Inline (Desktop) */
    .main-nav {
        position: static;
        width: auto;
        background: none;
        padding: 0;
        transform: none;
        transition: none;
        z-index: auto;
        overflow-y: visible;
        box-shadow: none;
    }

    .main-nav ul {
        flex-direction: row;
        gap: 0.25rem;
    }

    .main-nav a {
        color: var(--text-light);
        font-size: 15px;
        padding: 11px 14px;
        border-bottom: none;
        border-radius: 8px;
    }

    .main-nav a:hover,
    .main-nav a:focus-visible {
        border-bottom-color: transparent;
        color: var(--plum);
        background: var(--rose-pale);
    }

    .main-nav a.is-active {
        border-bottom-color: transparent;
        color: var(--plum);
        background: rgba(107, 58, 107, 0.06);
    }

    /* Nav-Overlay auf Desktop nicht noetig */
    .nav-overlay {
        display: none;
    }

    /* --- Hero: Tablet --- */
    .hero {
        padding: 80px 24px 72px;
    }

    .hero h1 {
        font-size: 34px;
    }

    .hero__text {
        font-size: 19px;
    }

    /* --- SSW Grid: 4 Spalten --- */
    .ssw-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    .ssw-finder {
        padding: 36px;
    }

    /* --- SSW Landingpages --- */
    .ssw-header {
        margin-bottom: var(--space-2xl);
        padding-bottom: var(--space-xl);
    }

    .ssw-header h1 {
        font-size: 32px;
    }

    .ssw-facts {
        padding: var(--space-lg) var(--space-lg) var(--space-lg) var(--space-xl);
        margin: var(--space-xl) 0;
    }

    .ssw-tips {
        padding: var(--space-lg) var(--space-xl);
        margin: var(--space-xl) 0;
    }

    .ssw-outlook {
        padding: var(--space-lg) var(--space-xl);
        margin: var(--space-xl) 0;
    }

    .ssw-tips li {
        padding-left: 28px;
    }

    /* --- Topics: 2 Spalten --- */
    .topics-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .topics-section {
        padding: 80px 24px;
    }

    /* --- Trust-Bar --- */
    .trust-bar .container {
        gap: 48px;
    }

    /* --- CTA-Band --- */
    .cta-band {
        padding: 64px 24px;
    }

    .cta-band h2 {
        font-size: 30px;
    }

    /* --- Schnellzugriff: 2 Spalten --- */
    .quick-access__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.25rem;
    }

    .quick-access__box {
        flex-direction: column;
        text-align: center;
        padding: 1.75rem 1.25rem;
        gap: 0;
    }

    .quick-access__icon {
        font-size: 2.25rem;
        margin-bottom: 0.75rem;
        flex-shrink: initial;
    }

    /* --- Artikel: Tablet --- */
    .articles-list {
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    }

    .article-header h1 {
        font-size: 2.1rem;
    }

    .article-meta {
        font-size: 0.88rem;
    }

    .article-featured-image {
        max-height: 440px;
        margin: 0 0 2rem;
        border-radius: var(--radius);
    }

    .article-toc {
        padding: 1.25rem 1.5rem;
    }

    .article-content,
    .ssw-content,
    .page-content {
        font-size: 1.05rem;
    }

    .article-content h2,
    .ssw-content h2,
    .lexikon-entry__content h2,
    .page-content h2 {
        font-size: 1.45rem;
    }

    /* WordPress Alignment: Float erst ab Tablet aktivieren */
    .article-content .alignright,
    .ssw-content .alignright,
    .lexikon-entry__content .alignright,
    .page-content .alignright {
        float: right;
        margin: 0.5em 0 1em 1.5em;
        max-width: 50%;
    }

    .article-content .alignleft,
    .ssw-content .alignleft,
    .lexikon-entry__content .alignleft,
    .page-content .alignleft {
        float: left;
        margin: 0.5em 1.5em 1em 0;
        max-width: 50%;
    }

    .related-articles__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* --- Sections allgemein --- */
    .section-header h2 {
        font-size: 34px;
    }

    .section-header p {
        font-size: 18px;
    }

    .stories-section,
    .articles-section,
    .about-section {
        padding: 80px 24px;
    }

    /* --- About --- */
    .about-stats {
        justify-content: flex-start;
    }

    /* --- Lexikon --- */
    .lexikon-entry__nav {
        flex-direction: row;
        justify-content: space-between;
        gap: 0;
    }

    .lexikon-entry__next {
        text-align: right;
    }

    /* --- Footer: 2 Spalten --- */
    .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 32px;
    }

    .footer-main {
        padding: 56px 0 40px;
    }

    .footer-bottom {
        flex-direction: row;
        justify-content: space-between;
        text-align: left;
        gap: 0;
    }

    .footer-bottom-links {
        justify-content: flex-end;
    }

    .footer-nav ul {
        flex-direction: row;
        align-items: flex-start;
        gap: 1.5rem;
    }

    .error-page__actions ul {
        flex-direction: row;
        align-items: center;
    }

    /* --- Search --- */
    .search-form {
        flex-direction: row;
    }

    .search-form__button {
        width: auto;
    }
}

/* ============================================================
   Responsive: Ab 901px (Desktop)
   ============================================================ */

@media (min-width: 901px) {

    /* Hero: 2 Spalten */
    .hero__inner {
        grid-template-columns: 1fr 1fr;
        gap: 64px;
        text-align: left;
    }

    .hero h1 {
        font-size: 44px;
    }

    .hero__text {
        margin-left: 0;
        margin-right: 0;
    }

    .hero__buttons {
        justify-content: flex-start;
    }

    /* Topics: 3 Spalten */
    .topics-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    /* Stories: 3 Spalten */
    .stories-grid {
        grid-template-columns: repeat(3, 1fr);
        max-width: none;
        margin-left: 0;
        margin-right: 0;
    }

    /* Artikel: 2 Spalten */
    .articles-section-grid {
        grid-template-columns: 1fr 1fr;
    }

    /* About: 2 Spalten */
    .about-grid {
        grid-template-columns: 1fr 1.5fr;
        gap: 64px;
    }

    /* Footer: 4 Spalten */
    .footer-grid {
        grid-template-columns: 2fr 1fr 1fr 1fr;
        gap: 40px;
    }

    /* Quick Access: auto-fit */
    .quick-access__grid {
        grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    }
}

/* ============================================================
   Cookie-Banner (DSGVO)
   ============================================================ */

.cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 9000;
    background: var(--warm-white);
    border-top: 2px solid var(--rose-light);
    box-shadow: 0 -4px 20px rgba(107, 58, 107, 0.1);
    padding: 16px;
    transform: translateY(100%);
    transition: transform 0.4s ease-out, opacity 0.4s ease-out;
    opacity: 0;
}

.cookie-banner.is-visible {
    transform: translateY(0);
    opacity: 1;
}

.cookie-banner.is-hiding {
    transform: translateY(100%);
    opacity: 0;
}

.cookie-banner__inner {
    max-width: 960px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.cookie-banner__text {
    flex-basis: 100%;
    font-size: 14px;
    line-height: 1.6;
    color: var(--text);
    margin: 0;
}

.cookie-banner__text a {
    color: var(--plum);
    text-decoration: underline;
    text-decoration-color: var(--rose-light);
    text-underline-offset: 2px;
}

.cookie-banner__text a:hover {
    color: var(--plum-hover);
    text-decoration-color: var(--rose);
}

.cookie-banner__actions {
    display: flex;
    gap: 10px;
    flex-shrink: 0;
    flex-wrap: wrap;
    width: 100%;
}

.cookie-banner__btn {
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 600;
    padding: 10px 14px;
    border-radius: 6px;
    border: none;
    cursor: pointer;
    transition: background-color 0.2s ease, transform 0.1s ease;
    min-height: 44px;
    min-width: 44px;
    line-height: 1.3;
    flex: 1;
    text-align: center;
}

.cookie-banner__btn:focus-visible {
    outline: 3px solid var(--lavender);
    outline-offset: 2px;
}

.cookie-banner__btn:active {
    transform: scale(0.97);
}

.cookie-banner__btn--accept {
    background-color: var(--plum);
    color: #fff;
}

.cookie-banner__btn--accept:hover {
    background-color: var(--plum-hover);
}

.cookie-banner__btn--necessary {
    background-color: transparent;
    color: var(--text-light);
    border: 1.5px solid var(--warm-gray-dark);
}

.cookie-banner__btn--necessary:hover {
    border-color: var(--rose);
    color: var(--text);
    background-color: var(--rose-pale);
}

/* ============================================================
   Kontaktformular
   ============================================================ */

.contact-page .page-content {
    max-width: 680px;
}

.contact-form {
    margin-top: var(--space-lg);
}

.contact-form__group {
    margin-bottom: var(--space-md);
}

.contact-form__label {
    display: block;
    margin-bottom: var(--space-xs);
    font-weight: 600;
    color: var(--text);
    font-size: 0.95rem;
}

.contact-form__required {
    color: var(--plum);
    font-weight: 700;
}

.contact-form__input,
.contact-form__textarea {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 2px solid var(--warm-gray-dark);
    border-radius: var(--radius-sm);
    font-size: 1rem;
    font-family: inherit;
    color: var(--text);
    background: var(--warm-white);
    transition: border-color var(--transition), box-shadow var(--transition);
    box-sizing: border-box;
}

.contact-form__input:focus,
.contact-form__textarea:focus {
    outline: 2px solid var(--lavender);
    outline-offset: 2px;
    border-color: var(--lavender);
    box-shadow: 0 0 0 3px rgba(139, 126, 184, 0.15);
}

.contact-form__input--error {
    border-color: #c0392b;
}

/* Feld-spezifische Fehlermeldungen (WCAG 3.3.1 - aria-describedby) */
.field-error {
    display: block;
    margin-top: 4px;
    color: #922b21;
    font-size: 0.85rem;
    font-weight: 500;
    line-height: 1.4;
}

.contact-form__textarea {
    resize: vertical;
    min-height: 160px;
}

.contact-form__hint {
    display: block;
    margin-top: 4px;
    color: var(--text-muted);
    font-size: 0.85rem;
}

.contact-form__submit {
    margin-top: var(--space-sm);
    padding: 14px 36px;
    font-size: 1.05rem;
}

.contact-form__note {
    margin-top: var(--space-md);
    color: var(--text-muted);
    line-height: 1.6;
}

.contact-form__note a {
    color: var(--plum);
    text-decoration: underline;
}

.contact-form__note a:hover {
    color: var(--plum-hover);
}

/* Honeypot — unsichtbar fuer Menschen */
.contact-form__hp {
    position: absolute;
    left: -9999px;
    height: 0;
    overflow: hidden;
    opacity: 0;
}

/* Erfolgs- und Fehlermeldungen */
.contact-alert {
    padding: var(--space-md);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-lg);
    line-height: 1.6;
}

.contact-alert strong {
    display: block;
    margin-bottom: 0.25rem;
}

.contact-alert ul {
    margin: 0.5rem 0 0 1.25rem;
    padding: 0;
}

.contact-alert ul li {
    margin-bottom: 0.25rem;
}

.contact-alert--success {
    background: var(--sage-light);
    border: 2px solid var(--sage);
    color: #1a5928;
}

.contact-alert--error {
    background: #fde8e8;
    border: 2px solid #e74c3c;
    color: #922b21;
}

/* ============================================================
   Newsletter-Anmeldeformular (Footer-Widget)
   ============================================================ */

.newsletter-signup {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: 32px 0;
    max-width: var(--container-width, 1200px);
    margin: 0 auto;
    padding-left: var(--container-padding, 20px);
    padding-right: var(--container-padding, 20px);
}

.newsletter-signup__inner {
    max-width: 560px;
    margin: 0 auto;
    text-align: center;
}

.newsletter-signup__text {
    font-family: var(--font-heading);
    font-size: 16px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.85);
    margin-bottom: 16px;
    line-height: 1.4;
}

.newsletter-signup__form {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}

.newsletter-signup__label {
    display: block;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.85);
    margin-bottom: 6px;
    text-align: left;
    max-width: 440px;
    margin-left: auto;
    margin-right: auto;
}

.newsletter-signup__field {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 440px;
    gap: 8px;
}

.newsletter-signup__input {
    flex: 1;
    padding: 12px 16px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.08);
    color: var(--white);
    font-size: 15px;
    font-family: var(--font-body);
    transition: border-color 0.2s ease, background 0.2s ease;
}

.newsletter-signup__input::placeholder {
    color: rgba(255, 255, 255, 0.4);
}

.newsletter-signup__input:focus {
    outline: 2px solid var(--rose);
    outline-offset: 2px;
    border-color: var(--rose);
    background: rgba(255, 255, 255, 0.12);
}

.newsletter-signup__btn {
    padding: 12px 24px;
    background: var(--plum);
    color: var(--white);
    border: 2px solid var(--plum);
    border-radius: 6px;
    font-size: 15px;
    font-weight: 600;
    font-family: var(--font-body);
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease;
    white-space: nowrap;
    width: 100%;
}

.newsletter-signup__btn:hover {
    background: var(--plum-hover);
    border-color: var(--plum-hover);
}

.newsletter-signup__btn:focus-visible {
    outline: 2px solid var(--rose);
    outline-offset: 2px;
}

.newsletter-signup__hint {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.35);
    margin-top: 4px;
}

.newsletter-signup__hint a {
    color: rgba(255, 255, 255, 0.45);
    text-decoration: underline;
    text-decoration-color: rgba(255, 255, 255, 0.2);
}

.newsletter-signup__hint a:hover {
    color: rgba(255, 255, 255, 0.7);
}

/* Honeypot — unsichtbar fuer echte Nutzer */
.newsletter-signup__hp {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
}

/* Flash-Meldungen */
.newsletter-signup__alert {
    padding: 10px 16px;
    border-radius: 6px;
    font-size: 14px;
    margin-bottom: 12px;
    width: 100%;
    max-width: 440px;
    text-align: left;
}

.newsletter-signup__alert--success {
    background: rgba(143, 185, 150, 0.15);
    border: 1px solid rgba(143, 185, 150, 0.4);
    color: #a8d5b0;
}

.newsletter-signup__alert--error {
    background: rgba(231, 76, 60, 0.15);
    border: 1px solid rgba(231, 76, 60, 0.4);
    color: #f0a8a0;
}

.newsletter-signup__alert--info {
    background: rgba(139, 126, 184, 0.15);
    border: 1px solid rgba(139, 126, 184, 0.4);
    color: var(--lavender-light);
}

/* Responsive: Desktop (Newsletter-Feld nebeneinander) */
@media (min-width: 481px) {
    .newsletter-signup__field {
        flex-direction: row;
        gap: 0;
    }

    .newsletter-signup__input {
        border-right: none;
        border-radius: 6px 0 0 6px;
    }

    .newsletter-signup__btn {
        border-radius: 0 6px 6px 0;
        width: auto;
    }

    .newsletter-signup__text {
        font-size: 18px;
    }
}

/* ============================================================
   Erfahrungsbericht-Formular
   ============================================================ */

/* Intro-Text */
.story-intro {
    color: var(--text-muted);
    margin-bottom: 0.5rem;
}

.story-intro:last-of-type {
    margin-bottom: 2rem;
}

/* Textarea groesser fuer Berichte */
.story-form__textarea {
    min-height: 200px;
    font-size: 1rem;
    line-height: 1.75;
}

/* Select-Feld native */
.story-form__select {
    appearance: auto;
    max-width: 200px;
}

/* Details/Summary fuer optionale Felder */
.story-form__details {
    margin: 1.5rem 0;
    border: 1px solid var(--warm-gray-dark);
    border-radius: var(--radius);
    background: var(--cream);
}

.story-form__details-toggle {
    padding: 0.85rem 1rem;
    cursor: pointer;
    color: var(--plum);
    font-weight: 600;
    font-size: 0.9rem;
    line-height: 1.5;
    list-style: none;
}

.story-form__details-toggle::-webkit-details-marker {
    display: none;
}

.story-form__details-toggle::before {
    content: '\25B6';
    display: inline-block;
    margin-right: 0.5rem;
    font-size: 0.75rem;
    transition: transform 0.2s ease;
}

.story-form__details[open] > .story-form__details-toggle::before {
    transform: rotate(90deg);
}

.story-form__details-content {
    padding: 0 1rem 1rem;
}

/* Einwilligungen Fieldset */
.story-form__consent {
    border: none;
    padding: 0;
    margin: 2rem 0 1.5rem;
}

.story-form__consent legend {
    font-family: var(--font-heading);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--text-dark);
    margin-bottom: 1rem;
    padding: 0;
}

/* Checkbox-Labels */
.contact-form__checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
    line-height: 1.5;
    font-size: 0.9rem;
    color: var(--text-light);
}

.contact-form__checkbox-label input[type="checkbox"] {
    flex-shrink: 0;
    margin-top: 0.2rem;
    width: 18px;
    height: 18px;
    accent-color: var(--plum);
    cursor: pointer;
}

.contact-form__checkbox--error {
    color: var(--error-text, #b91c1c);
}

.contact-form__checkbox--error input[type="checkbox"] {
    outline: 2px solid var(--error-text, #b91c1c);
    outline-offset: 1px;
}

/* Erfolgsmeldung */
.story-success p {
    margin: 0.75rem 0 0;
    font-size: 0.95rem;
}

.story-success p:last-child {
    margin-bottom: 0;
}

/* Desktop */
@media (min-width: 769px) {
    .story-form__textarea {
        min-height: 240px;
    }

    .story-form__details-toggle {
        font-size: 0.95rem;
        padding: 1rem 1.25rem;
    }

    .story-form__details-content {
        padding: 0 1.25rem 1.25rem;
    }
}

/* ============================================================
   Reduced Motion -- WCAG 2.3.3
   ============================================================ */

/* Footer-Headings (h2 visuell wie vorher h4) */
.footer-heading {
    font-family: var(--font-heading);
    font-size: 16px;
    font-weight: 600;
    color: var(--white);
    margin-bottom: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

@media (prefers-contrast: more) {
    :root {
        --text-muted: #555;
        --rose: #9B5B7A;
        --lavender: #6B5E98;
    }
    .footer-column a {
        color: rgba(255, 255, 255, 0.95);
    }
}

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

/* ============================================================
   PWA -- Batch 17: UX-Erweiterungen
   ============================================================ */

/* --- 17.1: Install-Banner ----------------------------------------- */
.pwa-install-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: #fff;
    border-top: 2px solid var(--plum);
    /* iOS Safe Area (Notch/Home-Indicator) */
    padding: 0.875rem 1rem calc(0.875rem + env(safe-area-inset-bottom, 0px)) 1rem;
    z-index: 900; /* Unter Cookie-Banner (1000), ueber Content */
    box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.1);
}
.pwa-install-banner[hidden] { display: none; }

/* Mobil: kompakter 2-Zeiler (Text oben, Buttons unten) */
.pwa-install-banner__inner {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    max-width: 860px;
    margin: 0 auto;
}
/* Icon auf Mobil ausblenden */
.pwa-install-banner__icon {
    display: none;
}
.pwa-install-banner__content {
    min-width: 0;
}
.pwa-install-banner__title {
    font-weight: 700;
    font-size: 0.95rem;
    color: var(--plum);
    margin-bottom: 0.2rem;
}
.pwa-install-banner__desc {
    font-size: 0.85rem;
    color: var(--text-muted, #666);
    margin: 0;
}
.pwa-install-banner__actions {
    display: flex;
    gap: 0.5rem;
}
.pwa-install-banner__btn {
    flex: 1;
    min-height: 44px;
    padding: 0.5rem 0.75rem;
    border-radius: 4px;
    border: 2px solid var(--plum);
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1.2;
    transition: background 0.15s, color 0.15s;
    text-align: center;
}
.pwa-install-banner__btn--install {
    background: var(--plum);
    color: #fff;
}
.pwa-install-banner__btn--install:hover,
.pwa-install-banner__btn--install:active {
    background: #5a306a;
    border-color: #5a306a;
}
.pwa-install-banner__btn--later {
    background: transparent;
    color: var(--plum);
    flex: 0 0 auto;
}
.pwa-install-banner__btn--later:hover,
.pwa-install-banner__btn--later:active {
    background: #f3edf3;
}
.pwa-install-banner__btn:focus-visible {
    outline: 3px solid var(--plum);
    outline-offset: 2px;
}

/* Tablet+: horizontales Layout mit Icon */
@media (min-width: 600px) {
    .pwa-install-banner__inner {
        flex-direction: row;
        align-items: center;
        gap: 0.75rem;
    }
    .pwa-install-banner__icon {
        display: block;
        flex-shrink: 0;
        border-radius: 8px;
    }
    .pwa-install-banner__content {
        flex: 1;
    }
    .pwa-install-banner__actions {
        flex-shrink: 0;
    }
    .pwa-install-banner__btn {
        flex: 0 0 auto;
    }
    .pwa-install-banner__btn--later {
        flex: 0 0 auto;
    }
}

/* --- 17.2: Online/Offline-Status ---------------------------------- */
.connection-status {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    padding: 0.5rem 1rem;
    text-align: center;
    font-size: 0.9rem;
    font-weight: 600;
    z-index: 1100;
    transition: transform 0.2s ease;
}
.connection-status[hidden] { display: none; }

.connection-status--online {
    background: #d4edda;
    color: #1a5c2e; /* Kontrast >= 7:1 auf #d4edda */
    border-bottom: 2px solid #1a7a3a;
}
.connection-status--offline {
    background: #fff3cd;
    color: #7a4f00; /* Kontrast >= 7:1 auf #fff3cd */
    border-bottom: 2px solid #d4a017;
}

/* --- 17.3: Offline speichern -------------------------------------- */
.article-save-offline {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin: 0.75rem 0 1.25rem;
    flex-wrap: wrap;
}
.article-save-offline[hidden] { display: none; }

.article-save-offline__btn {
    min-height: 44px;
    padding: 0.5rem 1.25rem;
    background: transparent;
    color: var(--plum);
    border: 2px solid var(--plum);
    border-radius: 4px;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
}
.article-save-offline__btn:hover {
    background: #f3edf3;
}
.article-save-offline__btn:focus-visible {
    outline: 3px solid var(--plum);
    outline-offset: 2px;
}
.article-save-offline__btn:disabled {
    opacity: 0.7;
    cursor: default;
}
.article-save-offline__status {
    font-size: 0.875rem;
    color: var(--text-muted, #666);
}

/* --- 17.4: Standalone-Navigation ---------------------------------- */
.pwa-back-btn {
    display: none; /* Standard: verborgen */
    color: var(--plum);
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    min-height: 44px;
    align-items: center;
}
.pwa-back-btn:focus-visible {
    outline: 3px solid var(--plum);
    outline-offset: 2px;
}

@media (display-mode: standalone) {
    /* Zurueck-Button einblenden */
    .pwa-back-btn {
        display: inline-flex;
    }
    /* Safe-Area oben (iPhone Notch / Dynamic Island) */
    .site-header {
        padding-top: calc(0.75rem + env(safe-area-inset-top, 0px));
    }
}

/* --- PWA: In Print-Ausgabe nicht drucken -------------------------- */
@media print {
    .pwa-install-banner,
    .connection-status,
    .article-save-offline,
    .pwa-back-btn {
        display: none !important;
    }
}

/* --- Reduzierte Bewegung fuer PWA-Elemente ------------------------ */
@media (prefers-reduced-motion: reduce) {
    .pwa-install-banner__btn,
    .article-save-offline__btn,
    .connection-status {
        transition: none;
    }
}

/* ============================================================
   Print
   ============================================================ */

@media print {
    .site-header,
    .site-footer,
    .nav-toggle,
    .nav-overlay,
    .quick-access,
    .related-articles,
    .pagination,
    .article-tags,
    .trust-bar,
    .cta-band,
    .ssw-finder,
    .cookie-banner,
    .newsletter-signup {
        display: none;
    }

    body {
        color: #000;
        background: #fff;
        font-size: 12pt;
    }

    .article-content a::after {
        content: ' (' attr(href) ')';
        font-size: 0.8em;
        color: #555;
    }
}
