@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap');
/*
 * FitStaff Akademie — Globales Kurs-CSS (MFA-Paket) · PREMIUM
 * Stand: Juni 2026
 *
 * ─────────────────────────────────────────────────────────────
 * FARBROLLEN (premium.md-konform) — WICHTIG:
 *
 *   --primary       = ACTION-Rolle. Struktur & Interaktion.
 *                     Buttons, Nummern-Kreise, Progress-Bars,
 *                     Sidebar-Akzente, Hero-Border, Quiz-Auswahl,
 *                     Pfeil-Listen. Kurs-spezifisch (Navy/Blau/Lila).
 *
 *   --trust         = TRUST-Rolle. IMMER GRÜN, kursunabhängig.
 *                     Häkchen (✓), Quiz-korrekt, Erledigt-Badges,
 *                     Erfolgs-Karten, .accent-Wörter.
 *                     >>> Kurs-Overrides fassen --trust NIE an. <<<
 *
 * Kursfarbe überschreiben per Inline-<style> im Modul-HTML —
 * NUR --primary / --primary-dark / --header-bg setzen:
 *
 *   MFA-Default (Hygiene/Datenschutz/Brandschutz/Notfall/Arbeitsschutz):
 *     (kein Override — Default ist Navy)
 *
 *   AGG:
 *     <style>:root{
 *       --primary:      #2D6CDF;
 *       --primary-dark: #1f4fa8;
 *       --header-bg:    linear-gradient(135deg,#15284a 0%,#213d70 55%,#2d6cdf 100%);
 *     }</style>
 *
 *   Pflege (zukünftig):
 *     <style>:root{
 *       --primary:      #7c3aed;
 *       --primary-dark: #5b21b6;
 *       --header-bg:    linear-gradient(135deg,#1e1a3c 0%,#2d246b 55%,#7c3aed 100%);
 *     }</style>
 * ─────────────────────────────────────────────────────────────
 * MOBILE: Alle Breakpoints liegen in shared/css/mobile.css und
 *         werden von route.ts automatisch injiziert.
 * ─────────────────────────────────────────────────────────────
 */
:root {
    --bg: #f5f6f9;
    --surface: #ffffff;
    --surface-soft: #f3f5f9;
    --heading: #182238;
    --text: #4a5560;
    --muted: #7a8899;

    /* ACTION-Rolle (Kurs-spezifisch, MFA-Default = Navy) */
    /* Default-Navy exakt auf Webapp-Navy (premium.md): #1c2f5e Action, #0f1f3d tief/Hover */
    --primary: #1c2f5e;
    --primary-dark: #0f1f3d;

    /* TRUST-Rolle (immer grün, nie per Kurs überschreiben) */
    --trust: #0fb5a6;
    --trust-dark: #0a857a;

    --secondary: #7496ac;
    /* Petrol-Akzent („Freude"); klar blaustichig, eindeutig ≠ Trust-Grün */
    --accent: #0e9aa7;
    --accent-dark: #0a6f78;
    --danger: #e11d74;
    --line: #e4eaf2;
    --shadow: 0 18px 48px rgba(24, 38, 56, 0.09);

    --header-bg: linear-gradient(135deg, #153151 0%, #214d7b 55%, #1a7a6e 100%);

    --font-head: 'Montserrat', sans-serif;
    --font-body: 'Montserrat', sans-serif;
    --radius: 22px;
    --radius-lg: 30px;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: clip; }
body {
    font-family: var(--font-body);
    background:
        radial-gradient(circle at 15% 0%, rgba(28,47,94,0.05), transparent 40%),
        linear-gradient(180deg, #f9fafc 0%, #f3f5f9 100%);
    color: var(--text);
    line-height: 1.7;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    letter-spacing: -0.003em;
}
img, video { max-width: 100%; height: auto; display: block; }

/* Grain-Overlay: dezente Print-Anmutung über die ganze Seite (premium.md-Marker) */
body::before { content: ""; position: fixed; inset: 0; z-index: 9999; pointer-events: none; opacity: 0.035; mix-blend-mode: multiply; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
@media (prefers-reduced-motion: reduce) { body::before { display: none; } }

/* Editorial-Akzentwort: kursive grüne Hervorhebung in Headlines */
.accent { font-family: var(--font-head); font-style: italic; font-weight: 400; color: var(--trust-dark); }

.reading-progress { position: fixed; left: 0; top: 0; width: 100%; height: 4px; background: rgba(255,255,255,0.25); z-index: 1000; }
.reading-progress__bar { width: 0%; height: 100%; background: linear-gradient(90deg, var(--accent), var(--primary)); box-shadow: 0 0 18px color-mix(in srgb, var(--primary) 32%, transparent); }
.brand-bar { background: #ffffff; border-bottom: 1px solid var(--line); box-shadow: 0 6px 18px rgba(17, 39, 64, 0.05); position: relative; z-index: 10000; }
.brand-bar__inner { max-width: 1200px; margin: 0 auto; padding: 16px 22px; display: flex; align-items: center; gap: 14px; }
.brand-bar__copy { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.brand-bar__label { font-family: var(--font-head); font-size: 1rem; font-weight: 600; color: var(--heading); line-height: 1.1; letter-spacing: 0; }
.brand-bar__sub { font-size: 0.8rem; color: var(--accent-dark); line-height: 1.2; }
.page-header {
    background: radial-gradient(circle at top left, rgba(14, 154, 167, 0.18), transparent 28%), var(--header-bg);
    color: #fff; padding: 30px 22px 28px; box-shadow: 0 10px 30px rgba(17, 39, 64, 0.18);
}
.header-inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.header-logo { width: 170px; height: auto; flex-shrink: 0; }
.header-subtitle { font-size: 0.8em; text-transform: uppercase; letter-spacing: 0.16em; opacity: 0.85; margin-bottom: 10px; font-weight: 500; }
.header-title { font-family: var(--font-head); font-size: clamp(1.35rem, 2.2vw, 1.9rem); line-height: 1.16; font-weight: 700; margin-bottom: 8px; letter-spacing: -0.01em; }
.header-text { max-width: 760px; color: rgba(255,255,255,0.9); }
.header-badge span { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; border-radius: 999px; background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.2); backdrop-filter: blur(6px); font-weight: 600; white-space: nowrap; }
.page-wrap { max-width: 1200px; margin: 26px auto 44px; padding: 0 14px; }
.layout { display: grid; grid-template-columns: 244px minmax(0, 1fr); gap: 26px; align-items: start; }
.sidebar, .card { background: var(--surface); border-radius: var(--radius); box-shadow: var(--shadow); }
.sidebar { padding: 18px 16px; position: sticky; top: 16px; border: 1px solid var(--line); }
.course-badge { display: inline-flex; align-items: center; gap: 7px; background: color-mix(in srgb, var(--primary) 8%, #fff); color: var(--primary-dark); font-size: 0.76em; font-weight: 600; padding: 6px 11px; border-radius: 999px; margin-bottom: 14px; border: 1px solid color-mix(in srgb, var(--primary) 16%, transparent); }
.sidebar-title { font-family: var(--font-head); font-size: 0.98em; font-weight: 600; color: var(--heading); }
.sidebar-progress-label { font-size: 0.8em; margin: 8px 0 6px; color: var(--muted); }
.progress-bar { width: 100%; height: 9px; background: #e4eaf2; border-radius: 999px; overflow: hidden; margin-bottom: 18px; }
.progress-bar__inner { width: 10%; height: 100%; background: linear-gradient(90deg, var(--primary), color-mix(in srgb, var(--primary) 60%, #fff)); }
.sidebar-mini-card { background: var(--surface-soft); border: 1px solid var(--line); border-radius: 12px; padding: 11px 13px; margin-bottom: 14px; }
.mini-label { font-size: 0.72em; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); margin-bottom: 5px; font-weight: 500; }
.mini-value { font-family: var(--font-head); font-size: 1.2rem; font-weight: 700; color: var(--heading); }
.module-list { list-style: none; display: grid; gap: 5px; }
.module-list li { display: flex; align-items: flex-start; gap: 9px; padding: 8px 9px; border-radius: 10px; color: var(--text); font-size: 0.82em; transition: background 0.2s ease, transform 0.2s ease; }
.module-list li.current { background: var(--accent-dark); color: #fff; font-weight: 600; transform: translateX(2px); }
.module-list li.current .status-icon { color: #fff; }
.status-icon { width: 18px; display: inline-flex; justify-content: center; padding-top: 2px; flex-shrink: 0; color: var(--trust); }
.card { padding: 40px 44px; max-width: 900px; margin-left: auto; margin-right: auto; border: 1px solid var(--line); }
/* Keine Wortumbrüche im Lesetext */
.card, .card *, .hero-panel, .hero-panel *, .content-section, .content-section * {
  word-break: normal !important;
  overflow-wrap: break-word !important; /* lange Komposita brechen NUR, wenn sie sonst aus der Karte laufen */
  hyphens: none !important;
  -webkit-hyphens: none !important;
}
.hero-panel { background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 6%, #fff), var(--surface-soft) 60%, color-mix(in srgb, var(--accent) 10%, #fff)); border: 1px solid color-mix(in srgb, var(--primary) 12%, transparent); border-radius: var(--radius-lg); padding: 34px 28px; margin-bottom: 32px; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 9px; padding: 8px 15px; border-radius: 999px; background: #fff; color: var(--primary-dark); font-size: 0.78em; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: 16px; border: 1px solid var(--line); }
.hero-eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--trust); box-shadow: 0 0 0 0 color-mix(in srgb, var(--trust) 50%, transparent); animation: vcPulse 2.4s ease-out infinite; }
@keyframes vcPulse { 0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--trust) 50%, transparent); } 70% { box-shadow: 0 0 0 8px transparent; } 100% { box-shadow: 0 0 0 0 transparent; } }
.hero-title, .content-section h2, .content-section h3, .card > h2, .card > h3, .card h3 { font-family: var(--font-head); color: var(--heading); line-height: 1.2; text-align: center; font-weight: 700; letter-spacing: -0.01em; }
.hero-title { font-size: clamp(1.25rem, 1.9vw, 1.6rem); margin-bottom: 14px; text-align: center; }
.hero-lead, .section-intro, p { max-width: 720px; }
p { margin: 0 auto 1.2em auto; text-align: center; }
blockquote { text-align: center; }
ol, ul.icon-list, ul.icon-grid { text-align: center; }
ol li { text-align: center; }
.content-section { margin-bottom: 42px; }
.content-section h2 { font-size: clamp(1.15rem, 1.5vw, 1.38rem); margin-bottom: 16px; }
.content-section h3 { font-size: 1.06rem; margin-bottom: 10px; font-weight: 600; }
.section-headline-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 8px; }
.goal-columns, .overview-grid, .impact-grid, .concept-compare { display: grid; gap: 20px; }
.goal-columns, .overview-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.impact-grid { grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); margin: 18px 0 22px; }
/* ── Einheitlicher Stapelabstand (systematisch) ────────────────────
   Zwei aufeinanderfolgende Karten/Boxen bekommen IMMER denselben
   vertikalen Abstand — egal welcher Kartentyp, egal welcher Kurs/Modul.
   Per :is() auch für gemischte Abfolgen. NUR Block-Container, KEINE
   Grid-Items (deren Abstand regelt der grid-gap). Grids mit eigenem
   margin (impact-/chain-/agent-grid) sind bewusst NICHT aufgeführt. */
:is(.narrative-card, .concept-compare, .statement-box, .humor-box, .why-box, .lehrmoment-box, .trust-card, .quiz-card, .overview-grid, .goal-columns, .cta-section)
  + :is(.narrative-card, .concept-compare, .statement-box, .humor-box, .why-box, .lehrmoment-box, .trust-card, .quiz-card, .overview-grid, .goal-columns, .cta-section) {
  margin-top: 20px;
}
.goal-card, .overview-card, .impact-card, .narrative-card, .statement-box, .humor-box, .cta-section, .finish-block, .lehrmoment-box, .why-box, .trust-card, .concept-card { background: var(--surface-soft); border: 1px solid var(--line); border-radius: 18px; }
.narrative-card, .statement-box, .humor-box, .cta-section, .lehrmoment-box, .why-box { padding: 22px 22px; }
.overview-card, .impact-card, .concept-card { padding: 20px 18px; background: #fff; transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease; }
.overview-card:hover, .impact-card:hover, .concept-card:hover { transform: translateY(-3px); box-shadow: 0 14px 30px rgba(24,38,56,0.08); border-color: color-mix(in srgb, var(--primary) 30%, var(--line)); }
/* ── Premium-Feinschliff: Info-Karten-Grids (overview-/impact-card) ──
   Linksbündig + großzügigere Polster + ruhiger Ruhe-Schatten + gleichmäßige
   Innenabstände via Flex-Gap. (concept-card bleibt bewusst unberührt.) */
.overview-card, .impact-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 24px 22px;
  text-align: left;
  box-shadow: 0 1px 3px rgba(24,38,56,0.04);
}
.overview-card h3, .impact-card h3 { text-align: left; font-size: 1.04rem; margin: 0; line-height: 1.3; }
.overview-card p, .impact-card p { text-align: left; margin: 0; max-width: none; font-size: 0.92em; line-height: 1.55; color: var(--text); }
.overview-card .overview-number, .impact-card .overview-number { margin-bottom: 2px; }
.overview-number { width: 38px; height: 38px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: var(--primary); color: #fff; font-family: var(--font-head); font-weight: 600; margin-bottom: 14px; }
.intro-image { margin: 20px auto 18px auto; max-width: 360px; width: 100%; border-radius: 14px; }
.lead { font-size: 1.08em; font-weight: 500; text-align: center; max-width: 760px; margin: 12px auto 8px auto; color: var(--heading); }
hr { border: 0; height: 1px; background-color: var(--line); margin: 40px auto; max-width: 820px; }
ul.icon-grid { list-style: none; padding-left: 0; margin: 0 auto 1.5em auto; max-width: 900px; display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
ul.icon-grid li { position: relative; background-color: #fff; border-radius: 16px; padding: 16px 16px 16px 48px; border: 1px solid var(--line); box-shadow: 0 4px 14px rgba(0,0,0,0.03); font-size: 0.95em; transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease; }
ul.icon-grid li:hover { transform: translateY(-3px); box-shadow: 0 12px 26px rgba(24,38,56,0.08); border-color: color-mix(in srgb, var(--trust) 30%, var(--line)); }
ul.icon-grid li::before { content: "\2713"; font-family: var(--font-body); font-weight: 700; position: absolute; left: 14px; top: 50%; transform: translateY(-50%); width: 24px; height: 24px; border-radius: 50%; background: var(--trust); color: #ffffff; font-size: 0.85em; display: flex; align-items: center; justify-content: center; }
ul.icon-list, .why-risk-list, .attitude-list { list-style: none; padding-left: 0; margin: 0 auto 1.5em auto; max-width: 800px; }
/* Pfeil-Listen: Pfeil sitzt direkt am Text, Pfeil+Text als Einheit zentriert */
ul.icon-list li, .attitude-list li { text-align: center; margin-bottom: 10px; font-size: 0.98em; list-style: none; }
ul.icon-list li::before, .attitude-list li::before { content: "\2192\00a0"; font-family: var(--font-body); font-weight: 700; color: var(--primary); font-size: 0.95em; }
.why-risk-list li { position: relative; padding-left: 28px; margin-bottom: 10px; font-size: 0.98em; }
.why-risk-list li::before { content: "!"; font-family: inherit; font-weight: 800; color: #fff; background: var(--danger); position: absolute; left: 0; top: 3px; width: 18px; height: 18px; border-radius: 50%; font-size: 0.75em; display: flex; align-items: center; justify-content: center; text-align: center; line-height: 18px; }
blockquote { background: var(--surface-soft); border-left: none; border-top: 3px solid var(--accent); padding: 22px 26px; font-family: var(--font-head); font-style: italic; font-weight: 400; font-size: 1.12em; color: var(--heading); margin: 26px auto; max-width: 800px; border-radius: 14px; text-align: center; }
.insurance-image-wrap { text-align: center; margin: 1.2em 0 1.4em 0; }
.insurance-img { max-width: 360px; width: 100%; height: auto; box-shadow: none; border-radius: 0; margin: 0 auto; }
.key-message { margin: 1.8em auto 1.6em auto; max-width: 100%; width: fit-content; padding: 11px 16px; border-radius: 999px; background: color-mix(in srgb, var(--accent) 6%, #fff); border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--line)); display: flex; flex-direction: column; align-items: center; gap: 4px; justify-content: center; text-align: center; }
@media(min-width: 500px) { .key-message { flex-direction: row; gap: 8px; } }
.key-message__label { font-size: 0.78em; text-transform: uppercase; letter-spacing: 0.1em; color: var(--accent-dark); font-weight: 600; }
.key-message__text { font-weight: 600; color: var(--heading); }
.key-message__button { border: 0; background: transparent; color: var(--heading); font: inherit; font-weight: 600; cursor: pointer; }
.key-message.is-highlighted { box-shadow: 0 0 0 4px color-mix(in srgb, var(--trust) 14%, transparent), 0 14px 28px color-mix(in srgb, var(--trust) 14%, transparent); transform: scale(1.02); }
.concept-card--danger { border-left: 4px solid var(--danger); }
.concept-card--success { border-left: 4px solid var(--trust); }
.concept-tag { display: inline-flex; align-items: center; gap: 6px; font-size: 0.78em; padding: 5px 11px; border-radius: 999px; text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; margin-bottom: 12px; }
.concept-tag--danger { background: #fde4f0; color: #ab0d56; }
.concept-tag--success { background: #e0f7f4; color: var(--trust-dark); }
.quote-line { display: flex; justify-content: center; align-items: flex-start; gap: 10px; max-width: 680px; margin: 0.3em auto 0.6em auto; font-family: var(--font-head); font-style: italic; font-size: 1.12em; line-height: 1.5; color: var(--heading); }
.quote-line i { color: var(--accent); font-size: 1.1em; margin-top: 3px; flex-shrink: 0; }
.danger-line { font-weight: 600; color: #ab0d56; margin-top: 0.8em; margin-bottom: 0.4em; }
.small-line, .roles-intro, .contrast-text, .contrast-intro, .insurance-intro, .insurance-intro--second, .attitude-intro { text-align: center; }
.role-chips { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.role-chip { display: inline-flex; align-items: center; gap: 6px; padding: 7px 13px; border-radius: 999px; background: #fff; color: var(--heading); font-size: 0.88em; font-weight: 500; border: 1px solid var(--line); }
.role-chip i { color: var(--trust); font-size: 0.9em; }
/* Hero-Sprungmarken-Chips (.action-chip) — Premium-Pillen mit Icon */
.hero-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-top: 18px; }
.action-chip { display: inline-flex; align-items: center; gap: 8px; padding: 10px 18px; border-radius: 999px; background: #fff; border: 1px solid color-mix(in srgb, var(--primary) 18%, var(--line)); color: var(--primary-dark); font-family: var(--font-body); font-size: 0.9rem; font-weight: 600; cursor: pointer; transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease; }
.action-chip i { color: var(--primary); font-size: 0.95em; }
.action-chip:hover { transform: translateY(-2px); box-shadow: 0 10px 22px rgba(24,38,56,0.10); border-color: color-mix(in srgb, var(--primary) 38%, var(--line)); background: color-mix(in srgb, var(--primary) 5%, #fff); }
/* AGG-Variante: interaktive Chips */
.role-chip-row { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-bottom: 12px; }
.role-chip--interactive { cursor: pointer; transition: transform 0.2s ease, box-shadow 0.2s ease; }
.role-chip--interactive:hover, .role-chip--interactive.is-active { transform: translateY(-1px); box-shadow: 0 10px 18px rgba(24,49,79,0.08); }
.chip-feedback { min-height: 24px; color: var(--muted); font-size: 0.92em; margin-bottom: 20px; font-weight: 500; text-align: center; }
/* Akkordeon Goal-Cards (AGG-Stil) */
.goal-card { overflow: hidden; }
.goal-card__toggle { width: 100%; border: 0; background: transparent; text-align: left; padding: 18px 16px; cursor: pointer; font: inherit; display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.goal-tag { font-family: var(--font-head); font-weight: 600; color: var(--heading); }
.goal-card__icon { width: 36px; height: 36px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--primary) 10%, #fff); color: var(--primary-dark); flex-shrink: 0; }
.goal-card__content { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.3s ease; }
.goal-card__content > * { overflow: hidden; }
.goal-card.is-open .goal-card__content { grid-template-rows: 1fr; }
/* ── Boxen nicht ausklappbar: Inhalt immer sichtbar, Toggle entfernt ── */
.goal-card__content { grid-template-rows: 1fr !important; }
.goal-card__toggle { cursor: default; }
.goal-card__icon { display: none !important; }
#toggleAllGoals { display: none !important; }
.goal-card ul { list-style: none; display: grid; gap: 10px; padding: 0 16px 18px; }
.goal-card li { position: relative; padding-left: 24px; }
.goal-card li::before { content: "•"; position: absolute; left: 8px; top: 0; color: var(--primary); font-weight: 800; }
/* ── Premium-Aufwertung: dauerhaft offene Info-Cards (.goal-card.interactive-card).
   Nur Arbeitsschutz/Notfall (immer offen) — AGG-Akkordeon bleibt unberührt. ── */
.goal-card.interactive-card {
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-soft) 100%);
  border-color: color-mix(in srgb, var(--primary) 12%, var(--line));
  box-shadow: 0 10px 30px rgba(24,38,56,0.07);
}
.goal-card.interactive-card .goal-card__toggle {
  justify-content: center;
  gap: 12px;
  padding: 20px 22px 14px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
}
.goal-card.interactive-card .goal-tag {
  font-size: 1.08rem;
  color: var(--heading);
  letter-spacing: -0.01em;
}
.goal-card.interactive-card .goal-card__content { padding-top: 16px; }
/* Navy-Kreis-Badge statt Keycap-Emoji / Text-Nummer im Kartentitel */
.goal-num {
  flex-shrink: 0;
  width: 30px; height: 30px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--primary); color: #fff;
  font-family: var(--font-head); font-weight: 600; font-size: 0.95rem; line-height: 1;
}
/* Badge auch in concept-card-Titeln (zentriert, an Textgröße angepasst) */
.concept-card h3 .goal-num { vertical-align: middle; margin-right: 14px; width: 28px; height: 28px; font-size: 0.9rem; box-shadow: 0 4px 10px color-mix(in srgb, var(--primary) 30%, transparent); }
/* ── Gleiche Premium-Anmutung für overview-/impact-Cards (Verlauf, getönter Rand, weicher Schatten) ── */
.overview-card, .impact-card {
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-soft) 100%);
  border-color: color-mix(in srgb, var(--primary) 12%, var(--line));
  box-shadow: 0 10px 30px rgba(24,38,56,0.07);
}
/* Statement Box */
.statement-box { background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, #fff), #fff); border-color: color-mix(in srgb, var(--accent) 22%, var(--line)); }
.statement-label { font-size: 0.8em; text-transform: uppercase; letter-spacing: 0.12em; color: var(--accent-dark); margin-bottom: 10px; font-weight: 600; }
.statement-box.is-echoing { box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent), 0 18px 34px color-mix(in srgb, var(--accent) 14%, transparent); }
/* Humor Box */
.humor-label { font-weight: 600; color: var(--accent-dark); margin-bottom: 8px; }
.reveal-panel { margin-top: 14px; padding: 14px; border-radius: 14px; background: rgba(255,255,255,0.75); border: 1px solid var(--line); }
/* Selfcheck */
.selfcheck-section { background: var(--surface-soft); border: 1px solid var(--line); border-radius: var(--radius); padding: 26px 22px; margin-bottom: 42px; }
.selfcheck-caption { display: inline-flex; align-items: center; gap: 8px; padding: 8px 13px; border-radius: 999px; background: color-mix(in srgb, var(--primary) 8%, #fff); border: 1px solid color-mix(in srgb, var(--primary) 18%, transparent); color: var(--primary-dark); font-size: 0.76rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; }
.quiz-card { padding: 24px; border-radius: 18px; background: #fff; border: 1px solid var(--line); box-shadow: 0 12px 28px rgba(24,38,56,0.06); }
.quiz-question { font-family: var(--font-head); font-weight: 700; color: var(--heading); margin-bottom: 18px; font-size: 1.12rem; }
.quiz-options { display: grid; gap: 12px; }
.quiz-option { position: relative; text-align: left; border: 1px solid var(--line); background: #fff; color: var(--text); cursor: pointer; font: inherit; font-weight: 500; padding: 16px 18px 16px 52px; border-radius: 14px; transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease; }
.quiz-option::before { content: ""; position: absolute; left: 16px; top: 50%; transform: translateY(-50%); width: 22px; height: 22px; border-radius: 50%; border: 2px solid #c8d3e2; background: #f3f5f9; transition: all 0.2s ease; }
.quiz-option:hover { transform: translateY(-2px); box-shadow: 0 12px 22px rgba(24,38,56,0.09); border-color: color-mix(in srgb, var(--primary) 30%, var(--line)); }
.quiz-option.is-selected { border-color: color-mix(in srgb, var(--primary) 45%, var(--line)); box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 10%, transparent); }
.quiz-option.is-selected::before { border-color: var(--primary); background: var(--primary); box-shadow: inset 0 0 0 5px #fff; }
.quiz-option.is-correct { border-color: color-mix(in srgb, var(--trust) 45%, #fff); background: #eafbf8; color: var(--trust-dark); }
.quiz-option.is-correct::before { border-color: var(--trust); background: var(--trust); box-shadow: inset 0 0 0 4px #eafbf8; }
.quiz-option.is-wrong { border-color: #f5c6dd; background: #fdeef5; color: #ab0d56; }
.quiz-option.is-wrong::before { border-color: #e11d74; background: #e11d74; box-shadow: inset 0 0 0 4px #fdeef5; }
.quiz-feedback { margin-top: 18px; min-height: 24px; font-weight: 600; color: var(--heading); padding: 13px 15px; border-radius: 12px; background: color-mix(in srgb, var(--trust) 6%, #fff); border: 1px solid color-mix(in srgb, var(--trust) 16%, transparent); }
.quiz-feedback.is-correct { color: var(--trust-dark); background: #eafbf8; border-color: #a8e6df; }
.quiz-feedback.is-wrong { color: #ab0d56; background: #fdeef5; border-color: #f5c6dd; }
.attitude-grid { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr); gap: 22px; margin-top: 0.8em; }
.attitude-left p, .attitude-right, .concept-card h3, .concept-card p, .finish-block h3, .finish-block p { text-align: center; }
.trust-card { position: relative; padding: 18px 20px 18px 58px; background: linear-gradient(135deg, #effbf9, #e0f7f4); border-color: color-mix(in srgb, var(--trust) 20%, var(--line)); }
.trust-icon { position: absolute; left: 18px; top: 50%; transform: translateY(-50%); width: 30px; height: 30px; border-radius: 50%; background: #ffffff; display: flex; align-items: center; justify-content: center; color: var(--trust); box-shadow: 0 2px 6px rgba(0,0,0,0.08); }
.trust-quote { margin: 0; font-weight: 500; color: var(--heading); }
.attitude-divider-line { margin: 1.8em auto 0 auto; display: flex; align-items: center; gap: 12px; font-weight: 500; color: var(--heading); font-size: 1.05em; justify-content: center; flex-wrap: wrap; text-align: center; }
.attitude-divider-line i { color: var(--trust); }
.attitude-divider-line::before, .attitude-divider-line::after { content: ""; flex: 1; max-width: 140px; height: 1px; background: var(--line); display: none; }
@media(min-width: 600px) { .attitude-divider-line::before, .attitude-divider-line::after { display: block; } }
.cta-section { text-align: center; background: linear-gradient(135deg, color-mix(in srgb, var(--trust) 7%, #fff), var(--surface-soft)); border-color: color-mix(in srgb, var(--trust) 18%, var(--line)); padding: 30px 24px; }
.cta-label { font-size: 0.8em; text-transform: uppercase; letter-spacing: 0.12em; color: var(--trust-dark); font-weight: 600; margin-bottom: 10px; text-align: center; }
.cta-title { font-family: var(--font-head); font-size: clamp(1.2rem, 1.6vw, 1.4rem); color: var(--heading); font-weight: 700; margin-bottom: 12px; text-align: center; }
.cta-text { max-width: 720px; margin: 0 auto; text-align: center; }
.finish-block { max-width: 600px; margin: 20px auto 0; padding: 18px 20px; background: #fff; border: 1px solid color-mix(in srgb, var(--trust) 20%, var(--line)); }
.finish-block h3 { font-family: var(--font-head); font-weight: 600; }
.finish-block h3 i { color: var(--trust); }
/* ── Modul 2: Agent-Grid (Erreger-Karten) ── */
.agent-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; margin-top: 16px; }
.agent-card { background: var(--surface-soft); border: 1px solid var(--line); border-radius: 18px; padding: 20px 18px; overflow: hidden; }
.agent-badge { display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; border-radius: 999px; font-size: 0.8em; font-weight: 600; margin-bottom: 12px; }
.agent-badge--bacteria  { background: #e3f7ee; color: #1a6640; }
.agent-badge--virus     { background: #ffeaea; color: #a63232; }
.agent-badge--fungi     { background: #fff8e1; color: #8a6200; }
.agent-badge--parasites { background: #f0eaff; color: #5a3fa0; }
.agent-card h3 { font-size: 1.05rem; color: var(--heading); margin-bottom: 8px; text-align: left !important; }
.agent-card p  { font-size: 0.93em; margin-bottom: 0.7em; }
.agent-quote   { font-style: italic; color: var(--muted); font-size: 0.88em !important; border-left: 3px solid var(--line); padding-left: 10px; margin-top: 8px; }
.mini-image-wrap { text-align: center; margin: 10px 0 12px; }
.mini-img { max-width: 100px; width: 100%; height: auto; display: block; margin: 0 auto; border-radius: 8px; }
.small-img { max-width: 260px; width: 100%; height: auto; display: block; margin: 0 auto; border-radius: 10px; }

/* ── Modul 2: Infektionskette (chain-grid) ── */
.chain-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; margin-top: 20px; }
.chain-step { background: var(--surface-soft); border: 1px solid var(--line); border-radius: 16px; padding: 18px 16px; }
.chain-step-header { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.chain-step-header h3 { font-size: 1.05rem; color: var(--heading); margin: 0; text-align: left !important; }
.chain-number { width: 32px; height: 32px; border-radius: 50%; background: var(--primary); color: #fff; font-family: var(--font-head); font-weight: 600; font-size: 0.9em; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.chain-step ul { list-style: none; padding: 0; margin: 8px 0; }
.chain-step ul li { position: relative; padding-left: 14px; margin-bottom: 5px; font-size: 0.92em; }
.chain-step ul li::before { content: "›"; position: absolute; left: 0; color: var(--primary); font-weight: 700; }
.chain-quote { font-style: italic; color: var(--muted); font-size: 0.88em; border-left: 3px solid var(--line); padding-left: 10px; margin-top: 8px; }
.chain-highlight { font-weight: 600; color: var(--heading); }
.chain-intro { text-align: center; max-width: 760px; margin: 0 auto 10px; }
.key-message--chain { margin-top: 24px; }
.praxis-case-intro { font-size: 1em; font-weight: 500; color: var(--heading); text-align: center; }
.praxis-key { font-weight: 600; color: var(--primary-dark); }

.cta-back-btn { display: inline-flex; align-items: center; gap: 8px; margin-top: 20px; padding: 13px 30px; border-radius: 999px; background: var(--primary); color: #fff; font-family: var(--font-body); font-size: 0.92rem; font-weight: 600; text-decoration: none; box-shadow: 0 10px 26px color-mix(in srgb, var(--primary) 28%, transparent); transition: all 0.2s; }
.cta-back-btn:hover { background: var(--primary-dark); transform: translateY(-3px); }

/* ── Concept-Cards: Premium-Anmutung + lesbare Listen ───────────────
   Verlauf + weicher Schatten (wie overview/impact); farbiger Rand bleibt.
   Und: icon-list-<li> als Block erzwingen, damit ein vom Webapp-Rahmen
   geerbtes display:flex die <li> mit <strong> nicht in Spalten zerreißt. */
.concept-card {
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-soft) 100%);
  box-shadow: 0 10px 30px rgba(24,38,56,0.07);
}
ul.icon-list li, .attitude-list li { display: block !important; }
/* ── Geordnete Listen (ol): Navy-Zähler-Badge + linksbündiger Text.
   Ersetzt die mittig gesetzten „1./2."-Marker, die Ziffer & Text auseinander-
   rissen (v. a. mobil). !important überstimmt vereinzelte Inline-Stile am <ol>. ── */
ol { list-style: none !important; counter-reset: olc; padding-left: 0 !important; text-align: left; }
ol li { counter-increment: olc; position: relative; display: block !important; text-align: left !important; padding-left: 42px; margin-bottom: 12px; min-height: 28px; }
ol li::before { content: counter(olc); position: absolute; left: 0; top: 0; width: 28px; height: 28px; border-radius: 50%; background: var(--primary); color: #fff; font-family: var(--font-head); font-weight: 600; font-size: 0.85rem; display: inline-flex; align-items: center; justify-content: center; }
/* ── Nummern-Badges premium (goal-num, overview-number, chain-number, ol-Zähler;
   alle Kurse): dezenter Navy-Verlauf + weicher Schatten statt flacher Fläche. ── */
.goal-num, .overview-number, .chain-number, ol li::before {
  background: linear-gradient(160deg, color-mix(in srgb, var(--primary) 82%, #ffffff), var(--primary) 48%, var(--primary-dark));
  box-shadow: 0 4px 10px color-mix(in srgb, var(--primary) 32%, transparent);
}
h2 .goal-num, h3 .goal-num { vertical-align: middle; margin-right: 14px; }
/* ── Premium-Angleichung restlicher Boxen & Zitate (global) ──
   narrative-/humor-/lehrmoment-/why-Box waren noch flach (surface-soft, kein
   Schatten). Jetzt Verlauf + weicher Schatten wie die Karten. statement-/trust-
   card behalten ihren eigenen Akzent-Verlauf (bewusst nicht aufgeführt). ── */
.narrative-card, .humor-box, .lehrmoment-box, .why-box {
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-soft) 100%);
  border-color: color-mix(in srgb, var(--primary) 12%, var(--line));
  box-shadow: 0 10px 30px rgba(24,38,56,0.07);
}
blockquote {
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-soft) 100%);
  box-shadow: 0 10px 30px rgba(24,38,56,0.06);
}
.cta-section { box-shadow: 0 10px 30px rgba(24,38,56,0.07); }
.finish-block { box-shadow: 0 6px 18px rgba(24,38,56,0.06); }
/* ── Mehrfachen Modul-Titel entschlacken (global) ──
   Die farbige Kopfzeile (page-header) trägt bereits Kurs + Modultitel. Im
   Content-Hero waren Eyebrow-Pille UND Überschrift wortgleiche Wiederholungen
   → ausgeblendet; nur der Lead-Untertitel bleibt (schlanke Intro-Zeile).
   (Router serviert nur lang-Module — die haben alle die page-header-Kopfzeile.) ── */
.hero-panel .hero-eyebrow, .hero-panel .hero-title { display: none; }
.hero-panel { padding: 22px 26px; }
.hero-panel .lead { margin: 0 auto; }
/* ── „Lernziele"-Pill über dem Intro-Bild (premium, themt pro Kurs) ── */
.intro-pill {
  display: inline-flex; align-items: center; gap: 8px;
  margin: 0 0 2px 0; padding: 7px 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 14%, #fff), color-mix(in srgb, var(--accent) 12%, #fff));
  border: 1px solid color-mix(in srgb, var(--primary) 20%, var(--line));
  color: var(--primary-dark);
  font-weight: 700; font-size: 0.8rem;
  text-transform: uppercase; letter-spacing: 0.08em;
  box-shadow: 0 4px 12px color-mix(in srgb, var(--primary) 14%, transparent);
}
.intro-pill i { font-size: 0.9em; color: var(--primary); }
