/* ============================================================
   MEISTERJÄGER AKADEMIE — Startseite (Design-Prototyp)
   Vorlage für die spätere Drupal-Umsetzung.

   Aufbau dieser Datei:
   1. Design-Tokens (CSS-Variablen)  -> Farben, Typo, Abstände
   2. Reset & Basis
   3. Typografie & Utilities
   4. Buttons
   5. Header / Navigation
   6. Sektionen (Hero, Stats, Intro, Kurse, Vorteile,
      Ablauf, Dozenten, Stimmen, Waidwissen, FAQ, CTA, Footer)
   7. Animationen & Reduced-Motion
   8. Responsive Breakpoints

   Farb-/Typo-Tokens unten 1:1 in Drupal-Theme übernehmbar.
   ============================================================ */

/* 1. DESIGN-TOKENS ------------------------------------------------ */
:root {
  /* Markenfarben – aus dem Original-Logo abgeleitet (#29320F = exaktes Olivgrün) */
  --forest-900: #11160A;
  --forest-800: #1C2309;
  --forest-700: #29320F;   /* Primär – Logo-Olivgrün (Marke) */
  --forest-600: #36410F;
  --moss-500:   #54652A;
  --moss-400:   #6E8038;

  /* Dunkle Bänder (neutral) */
  --navy-700:   #242833;
  --navy-900:   #121212;

  /* Marken-Akzent = #938B44 (Buttons filled/outlined, Eyebrows, Häkchen) */
  --brass-600:  #6F6833;   /* dunklere Variante (Text auf Hell / Hover) */
  --brass-500:  #938B44;   /* Hauptakzent (Button-Füllung) */
  --brass-400:  #A89F55;   /* hellere Variante (auf dunklen Bändern) */
  --brass-200:  #E8E6D2;   /* blasser Ton (Badge-BG) */

  --cream-50:   #FDFDFB;   /* Haupt-Hintergrund (leicht warmes Off-White) */
  --cream-100:  #F3F3F3;   /* alternierende Sektionen: Hellgrau (Live-Seite) */
  --cream-200:  #E8E8E8;
  --stone-300:  #E2E2E2;   /* neutrale Hairline-Rahmen */

  --ink-900:    #16181C;   /* Haupttext (neutrales Schwarz) */
  --ink-700:    #3B3E45;
  --ink-500:    #6C6F77;   /* gedämpfter Text */
  --ink-300:    #A2A5AD;

  /* Semantische Tokens */
  --color-bg:           var(--cream-50);
  --color-surface:      #FFFFFF;
  --color-fg:           var(--ink-900);
  --color-fg-muted:     var(--ink-500);
  --color-primary:      var(--forest-700);
  --color-primary-fg:   #FFFFFF;
  --color-accent:       var(--brass-500);
  --color-border:       var(--stone-300);

  /* Typografie – von der Original-Seite übernommen: Farro (Headlines) + DM Sans (Text) */
  --font-display: "Farro", "DM Sans", system-ui, sans-serif;
  --font-body:    "DM Sans", -apple-system, "Segoe UI", sans-serif;

  --text-xs:   0.72rem;
  --text-sm:   0.84rem;
  --text-base: 0.97rem;
  --text-lg:   1.08rem;
  --text-xl:   1.3rem;
  --text-2xl:  1.7rem;
  --text-3xl:  clamp(1.85rem, 3vw, 2.5rem);
  --text-4xl:  clamp(2.2rem, 4.6vw, 3.9rem);

  /* Abstände (8pt-Raster) */
  --space-1: 0.5rem;  --space-2: 1rem;   --space-3: 1.5rem;
  --space-4: 2rem;    --space-5: 3rem;   --space-6: 4rem;
  --space-7: 6rem;    --space-8: 8rem;

  /* Scharfkantig wie die Live-Seite — alle Radien 0 */
  --radius-sm: 0;
  --radius:    0;
  --radius-lg: 0;
  --radius-pill: 0;

  --container: 1240px;

  --shadow-sm: 0 1px 2px rgba(20,22,16,.04);
  --shadow:    0 6px 20px -10px rgba(20,22,16,.16);
  --shadow-lg: 0 22px 50px -28px rgba(20,22,16,.26);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* 2. RESET & BASIS ------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

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

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-fg);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
[hidden] { display: none !important; }   /* überschreibt display von .btn/.rt-reset */

/* 3. TYPOGRAFIE & UTILITIES -------------------------------------- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 1.08;
  letter-spacing: -0.022em;
  color: var(--color-fg);
}

.display { font-size: var(--text-4xl); font-weight: 700; line-height: 1.0; letter-spacing: -0.035em; }
.h2 { font-size: var(--text-3xl); letter-spacing: -0.03em; }
.h3 { font-size: var(--text-2xl); letter-spacing: -0.025em; }

.eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--brass-600);
  display: inline-flex;
  align-items: center;
  gap: .6rem;
}
.eyebrow::before {
  content: "";
  width: 26px; height: 1px;
  background: var(--brass-500);
  display: inline-block;
}
/* Mikrotypografie: Kapitel-Index in der Eyebrow (tabellarische Ziffern) */
.eyebrow .idx { font-variant-numeric: tabular-nums; font-weight: 700; color: var(--ink-300); letter-spacing: .1em; margin-right: -.2rem; }

.lead { font-size: var(--text-lg); color: var(--color-fg-muted); max-width: 60ch; }
.muted { color: var(--color-fg-muted); }
.accent { color: var(--brass-600); }
.serif-italic { color: var(--brass-600); } /* Akzentwort (Farro kennt kein Kursiv) */

.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--space-3);
}

.section { padding-block: clamp(3.5rem, 7vw, 7rem); }
.section-head { max-width: 56ch; margin-bottom: var(--space-5); }
.section-head .h2 { margin-top: var(--space-2); }
.center { text-align: center; margin-inline: auto; }

/* 4. BUTTONS ------------------------------------------------------ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  padding: .9rem 1.7rem;
  border-radius: var(--radius-pill);   /* = 0, scharfkantig */
  border: 1px solid transparent;
  font-weight: 600;
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  transition: transform .2s var(--ease), background .25s var(--ease),
              box-shadow .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
.btn svg { width: 16px; height: 16px; }
.btn:active { transform: translateY(1px); }

/* Nur zwei Varianten: FILLED (#938B44) und OUTLINED (#938B44) */
.btn-primary, .btn-accent { background: var(--brass-500); color: #fff; border-color: var(--brass-500); }
.btn-primary:hover, .btn-accent:hover { background: var(--brass-600); border-color: var(--brass-600); transform: translateY(-2px); }

.btn-outline, .btn-ghost { background: transparent; border-color: var(--brass-500); color: var(--brass-600); }
.btn-outline:hover, .btn-ghost:hover { background: var(--brass-500); border-color: var(--brass-500); color: #fff; transform: translateY(-2px); }

/* Outline auf dunklen Bändern (weiß) */
.btn-light { background: transparent; color: #fff; border-color: rgba(255,255,255,.55); }
.btn-light:hover { background: #fff; color: var(--ink-900); border-color: #fff; }

.link-arrow { display: inline-flex; align-items: center; gap: .45rem; font-weight: 600; color: var(--forest-700); }
.link-arrow svg { width: 16px; height: 16px; transition: transform .2s var(--ease); }
.link-arrow:hover { color: var(--brass-600); }
.link-arrow:hover svg { transform: translateX(4px); }

/* 5. HEADER / NAVIGATION ----------------------------------------- */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 1000;
  transition: background .35s var(--ease), box-shadow .35s var(--ease), padding .35s var(--ease);
  padding-block: .55rem;          /* schmale Navbar */
}
.site-header.scrolled {
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(20px) saturate(180%);
  box-shadow: 0 1px 0 rgba(20,22,16,.07);
  padding-block: .55rem;
}
.nav { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }

/* Logo: weiße Version über dem Hero, grüne Version nach dem Scrollen */
.brand { display: flex; align-items: center; }
.brand img { height: 38px; width: auto; display: block; transition: height .35s var(--ease); }

.brand .logo-light { display: block; }
.brand .logo-dark  { display: none; }
.site-header.scrolled .brand .logo-light { display: none; }
.site-header.scrolled .brand .logo-dark  { display: block; }
.site-header:not(.scrolled) .nav-links a { color: var(--cream-50); }

.nav-links { display: flex; align-items: center; gap: var(--space-3); list-style: none; }
.nav-links a { font-size: var(--text-sm); font-weight: 500; position: relative; padding-block: .3rem; transition: color .2s; }
.nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: 1.5px;
  background: var(--brass-500); transition: width .25s var(--ease);
}
.nav-links a:hover::after { width: 100%; }
.nav-actions { display: flex; align-items: center; gap: var(--space-2); }

.nav-toggle { display: none; background: none; border: 0; color: inherit; padding: .4rem; }
.nav-toggle svg { width: 28px; height: 28px; }

/* 6. SEKTIONEN ---------------------------------------------------- */

/* --- HERO --- */
.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: center;            /* Inhalt vertikal mittig (höher als zuvor) */
  text-align: center;             /* zentrierter Hero-Content */
  padding: calc(var(--space-7) + 40px) 0 var(--space-6);
  color: var(--cream-50);
  overflow: hidden;
}
.hero-bg { position: absolute; inset: 0; z-index: -2; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 38%; }
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(to top, rgba(17,22,10,.94) 0%, rgba(17,22,10,.5) 42%, rgba(17,22,10,.32) 66%, rgba(17,22,10,.66) 100%);
}
.hero-inner { max-width: 60ch; margin-inline: auto; }
/* zentrierte Eyebrow mit Strich auf beiden Seiten */
.hero .eyebrow { color: rgba(255,255,255,.82); }
.hero .eyebrow::before, .hero .eyebrow::after { content: ""; width: 30px; height: 1px; background: rgba(255,255,255,.55); display: inline-block; }
.hero h1 { margin: var(--space-2) 0 var(--space-3); color: #fff; }
.hero h1 em { font-style: normal; color: #fff; }
.hero p { font-size: var(--text-lg); color: rgba(255,255,255,.88); max-width: 52ch; margin-inline: auto; font-weight: 400; }
.hero-cta { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-4); }

.scroll-cue {
  position: absolute; left: 50%; bottom: var(--space-3); transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  font-size: var(--text-xs); letter-spacing: .2em; text-transform: uppercase; opacity: .8;
}
.scroll-cue span { width: 1px; height: 38px; background: linear-gradient(var(--brass-400), transparent); animation: cue 2s var(--ease) infinite; }

/* --- MANIFEST (weiß, 2 Spalten: Text links / Bild rechts) --- */
.manifest { background: var(--color-surface); }
.manifest-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: var(--space-6); align-items: center; }
.manifest-text .statement {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(1.6rem, 2.7vw, 2.45rem); line-height: 1.22; letter-spacing: -.015em;
  color: var(--ink-900); margin: var(--space-2) 0 var(--space-3); text-wrap: balance;
}
.manifest-text .statement b { font-weight: 600; color: inherit; }
.manifest-text .lead { max-width: 42ch; }
.manifest-text .sign { margin-top: var(--space-4); font-size: var(--text-xs); letter-spacing: .26em; text-transform: uppercase; color: var(--ink-300); display: flex; align-items: center; gap: .7rem; }
.manifest-text .sign::before { content: ""; width: 32px; height: 1px; background: var(--brass-500); }
.manifest-media { margin: 0; position: relative; }
.manifest-media img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.manifest-media figcaption {
  position: absolute; left: var(--space-2); bottom: var(--space-2);
  display: inline-flex; align-items: center; gap: .55rem;
  background: rgba(245,242,234,.92); backdrop-filter: blur(6px);
  padding: .5rem .85rem; border-radius: var(--radius-pill);
  font-size: var(--text-xs); color: var(--ink-700); letter-spacing: .02em;
}
.manifest-media figcaption .idx { font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--brass-600); }
@media (max-width: 900px) {
  .manifest-grid { grid-template-columns: 1fr; gap: var(--space-4); }
  .manifest-media img { aspect-ratio: 16 / 10; }
}

/* --- WILDTIER-/REVIER-GALERIE --- */
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-2); }
.gallery-grid figure { position: relative; overflow: hidden; border-radius: var(--radius); aspect-ratio: 4 / 3; margin: 0; }
.gallery-grid img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--ease); }
.gallery-grid figure:hover img { transform: scale(1.07); }
.gallery-grid figcaption {
  position: absolute; inset: auto 0 0 0; padding: var(--space-3) var(--space-2) var(--space-2);
  color: var(--cream-50); font-size: var(--text-sm); font-weight: 600; letter-spacing: .02em;
  background: linear-gradient(transparent, rgba(17,22,10,.8));
  display: flex; align-items: center; gap: .5rem;
}
.gallery-grid figcaption::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--brass-400); }
.gallery-grid figure:first-child { grid-column: span 2; grid-row: span 2; }
@media (max-width: 760px) {
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .gallery-grid figure:first-child { grid-column: span 2; grid-row: auto; }
}

/* --- STATS-STREIFEN --- */
.stats {
  background: var(--forest-800);
  color: var(--cream-50);
}
.stats .container { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); padding-block: var(--space-5); }
.stat { text-align: center; }
.stat .num { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem); color: var(--brass-400); line-height: 1; }
.stat .label { font-size: var(--text-sm); color: rgba(246,241,230,.75); margin-top: .5rem; }
.stat + .stat { border-left: 1px solid rgba(246,241,230,.12); }

/* --- INTRO / SPLIT --- */
.split { display: grid; grid-template-columns: 1.05fr .95fr; gap: var(--space-6); align-items: center; }
/* Vertikaler Rhythmus im Textblock: Eyebrow nah an der Headline, klare Luft zum Fließtext */
.split .eyebrow { margin-bottom: var(--space-2); }
.split .h2 { margin-bottom: var(--space-3); }
.split .lead + * { margin-top: var(--space-3); }
.split-media { position: relative; }
.split-media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); aspect-ratio: 3/4; object-fit: cover; width: 100%; }
.split-media .badge {
  position: absolute; bottom: -22px; left: -22px;
  background: var(--cream-50); border: 1px solid var(--color-border);
  border-radius: var(--radius); padding: var(--space-2) var(--space-3);
  box-shadow: var(--shadow); display: flex; gap: .9rem; align-items: center;
}
.split-media .badge .seal { width: 46px; height: 46px; color: var(--brass-600); flex: none; }
.split-media .badge b { font-family: var(--font-display); font-size: 1.4rem; display: block; line-height: 1; }
.split-media .badge small { font-size: var(--text-xs); color: var(--color-fg-muted); }
.intro-points { list-style: none; padding: 0; margin-top: var(--space-3); display: grid; gap: var(--space-2); }
.intro-points li { display: flex; gap: .8rem; align-items: flex-start; }
.intro-points svg { width: 22px; height: 22px; color: var(--forest-700); flex: none; margin-top: 2px; }

/* --- KURSE --- */
.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.course-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  display: flex; flex-direction: column;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  position: relative; overflow: hidden;
}
.course-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--brass-400); }
/* Bild-Kopf der Kurskarte */
.course-media { margin: calc(var(--space-4) * -1) calc(var(--space-4) * -1) var(--space-3); aspect-ratio: 16 / 9; overflow: hidden; position: relative; }
.course-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.course-card:hover .course-media img { transform: scale(1.05); }
.course-media .course-tag { position: absolute; top: var(--space-2); left: var(--space-2); margin: 0; }
/* hervorgehobene Karte: weiß wie die anderen, nur mit Messing-Rahmen markiert */
.course-card.featured { border-color: var(--brass-500); border-width: 2px; box-shadow: var(--shadow); }
.course-tag {
  align-self: flex-start; font-size: var(--text-xs); font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  padding: .35rem .8rem; border-radius: var(--radius-pill); background: var(--brass-500); color: var(--forest-900); margin-bottom: var(--space-2);
}
.course-card h3 { font-size: var(--text-xl); }
.course-price { font-family: var(--font-display); font-size: 2.4rem; margin: var(--space-2) 0; line-height: 1; }
.course-price small { font-family: var(--font-body); font-size: var(--text-sm); font-weight: 400; }
.course-feats { list-style: none; padding: 0; margin: var(--space-2) 0 var(--space-4); display: grid; gap: .7rem; }
.course-feats li { display: flex; gap: .6rem; align-items: flex-start; font-size: var(--text-sm); }
.course-feats svg { width: 18px; height: 18px; color: var(--forest-600); flex: none; margin-top: 3px; }
.course-card .btn { margin-top: auto; justify-content: center; }

/* --- VORTEILE / FEATURE-GRID --- */
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4) var(--space-5); }
.feature .ficon {
  width: 54px; height: 54px; border-radius: var(--radius); display: grid; place-items: center;
  background: var(--cream-100); border: 1px solid var(--color-border); color: var(--forest-700); margin-bottom: var(--space-2);
}
.feature .ficon svg { width: 26px; height: 26px; }
.feature h3 { font-size: var(--text-lg); margin-bottom: .4rem; }
.feature p { font-size: var(--text-sm); color: var(--color-fg-muted); }

/* --- ABLAUF / STEPS --- */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); counter-reset: step; }
.step { counter-increment: step; }
.step-media { position: relative; aspect-ratio: 4 / 3; border-radius: var(--radius); overflow: hidden; margin-bottom: var(--space-2); }
.step-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.step:hover .step-media img { transform: scale(1.05); }
.step-media::after {
  content: counter(step, decimal-leading-zero);
  position: absolute; left: 12px; bottom: 12px;
  font-family: var(--font-display); font-size: 1.15rem; color: var(--cream-50);
  width: 42px; height: 42px; display: grid; place-items: center;
  background: var(--forest-700); border: 2px solid var(--brass-400); border-radius: 0;
}
.step h3 { font-size: var(--text-lg); }
.step p { font-size: var(--text-sm); color: var(--color-fg-muted); }

/* --- DOZENTEN --- */
.team { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.coach {
  background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  padding: var(--space-3); display: flex; gap: var(--space-2); align-items: center;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease);
}
.coach:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.coach .avatar {
  width: 64px; height: 64px; border-radius: 0; flex: none; display: grid; place-items: center;
  font-family: var(--font-display); font-size: 1.5rem; color: var(--cream-50);
  background: linear-gradient(145deg, var(--forest-600), var(--forest-800));
  border: 2px solid var(--brass-400);
}
.coach h3 { font-size: var(--text-lg); }
.coach .role { font-size: var(--text-xs); letter-spacing: .04em; color: var(--brass-600); text-transform: uppercase; font-weight: 600; }
.coach .spec { font-size: var(--text-sm); color: var(--color-fg-muted); margin-top: .2rem; }

/* --- STIMMEN / TESTIMONIALS --- */
.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.quote {
  background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  padding: var(--space-4); position: relative;
}
.quote .stars { color: var(--brass-500); display: flex; gap: 3px; margin-bottom: var(--space-2); }
.quote .stars svg { width: 18px; height: 18px; }
.quote blockquote { font-size: 1.18rem; font-style: italic; line-height: 1.5; color: var(--ink-700); } /* DM Sans hat echtes Kursiv */
.quote .by { display: flex; align-items: center; gap: .8rem; margin-top: var(--space-3); }
.quote .by .avatar { width: 42px; height: 42px; border-radius: 0; background: var(--cream-200); display: grid; place-items: center; font-family: var(--font-display); color: var(--forest-700); }
.quote .by b { display: block; font-family: var(--font-body); font-weight: 600; font-size: var(--text-sm); }
.quote .by small { color: var(--color-fg-muted); font-size: var(--text-xs); }

/* --- WAIDWISSEN / E-LEARNING --- */
.waid {
  position: relative; border-radius: var(--radius-lg); overflow: hidden;
  color: var(--cream-50); padding: var(--space-7) var(--space-5);
}
.waid-bg { position: absolute; inset: 0; z-index: -2; }
.waid-bg img { width: 100%; height: 100%; object-fit: cover; }
.waid::after { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(105deg, rgba(17,22,10,.95) 30%, rgba(17,22,10,.55) 100%); }
.waid-inner { max-width: 52ch; }
.waid .eyebrow { color: var(--brass-400); }
.waid .eyebrow::before { background: var(--brass-400); }
.waid h2 { color: #fff; margin: var(--space-2) 0 var(--space-2); }
.waid p { color: rgba(246,241,230,.85); margin-bottom: var(--space-3); }

/* --- FAQ --- */
.faq { max-width: 800px; margin-inline: auto; }
.faq details {
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-3) 0;
}
.faq summary {
  display: flex; justify-content: space-between; align-items: center; gap: var(--space-2);
  font-family: var(--font-display); font-size: var(--text-lg); cursor: pointer; list-style: none;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary .pm { width: 26px; height: 26px; flex: none; position: relative; transition: transform .3s var(--ease); }
.faq summary .pm::before, .faq summary .pm::after { content:""; position:absolute; background: var(--brass-600); inset: 50% 0 auto 0; height: 2px; transform: translateY(-50%); }
.faq summary .pm::after { transform: translateY(-50%) rotate(90deg); transition: opacity .3s; }
.faq details[open] summary .pm::after { opacity: 0; }
.faq details[open] summary .pm { transform: rotate(180deg); }
.faq details p { color: var(--color-fg-muted); margin-top: var(--space-2); max-width: 70ch; }

/* --- CTA-BAND --- */
.cta-band { background: var(--navy-700); color: #fff; border-radius: var(--radius-lg); padding: var(--space-6) var(--space-5); text-align: center; position: relative; overflow: hidden; }
.cta-band > * { position: relative; }
.cta-band h2 { color: #fff; max-width: 22ch; margin-inline: auto; }
.cta-band p { color: rgba(255,255,255,.82); max-width: 50ch; margin: var(--space-2) auto var(--space-4); }
.cta-band .eyebrow { color: var(--brass-400); }
.cta-band .eyebrow::before { background: var(--brass-400); }
.cta-band .hero-cta { justify-content: center; }

/* --- FOOTER --- */
.site-footer { background: var(--forest-900); color: rgba(246,241,230,.7); padding-block: var(--space-6) var(--space-4); margin-top: var(--space-7); }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: var(--space-4); }
.site-footer .brand { color: var(--cream-50); margin-bottom: var(--space-2); }
.site-footer h4 { font-family: var(--font-body); font-size: var(--text-xs); letter-spacing: .18em; text-transform: uppercase; color: var(--brass-400); margin-bottom: var(--space-2); }
.site-footer ul { list-style: none; padding: 0; display: grid; gap: .6rem; }
.site-footer a:hover { color: var(--cream-50); }
.socials { display: flex; gap: .7rem; margin-top: var(--space-2); }
.socials a { width: 38px; height: 38px; border: 1px solid rgba(246,241,230,.2); border-radius: 0; display: grid; place-items: center; transition: all .2s; }
.socials a:hover { background: var(--brass-500); border-color: var(--brass-500); color: var(--forest-900); }
.socials svg { width: 18px; height: 18px; }
.footer-bottom { border-top: 1px solid rgba(246,241,230,.12); margin-top: var(--space-5); padding-top: var(--space-3); display: flex; justify-content: space-between; gap: var(--space-2); flex-wrap: wrap; font-size: var(--text-xs); }
.footer-bottom a { text-decoration: underline; text-underline-offset: 3px; }

/* 7. ANIMATIONEN -------------------------------------------------- */
@keyframes cue { 0%,100% { transform: scaleY(.4); opacity:.4 } 50% { transform: scaleY(1); opacity:1 } }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-delay="1"] { transition-delay: .08s; }
.reveal[data-delay="2"] { transition-delay: .16s; }
.reveal[data-delay="3"] { transition-delay: .24s; }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* 8. RESPONSIVE --------------------------------------------------- */
@media (max-width: 1024px) {
  .split { grid-template-columns: 1fr; gap: var(--space-5); }
  .split-media { max-width: 460px; }
  .features, .team, .quotes { grid-template-columns: repeat(2, 1fr); }
  .steps { grid-template-columns: repeat(2, 1fr); }
  .step::after { display: none; }
}

@media (max-width: 760px) {
  :root { --space-7: 4rem; }
  .nav-links { display: none; }
  .nav-toggle { display: inline-flex; }
  .nav-links.open {
    display: flex; flex-direction: column; align-items: flex-start;
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--cream-50); padding: var(--space-3); gap: var(--space-2);
    box-shadow: var(--shadow); border-top: 1px solid var(--color-border);
  }
  .site-header:not(.scrolled) .nav-links.open a { color: var(--forest-800); }
  .cards, .features, .team, .quotes, .steps { grid-template-columns: 1fr; }
  .stats .container { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }
  .stat:nth-child(3) { border-left: 0; }
  .stat + .stat { border-left: 0; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .hero { min-height: 92vh; }
  .split-media .badge { left: 0; }
}

@media (max-width: 460px) {
  .footer-grid { grid-template-columns: 1fr; }
  .stats .container { grid-template-columns: 1fr; }
  .stat + .stat { border-left: 0; padding-top: var(--space-3); border-top: 1px solid rgba(246,241,230,.12); }
}

/* ============================================================
   9. FANCY-LAYER — Extra-Politur & Interaktion
   ============================================================ */

/* Textauswahl & Custom-Scrollbar */
::selection { background: var(--brass-400); color: var(--forest-900); }
html { scrollbar-color: var(--moss-400) var(--cream-100); }

/* Scroll-Fortschrittsbalken oben */
.scroll-progress {
  position: fixed; top: 0; left: 0; height: 3px; width: 0;
  background: linear-gradient(90deg, var(--brass-600), var(--brass-400));
  z-index: 2000; transition: width .1s linear;
}

/* Mikrotypografie: tabellarische Ziffern für Preise & Zahlen */
.course-price, .r-price, .stat .num { font-variant-numeric: tabular-nums; }

/* Großes Zitatzeichen auf Stimmen-Karten */
.quote { isolation: isolate; }
.quote::before {
  content: "\201E"; position: absolute; top: -.1rem; right: 1.1rem; z-index: -1;
  font-family: var(--font-display); font-size: 5.5rem; line-height: 1; color: var(--cream-200);
}

/* Aktiver Navigationspunkt (Scrollspy) */
.nav-links a.active { color: var(--brass-600); }
.nav-links a.active::after { width: 100%; }
.site-header:not(.scrolled) .nav-links a.active { color: var(--brass-400); }

/* Zurück-nach-oben-Button */
.to-top {
  position: fixed; right: clamp(1rem, 3vw, 2rem); bottom: clamp(1rem, 3vw, 2rem); z-index: 900;
  width: 48px; height: 48px; border-radius: 0;
  display: grid; place-items: center;
  background: var(--forest-700); color: var(--cream-50); border: 1px solid var(--brass-500);
  box-shadow: var(--shadow); cursor: pointer;
  opacity: 0; visibility: hidden; transform: translateY(12px);
  transition: opacity .3s var(--ease), transform .3s var(--ease), visibility .3s, background .2s;
}
.to-top.show { opacity: 1; visibility: visible; transform: none; }
.to-top:hover { background: var(--forest-600); transform: translateY(-2px); }
.to-top svg { width: 20px; height: 20px; }

/* Akzentwörter: ruhige Volltonfarbe (kein Verlauf, kein Glow) */
.serif-italic, .text-gold { color: var(--brass-600); }

/* Hero: dezentes, gestaffeltes Einblenden des Inhalts (kein Bild-Zoom) */
.hero-inner > * { opacity: 0; animation: heroUp 1s var(--ease) forwards; }
.hero-inner > *:nth-child(1) { animation-delay: .2s; }
.hero-inner > *:nth-child(2) { animation-delay: .35s; }
.hero-inner > *:nth-child(3) { animation-delay: .5s; }
.hero-inner > *:nth-child(4) { animation-delay: .65s; }
@keyframes heroUp { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: none; } }

/* Laufband / USP-Ticker */
.ticker { background: var(--forest-800); color: var(--cream-50); overflow: hidden; border-block: 1px solid rgba(230,213,166,.18); }
.ticker-track { display: flex; align-items: center; gap: 0; white-space: nowrap; width: max-content; animation: ticker 34s linear infinite; }
.ticker:hover .ticker-track { animation-play-state: paused; }
.ticker-track span { display: inline-flex; align-items: center; gap: .9rem; padding: .85rem 1.6rem; font-size: var(--text-sm); letter-spacing: .04em; }
.ticker-track span::after { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--brass-400); }
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============================================================
   10. KURS-SUCHLEISTE (im Hero) + ERGEBNISSE
   ============================================================ */

/* Suchleiste unten im Hero – zentriert, mit deutlichem Abstand zum Text */
.hero-search {
  margin: var(--space-6) auto 0;
  background: rgba(255,255,255,.97);
  border: 1px solid rgba(255,255,255,.6);
  border-top: 3px solid var(--brass-500);   /* dezenter Marken-Akzent, weniger generisch */
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: var(--space-2);
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: var(--space-1);
  align-items: stretch;
  text-align: left;
  max-width: 760px;
}
.hs-field { display: flex; flex-direction: column; gap: .15rem; padding: .35rem .9rem; border-radius: var(--radius); position: relative; }
.hs-field + .hs-field { border-left: 1px solid var(--color-border); }
.hs-field label { font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--brass-600); }
.hs-field select {
  appearance: none; border: 0; background: transparent; width: 100%; cursor: pointer;
  font: inherit; font-size: var(--text-sm); font-weight: 500; color: var(--ink-900);
  padding: .15rem 1.6rem .15rem 0; outline: none;
}
.hs-field::after {
  content: ""; position: absolute; right: .9rem; bottom: 1rem; pointer-events: none;
  width: 8px; height: 8px; border-right: 2px solid var(--ink-500); border-bottom: 2px solid var(--ink-500);
  transform: rotate(45deg);
}
.hs-submit { align-self: stretch; padding-inline: 1.5rem; border-radius: var(--radius); white-space: nowrap; }
.hs-submit svg { width: 18px; height: 18px; }

/* Ergebnis-Sektion (Kurstermine) */
.results-head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-4); }
.results-count { font-size: var(--text-sm); color: var(--color-fg-muted); }
.results-count b { color: var(--forest-700); font-weight: 700; }
/* Filterleiste in der Sektion */
.rt-filters { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: flex-end; margin-top: var(--space-3); }
.rt-field { display: flex; flex-direction: column; gap: .35rem; }
.rt-field label { font-size: var(--text-xs); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--brass-600); }
.rt-field select {
  appearance: none; cursor: pointer; min-width: 210px;
  font: inherit; font-size: var(--text-sm); font-weight: 500; color: var(--ink-900);
  background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%235C6150' stroke-width='2' d='m1 1 5 5 5-5'/%3E%3C/svg%3E") no-repeat right .9rem center;
  border: 1px solid var(--color-border); border-radius: var(--radius);
  padding: .7rem 2.4rem .7rem .9rem; transition: border-color .2s, box-shadow .2s;
}
.rt-field select:focus { outline: none; border-color: var(--brass-500); box-shadow: 0 0 0 3px rgba(169,132,46,.15); }
.rt-reset { display: inline-flex; align-items: center; gap: .45rem; font-size: var(--text-sm); color: var(--brass-600); font-weight: 600; background: none; border: 0; cursor: pointer; padding: .7rem .2rem; }
.rt-reset svg { width: 16px; height: 16px; }
.rt-reset:hover { text-decoration: underline; }

/* Mehr/Einklappen */
.results-actions { display: flex; justify-content: center; gap: var(--space-2); margin-top: var(--space-4); }
.results-actions .btn svg { width: 18px; height: 18px; }

/* Ein-/Ausblenden der Karten */
.result-card.rt-hidden { display: none; }
@keyframes rIn { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

.results-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.result-card {
  background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  padding: var(--space-3); display: flex; flex-direction: column; gap: .7rem;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
}
.result-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--brass-400); }
.result-card .r-top { display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
.result-card .r-type { align-self: flex-start; font-size: .66rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: .28rem .65rem; border-radius: var(--radius-pill); }
.result-card .r-status { font-size: .66rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: #9A3B26; }
.result-card.is-full { opacity: .82; }
.result-card.is-full h3 { color: var(--ink-700); }
.r-type.t-präsenz { background: #E6EAD4; color: var(--forest-700); }
.r-type.t-online  { background: #DCE7E4; color: #1F4D45; }
.r-type.t-premium { background: var(--brass-200); color: var(--brass-600); }
.result-card h3 { font-size: var(--text-lg); }
.result-card .r-meta { display: grid; gap: .45rem; font-size: var(--text-sm); color: var(--color-fg-muted); }
.result-card .r-meta span { display: inline-flex; align-items: center; gap: .55rem; }
.result-card .r-meta svg { width: 16px; height: 16px; color: var(--moss-400); flex: none; }
.result-card .r-foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: var(--space-2); border-top: 1px solid var(--cream-100); }
.result-card .r-price { font-family: var(--font-display); font-size: 1.3rem; color: var(--forest-700); }
.results-empty { grid-column: 1/-1; text-align: center; padding: var(--space-6) var(--space-3); color: var(--color-fg-muted); }
.results-empty svg { width: 44px; height: 44px; color: var(--stone-300); margin-bottom: var(--space-2); }

@media (max-width: 760px) {
  .hero-search { grid-template-columns: 1fr; max-width: 420px; gap: 0; }
  .hs-field + .hs-field { border-left: 0; border-top: 1px solid var(--color-border); }
  .hs-submit { margin-top: var(--space-1); }
  .results-grid { grid-template-columns: 1fr; }
}
@media (max-width: 1024px) { .results-grid { grid-template-columns: repeat(2, 1fr); } }

/* Reduced-Motion: Zusatz-Animationen ruhigstellen */
@media (prefers-reduced-motion: reduce) {
  .hero-inner > *, .ticker-track { animation: none !important; }
  .hero-inner > * { opacity: 1 !important; }
}

/* ============================================================
   11. UNTERSEITEN — Page-Hero, Breadcrumb, Detail-Reihen,
       Vergleichstabelle, Workshops, Kontaktformular
   ============================================================ */

/* Kompakter Seiten-Hero */
.page-hero {
  position: relative; min-height: 60vh; display: flex; align-items: flex-end;
  padding: calc(var(--space-7) + 50px) 0 var(--space-6); color: var(--cream-50); overflow: hidden; text-align: left;
}
.page-hero-bg { position: absolute; inset: 0; z-index: -2; }
.page-hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.page-hero::after { content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(to top, rgba(17,22,10,.92) 0%, rgba(17,22,10,.5) 55%, rgba(17,22,10,.62) 100%); }
.page-hero .inner { max-width: 62ch; }
.page-hero h1 { color: #fff; font-size: var(--text-4xl); font-weight: 700; line-height: 1.05; margin: var(--space-1) 0 var(--space-2); }
.page-hero p { color: rgba(255,255,255,.9); font-size: var(--text-lg); max-width: 56ch; }

.breadcrumb { display: flex; align-items: center; gap: .5rem; font-size: var(--text-xs); letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.72); margin-bottom: var(--space-2); }
.breadcrumb a { transition: color .2s; }
.breadcrumb a:hover { color: var(--brass-400); }
.breadcrumb .sep { opacity: .5; }
.breadcrumb .current { color: var(--brass-400); }

/* Alternierende Detail-Reihen (Bild/Text) */
.detail-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); align-items: center; }
.detail-row + .detail-row { margin-top: var(--space-7); }
.detail-media { position: relative; margin: 0; }
.detail-media img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.detail-row.flip .detail-media { order: -1; }
.detail-badge { position: absolute; top: var(--space-2); left: var(--space-2); background: var(--brass-500); color: var(--forest-900); font-size: var(--text-xs); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: .4rem .8rem; border-radius: var(--radius-pill); }
.detail-text .price-line { font-family: var(--font-display); font-size: 2rem; color: var(--forest-700); margin: var(--space-2) 0; font-variant-numeric: tabular-nums; }
.detail-text .price-line small { font-family: var(--font-body); font-size: var(--text-sm); font-weight: 400; color: var(--color-fg-muted); }
.detail-feats { list-style: none; padding: 0; margin: var(--space-2) 0 var(--space-3); display: grid; gap: .6rem; }
.detail-feats li { display: flex; gap: .6rem; align-items: flex-start; font-size: var(--text-sm); }
.detail-feats svg { width: 18px; height: 18px; color: var(--forest-600); flex: none; margin-top: 3px; }

@media (max-width: 900px) {
  .detail-row { grid-template-columns: 1fr; gap: var(--space-4); }
  .detail-row.flip .detail-media { order: 0; }
}

/* Vergleichstabelle */
.compare-wrap { overflow-x: auto; border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-surface); }
.compare { width: 100%; border-collapse: collapse; min-width: 640px; }
.compare th, .compare td { padding: var(--space-2) var(--space-3); text-align: left; border-bottom: 1px solid var(--color-border); font-size: var(--text-sm); }
.compare thead th { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 500; background: var(--cream-100); }
.compare thead th.is-pop { color: var(--forest-700); position: relative; }
.compare thead th.is-pop::after { content: "Meist gebucht"; display: block; font-family: var(--font-body); font-size: .6rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--brass-600); }
.compare tbody th { font-weight: 600; color: var(--ink-700); }
.compare td svg { width: 18px; height: 18px; color: var(--forest-600); }
.compare td.no { color: var(--ink-300); }
.compare tr:last-child td, .compare tr:last-child th { border-bottom: 0; }
.compare .price { font-family: var(--font-display); font-size: 1.3rem; color: var(--forest-700); font-variant-numeric: tabular-nums; }

/* Workshop-Karten (Bild oben) */
.wcards { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.wcard { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease); }
.wcard:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--brass-400); }
.wcard-media { aspect-ratio: 3 / 2; overflow: hidden; }
.wcard-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.wcard:hover .wcard-media img { transform: scale(1.05); }
.wcard-body { padding: var(--space-3); display: flex; flex-direction: column; flex: 1; }
.wcard-body h3 { font-size: var(--text-xl); }
.wcard-body p { font-size: var(--text-sm); color: var(--color-fg-muted); margin: .5rem 0 var(--space-2); }
.wcard-foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: var(--space-2); border-top: 1px solid var(--cream-100); }
.wcard-price { font-family: var(--font-display); font-size: 1.4rem; color: var(--forest-700); font-variant-numeric: tabular-nums; }
.wcard-price small { font-family: var(--font-body); font-size: var(--text-xs); font-weight: 400; color: var(--color-fg-muted); display: block; }
@media (max-width: 900px) { .wcards { grid-template-columns: 1fr; } }

/* Kontaktformular */
.contact-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: var(--space-6); align-items: start; }
.form { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-4); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2) var(--space-3); }
.field { display: flex; flex-direction: column; gap: .4rem; margin-bottom: var(--space-2); }
.field.full { grid-column: 1 / -1; }
.field label { font-size: var(--text-sm); font-weight: 600; color: var(--ink-700); }
.field label .req { color: var(--brass-600); }
.field input, .field select, .field textarea {
  font: inherit; font-size: var(--text-sm); padding: .8rem 1rem; border: 1px solid var(--color-border);
  border-radius: var(--radius); background: #fff; color: var(--ink-900); transition: border-color .2s, box-shadow .2s; width: 100%;
}
.field select { appearance: none; cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%235C6150' stroke-width='2' d='m1 1 5 5 5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.4rem; }
.field textarea { resize: vertical; min-height: 120px; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--brass-500); box-shadow: 0 0 0 3px rgba(169,132,46,.15); }
.field.invalid input, .field.invalid textarea, .field.invalid select { border-color: #B5482E; }
.field .err { font-size: var(--text-xs); color: #B5482E; display: none; }
.field.invalid .err { display: block; }
.form-note { font-size: var(--text-xs); color: var(--color-fg-muted); margin-top: var(--space-1); }
.form-success { display: none; text-align: center; padding: var(--space-5) var(--space-3); }
.form-success.show { display: block; animation: rIn .5s var(--ease); }
.form-success .ok { width: 64px; height: 64px; margin: 0 auto var(--space-2); border-radius: 0; display: grid; place-items: center; background: var(--forest-700); color: var(--cream-50); }
.form-success .ok svg { width: 30px; height: 30px; }
.contact-aside { display: grid; gap: var(--space-3); }
.contact-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-3); }
.contact-card h3 { font-size: var(--text-lg); margin-bottom: var(--space-1); }
.contact-item { display: flex; gap: .8rem; align-items: flex-start; font-size: var(--text-sm); margin-top: var(--space-2); }
.contact-item svg { width: 20px; height: 20px; color: var(--forest-600); flex: none; margin-top: 2px; }
.contact-item a:hover { color: var(--brass-600); }
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; } .form-row { grid-template-columns: 1fr; } }

/* ============================================================
   12. MAGAZIN (Blog mit Filter) + E-LEARNING
   ============================================================ */

/* Filterleiste + Chips */
.filter-bar { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; justify-content: space-between; margin-bottom: var(--space-4); }
.chips { display: flex; flex-wrap: wrap; gap: .5rem; }
.chip { font-size: var(--text-sm); font-weight: 600; padding: .5rem 1rem; border-radius: var(--radius-pill); background: var(--cream-100); color: var(--ink-700); border: 1px solid transparent; cursor: pointer; transition: all .2s var(--ease); }
.chip:hover { border-color: var(--brass-400); }
.chip.active { background: var(--forest-700); color: var(--cream-50); }
.mag-search { position: relative; min-width: 240px; }
.mag-search input { width: 100%; font: inherit; font-size: var(--text-sm); padding: .65rem 1rem .65rem 2.4rem; border: 1px solid var(--color-border); border-radius: var(--radius-pill); background: #fff; }
.mag-search input:focus { outline: none; border-color: var(--brass-500); box-shadow: 0 0 0 3px rgba(169,132,46,.15); }
.mag-search svg { position: absolute; left: .85rem; top: 50%; transform: translateY(-50%); width: 16px; height: 16px; color: var(--moss-400); }

/* Kategorie-Tag */
.cat-tag { display: inline-block; font-size: .64rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: .28rem .65rem; border-radius: var(--radius-pill); background: var(--cream-200); color: var(--ink-700); }
.cat-tag.c-wild { background: #E6EAD4; color: var(--forest-700); }
.cat-tag.c-praxis { background: #CFDDB4; color: #3C4D18; }
.cat-tag.c-recht { background: #E7DED0; color: #6B4E1E; }
.cat-tag.c-ausruestung { background: var(--brass-200); color: var(--brass-600); }
.cat-tag.c-akademie { background: #E8D4B8; color: #7A552A; }

/* Featured-Artikel */
.featured-article { display: grid; grid-template-columns: 1.1fr .9fr; gap: 0; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; margin-bottom: var(--space-5); }
.featured-article .fa-media { position: relative; overflow: hidden; min-height: 340px; }
.featured-article .fa-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--ease); }
.featured-article:hover .fa-media img { transform: scale(1.04); }
.featured-article .fa-flag { position: absolute; top: var(--space-2); left: var(--space-2); background: var(--brass-500); color: var(--forest-900); font-size: var(--text-xs); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: .4rem .8rem; border-radius: var(--radius-pill); }
.featured-article .fa-body { padding: var(--space-5); display: flex; flex-direction: column; justify-content: center; }
.featured-article h2 { font-size: var(--text-2xl); margin: var(--space-2) 0; }
.featured-article p { color: var(--color-fg-muted); }
.ac-meta { display: flex; flex-wrap: wrap; gap: .3rem 1rem; font-size: var(--text-xs); color: var(--color-fg-muted); margin-top: var(--space-2); }
.ac-meta span { display: inline-flex; align-items: center; gap: .35rem; }
.ac-meta svg { width: 13px; height: 13px; }

/* Artikel-Grid */
.mag-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.article-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s; }
.article-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--brass-400); }
.article-card .ac-media { aspect-ratio: 16 / 10; overflow: hidden; }
.article-card .ac-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.article-card:hover .ac-media img { transform: scale(1.06); }
.article-card .ac-body { padding: var(--space-3); display: flex; flex-direction: column; flex: 1; gap: .5rem; }
.article-card h3 { font-size: var(--text-lg); line-height: 1.2; }
.article-card p { font-size: var(--text-sm); color: var(--color-fg-muted); }
.article-card .ac-link { margin-top: auto; }
.article-card.is-hidden { display: none; }
.mag-empty { grid-column: 1/-1; text-align: center; padding: var(--space-6) var(--space-3); color: var(--color-fg-muted); animation: rIn .4s var(--ease); }
.mag-empty svg { width: 44px; height: 44px; color: var(--stone-300); margin-bottom: var(--space-2); }
@media (max-width: 980px) { .mag-grid { grid-template-columns: repeat(2, 1fr); } .featured-article { grid-template-columns: 1fr; } .featured-article .fa-media { min-height: 240px; } }
@media (max-width: 620px) { .mag-grid { grid-template-columns: 1fr; } }

/* ---- E-LEARNING ---- */
.el-split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); align-items: center; }
@media (max-width: 900px) { .el-split { grid-template-columns: 1fr; } }

/* Dashboard-Mockup */
.dash { background: var(--forest-800); border-radius: var(--radius-lg); padding: var(--space-3); box-shadow: var(--shadow-lg); color: var(--cream-50); }
.dash-top { display: flex; align-items: center; justify-content: space-between; padding-bottom: var(--space-2); border-bottom: 1px solid rgba(246,241,230,.12); margin-bottom: var(--space-2); }
.dash-top .dots { display: flex; gap: .4rem; }
.dash-top .dots i { width: 10px; height: 10px; border-radius: 50%; background: rgba(246,241,230,.3); }
.dash-top small { font-size: var(--text-xs); color: rgba(246,241,230,.6); }
.dash-row { display: flex; align-items: center; gap: var(--space-2); padding: .7rem; border-radius: var(--radius); background: rgba(246,241,230,.05); margin-bottom: .6rem; }
.dash-row .ic { width: 38px; height: 38px; border-radius: 10px; background: rgba(198,162,76,.18); color: var(--brass-400); display: grid; place-items: center; flex: none; }
.dash-row .ic svg { width: 20px; height: 20px; }
.dash-row .meta { flex: 1; }
.dash-row .meta b { font-family: var(--font-body); font-weight: 600; font-size: var(--text-sm); display: block; }
.dash-bar { height: 6px; border-radius: 3px; background: rgba(246,241,230,.15); margin-top: .4rem; overflow: hidden; }
.dash-bar span { display: block; height: 100%; border-radius: 3px; background: linear-gradient(90deg, var(--brass-500), var(--brass-400)); }
.dash-row .pct { font-size: var(--text-xs); color: var(--brass-400); font-variant-numeric: tabular-nums; }

/* Lernmodule */
.modules { display: grid; gap: var(--space-2); counter-reset: mod; }
.module { counter-increment: mod; display: flex; gap: var(--space-3); align-items: center; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); padding: var(--space-3); transition: border-color .2s, transform .2s; }
.module:hover { border-color: var(--brass-400); transform: translateX(4px); }
.module::before { content: counter(mod, decimal-leading-zero); font-family: var(--font-display); font-size: 1.4rem; color: var(--brass-500); flex: none; width: 2.2rem; }
.module .m-body { flex: 1; }
.module .m-body h3 { font-size: var(--text-lg); }
.module .m-body p { font-size: var(--text-sm); color: var(--color-fg-muted); }
.module .m-count { font-size: var(--text-xs); color: var(--ink-300); white-space: nowrap; }

/* Zugang/Stat-Band E-Learning */
.el-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); }
.el-stat { text-align: center; padding: var(--space-3); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.el-stat .num { font-family: var(--font-display); font-size: 2rem; color: var(--forest-700); font-variant-numeric: tabular-nums; }
.el-stat .lbl { font-size: var(--text-sm); color: var(--color-fg-muted); margin-top: .3rem; }
@media (max-width: 760px) { .el-stats { grid-template-columns: 1fr 1fr; } }

/* ============================================================
   13. ARTIKEL / PROSE (Blog-Beiträge) + Detail-Meta
   ============================================================ */
.prose { max-width: 760px; margin-inline: auto; }
.prose > * + * { margin-top: var(--space-2); }
.prose h2 { font-size: var(--text-2xl); margin-top: var(--space-4); }
.prose h3 { font-size: var(--text-xl); margin-top: var(--space-3); }
.prose p { color: var(--ink-700); line-height: 1.65; }
.prose ul, .prose ol { margin-left: 1.2rem; display: grid; gap: .5rem; color: var(--ink-700); }
.prose li { line-height: 1.6; }
.prose blockquote { border-left: 3px solid var(--brass-500); padding: .2rem 0 .2rem var(--space-2); font-style: italic; color: var(--ink-700); }
.prose img { width: 100%; }
.prose a { color: var(--brass-600); text-decoration: underline; text-underline-offset: 3px; }
.prose strong { color: var(--ink-900); }

.article-meta { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem 1.2rem; font-size: var(--text-sm); color: rgba(255,255,255,.85); margin-top: var(--space-2); }
.article-meta span { display: inline-flex; align-items: center; gap: .4rem; }
.article-meta svg { width: 15px; height: 15px; flex: none; }
.article-meta .cat-tag { color: var(--forest-900); }

/* Info-Tabelle (Finanzierung / Zahlung) */
.info-table { width: 100%; border-collapse: collapse; background: var(--color-surface); border: 1px solid var(--color-border); }
.info-table th, .info-table td { text-align: left; padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--color-border); font-size: var(--text-sm); }
.info-table th { font-weight: 600; color: var(--ink-700); width: 40%; }
.info-table tr:last-child th, .info-table tr:last-child td { border-bottom: 0; }

/* ============================================================
   14. STARTSEITE-SEKTIONEN nach Live-Vorbild
   ============================================================ */
/* Partner-/Bekannt-durch-Leiste */
.partners { background: var(--cream-100); border-block: 1px solid var(--color-border); }
.partners .container { display: flex; flex-direction: column; align-items: center; gap: var(--space-3); padding-block: var(--space-4); }
.partners .p-label { font-size: var(--text-xs); letter-spacing: .18em; text-transform: uppercase; color: var(--ink-500); }
.partners .p-logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--space-5); }
.partners .p-logos img { height: 44px; width: auto; opacity: .65; filter: grayscale(1); transition: opacity .25s, filter .25s; }
.partners .p-logos img:hover { opacity: 1; filter: none; }

/* USP-Streifen (4 Punkte, dunkel) */
.usp-strip { background: var(--navy-700); color: #fff; }
.usp-strip .container { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); padding-block: var(--space-4); }
.usp { display: flex; align-items: center; gap: .75rem; font-size: var(--text-sm); font-weight: 500; }
.usp svg { width: 22px; height: 22px; color: var(--brass-400); flex: none; }
@media (max-width: 760px) { .usp-strip .container { grid-template-columns: 1fr 1fr; } }

/* Werte „Dafür stehen wir" (5) */
.values { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--space-3); }
.value .vicon { width: 50px; height: 50px; display: grid; place-items: center; color: var(--brass-600); border: 1px solid var(--color-border); margin-bottom: var(--space-2); }
.value .vicon svg { width: 24px; height: 24px; }
.value h3 { font-size: var(--text-lg); margin-bottom: .3rem; }
.value p { font-size: var(--text-sm); color: var(--color-fg-muted); }
@media (max-width: 1024px) { .values { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px) { .values { grid-template-columns: 1fr 1fr; } }

/* Newsletter */
.newsletter { background: var(--cream-100); text-align: center; }
.newsletter .inner { max-width: 560px; margin-inline: auto; }
.newsletter form { display: flex; gap: .5rem; margin-top: var(--space-3); }
.newsletter input { flex: 1; padding: .9rem 1rem; border: 1px solid var(--color-border); background: #fff; font: inherit; font-size: var(--text-sm); }
.newsletter input:focus { outline: none; border-color: var(--brass-500); box-shadow: 0 0 0 3px rgba(147,139,68,.15); }
.newsletter small { display: block; margin-top: var(--space-2); font-size: var(--text-xs); color: var(--ink-500); }
@media (max-width: 560px) { .newsletter form { flex-direction: column; } }

/* ============================================================
   15. REFINEMENT-LAYER (Feedback-Runde)
   ============================================================ */

/* — Hintergründe: alles #fdfdfb, dunkle Bänder bleiben — */
.partners, .newsletter, .manifest { background: var(--cream-50); }

/* — Taglines / Eyebrows raus (Headlines sollen stehen) — */
.eyebrow { display: none !important; }

/* — Buttons dezenter — */
.btn { padding: .56rem 1.15rem; font-weight: 500; letter-spacing: .05em; border-radius: 0; }
.btn svg { width: 15px; height: 15px; }
.btn-primary, .btn-accent { box-shadow: none; }
.btn:hover { transform: none; }
.btn-primary:hover, .btn-accent:hover { background: var(--brass-600); border-color: var(--brass-600); }
.btn-outline:hover, .btn-ghost:hover { transform: none; }

/* — Mehr Luft in Textabschnitten — */
.section-head { margin-bottom: var(--space-5); }
.lead { line-height: 1.55; margin-top: var(--space-1); }
.split .lead, .manifest-text .lead, .detail-text p { line-height: 1.6; }
.intro-points { gap: var(--space-2); }
.detail-feats { gap: .7rem; }
.prose > * + * { margin-top: var(--space-2); }
.split > div > .hero-cta, .detail-text .price-line { margin-top: var(--space-3); }

/* — Cooler Hero-Filter (dunkles Glas statt generischer weißer Leiste) — */
.hero-search {
  background: rgba(18,22,14,.42);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(16px) saturate(150%);
  box-shadow: 0 24px 60px -28px rgba(0,0,0,.6);
  padding: .4rem .4rem .4rem 0;
  max-width: 820px;
}
.hero-search .hs-field { padding: .55rem 1.2rem; }
.hero-search .hs-field + .hs-field { border-left: 1px solid rgba(255,255,255,.16); }
.hero-search .hs-field label { color: var(--brass-400); letter-spacing: .14em; }
.hero-search .hs-field select { color: #fff; }
.hero-search .hs-field select option { color: var(--ink-900); }
.hero-search .hs-field::after { border-color: rgba(255,255,255,.7); }
.hero-search .hs-submit { margin: .35rem; }

/* — Dozenten-Cards modern, mit Platzhalter für Personenbild — */
.team { grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.coach {
  display: flex; flex-direction: column; align-items: stretch;
  background: #fff; border: 1px solid var(--color-border); padding: 0; overflow: hidden;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
}
.coach:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--brass-400); }
.coach-photo {
  position: relative; aspect-ratio: 4 / 3; display: grid; place-items: center;
  background: linear-gradient(150deg, var(--forest-600), var(--forest-900));
  overflow: hidden;
}
.coach-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.coach-photo .ph-icon { width: 72px; height: 72px; color: rgba(255,255,255,.28); }
.coach-photo .ph-tag { position: absolute; left: 12px; bottom: 12px; font-size: var(--text-xs); letter-spacing: .04em; color: rgba(255,255,255,.7); background: rgba(18,22,14,.4); backdrop-filter: blur(4px); padding: .2rem .5rem; }
.coach-info { padding: var(--space-3); }
.coach-info h3 { font-size: var(--text-lg); }
.coach-info .role { font-size: var(--text-xs); letter-spacing: .06em; text-transform: uppercase; color: var(--brass-600); font-weight: 600; margin-top: .25rem; }
.coach-info .spec { font-size: var(--text-sm); color: var(--color-fg-muted); margin-top: .6rem; line-height: 1.6; }
@media (max-width: 900px) { .team { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .team { grid-template-columns: 1fr; } }

/* — Eindrücke-Slider (Startseite) — */
.slider-wrap { position: relative; }
.slider { display: flex; gap: var(--space-2); overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; -ms-overflow-style: none; scrollbar-width: none; padding-bottom: .5rem; }
.slider::-webkit-scrollbar { display: none; }
.slider figure { position: relative; flex: 0 0 clamp(260px, 32%, 420px); scroll-snap-align: start; margin: 0; overflow: hidden; aspect-ratio: 4 / 3; }
.slider figure img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.slider figure:hover img { transform: scale(1.05); }
.slider figcaption { position: absolute; inset: auto 0 0 0; padding: var(--space-3) var(--space-2) var(--space-2); color: #fff; font-size: var(--text-sm); font-weight: 600; background: linear-gradient(transparent, rgba(17,22,10,.8)); }
.slider-nav { display: flex; gap: .5rem; margin-top: var(--space-3); justify-content: flex-end; }
.slider-btn { width: 46px; height: 46px; display: grid; place-items: center; background: #fff; border: 1px solid var(--color-border); cursor: pointer; transition: all .2s; }
.slider-btn:hover { background: var(--forest-700); color: #fff; border-color: var(--forest-700); }
.slider-btn svg { width: 20px; height: 20px; }

/* — 4-Schritte mit Pfeilen — */
.step { position: relative; }
.step:not(:last-child)::after {
  content: ""; position: absolute; top: 21%; right: calc(var(--space-3) * -0.5 - 7px);
  width: 14px; height: 14px; border-top: 2px solid var(--brass-500); border-right: 2px solid var(--brass-500);
  transform: rotate(45deg); opacity: .8;
}
.step .step-link { display: inline-flex; align-items: center; gap: .4rem; margin-top: .7rem; font-size: var(--text-sm); font-weight: 600; color: var(--brass-600); }
.step .step-link svg { width: 15px; height: 15px; transition: transform .2s var(--ease); }
.step .step-link:hover svg { transform: translateX(4px); }
@media (max-width: 1024px) { .step:not(:last-child)::after { display: none; } }

/* — Footer: Sichere Bezahlung — */
.footer-pay { border-top: 1px solid rgba(255,255,255,.12); margin-top: var(--space-4); padding-top: var(--space-3); }
.footer-pay h4 { font-family: var(--font-body); font-size: var(--text-xs); letter-spacing: .18em; text-transform: uppercase; color: var(--brass-400); margin-bottom: var(--space-2); }
.pay-badges { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; }
.pay-emb { height: 24px; width: auto; display: block; border: 1px solid rgba(0,0,0,.10); box-shadow: 0 1px 2px rgba(0,0,0,.15); }
.cart-pay { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-2); padding-top: var(--space-3); border-top: 1px solid var(--color-border); }
.cart-pay__label { font-family: var(--font-body); font-size: var(--text-xs); letter-spacing: .14em; text-transform: uppercase; color: var(--ink-500); }

/* ============================================================
   16. REFINEMENT v2 (Feedback-Runde 2)
   ============================================================ */

/* — Ankündigungs-Topbar über der Nav (verschwindet beim Scrollen) — */
.topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1002; height: 40px;
  display: flex; align-items: center; justify-content: center;
  background: var(--forest-700); color: var(--cream-50);
  font-size: var(--text-xs); letter-spacing: .08em; text-transform: uppercase;
  transition: transform .35s var(--ease);
  overflow: hidden;
}
.topbar .tb-msg { display:inline-flex; align-items:center; gap:.6rem; opacity:0; transition:opacity .45s var(--ease); position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); white-space:nowrap; }
.topbar .tb-msg.on { opacity:1; }
.topbar .tb-msg::before { content: ""; width: 6px; height: 6px; background: var(--brass-400); display: inline-block; }
.site-header { top: 40px; }
html.tb-hidden .topbar { transform: translateY(-100%); }
html.tb-hidden .site-header { top: 0; }

/* — Dozenten: Bild links (schmaler), Text rechts, 3 pro Reihe — */
.coach { flex-direction: row; align-items: stretch; }
.coach-photo { flex: 0 0 40%; aspect-ratio: auto; min-height: 100%; }
.coach-photo .ph-icon { width: 48px; height: 48px; }
.coach-photo .ph-tag { left: 8px; bottom: 8px; font-size: .58rem; }
.coach-info { flex: 1; display: flex; flex-direction: column; justify-content: center; padding: var(--space-3); }
.coach-info .spec { margin-top: .5rem; }
@media (max-width: 560px) { .coach-photo { flex-basis: 42%; } }

/* — Kurskarten: keine Hervorhebung, Tag klein ÜBER der Karte — */
.course-card.featured { border-color: var(--color-border); border-width: 1px; box-shadow: none; }
.course-card > .course-tag {
  position: static; margin: 0 0 .6rem 0; align-self: flex-start;
  background: none; padding: 0; color: var(--brass-600);
  font-size: .64rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
}
.course-media .course-tag { display: none; }
.course-card .price-anfrage { font-size: var(--text-sm); color: var(--color-fg-muted); margin: var(--space-2) 0; }

/* — Full-width CTA mit Hintergrundbild — */
.cta-full { position: relative; padding: var(--space-7) var(--space-3); text-align: center; color: #fff; overflow: hidden; }
.cta-full-bg { position: absolute; inset: 0; z-index: -2; }
.cta-full-bg img { width: 100%; height: 100%; object-fit: cover; }
.cta-full::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(rgba(17,22,10,.78), rgba(17,22,10,.62)); }
.cta-full .inner { max-width: 640px; margin-inline: auto; }
.cta-full h2 { color: #fff; }
.cta-full p { color: rgba(255,255,255,.85); margin: var(--space-2) auto var(--space-3); max-width: 48ch; }

/* — Slider cooler — */
.slider-wrap { position: relative; }
.slider { gap: var(--space-2); }
.slider figure { flex-basis: clamp(300px, 44%, 540px); aspect-ratio: 3 / 2; }
.slider figcaption { font-size: var(--text-base); letter-spacing: -.01em; padding: var(--space-4) var(--space-3) var(--space-2); }
.slider-nav { position: absolute; top: -68px; right: 0; margin: 0; }
.slider-btn { width: 44px; height: 44px; }
@media (max-width: 600px) { .slider-nav { position: static; margin-top: var(--space-3); } }

/* — Coolere 4-Schritte-Grafik (Nummern statt Fotos) — */
.steps { counter-reset: step; gap: var(--space-4); }
.step { counter-increment: step; text-align: left; padding-top: var(--space-2); border-top: 2px solid var(--color-border); }
.step .step-media { display: none; }
.step::before { content: counter(step, decimal-leading-zero); display: block; font-family: var(--font-display); font-size: 2.6rem; line-height: 1; color: var(--brass-500); margin-bottom: var(--space-2); }
.step h3 { font-size: var(--text-lg); }
.step p { font-size: var(--text-sm); color: var(--color-fg-muted); line-height: 1.6; }
.step:not(:last-child)::after { content: ""; position: absolute; top: -2px; right: calc(var(--space-4) * -0.5 - 1px); width: 11px; height: 11px; border-top: 2px solid var(--brass-500); border-right: 2px solid var(--brass-500); transform: rotate(45deg); }
@media (max-width: 1024px) { .step:not(:last-child)::after { display: none; } }

/* — FAQ zweispaltig: links Intro, rechts Accordion — */
.faq-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: var(--space-6); align-items: start; }
.faq-grid .faq { max-width: none; margin: 0; }
.faq-intro h2 { margin-bottom: var(--space-2); }
.faq-intro .lead { margin-bottom: var(--space-3); }
@media (max-width: 860px) { .faq-grid { grid-template-columns: 1fr; gap: var(--space-4); } }

/* ============================================================
   17. REFINEMENT v3 (Feedback-Runde 3)
   ============================================================ */

/* — Topbar hell — */
.topbar { background: var(--cream-100); color: var(--ink-700); border-bottom: 1px solid var(--color-border); }
.topbar .tb-msg::before { background: var(--brass-500); }

/* — Hero-Filter hell — */
.hero-search {
  background: rgba(255,255,255,.95); border: 1px solid rgba(255,255,255,.7);
  backdrop-filter: blur(10px) saturate(140%); box-shadow: var(--shadow-lg);
}
.hero-search .hs-field label { color: var(--brass-600); }
.hero-search .hs-field select { color: var(--ink-900); }
.hero-search .hs-field select option { color: var(--ink-900); }
.hero-search .hs-field + .hs-field { border-left: 1px solid var(--color-border); }
.hero-search .hs-field::after { border-color: var(--ink-500); }

/* — Kurskarten: Tag lesbar OBEN, Bild nicht darüber, Preise auf gleicher Höhe — */
.course-media { margin-top: 0; }
.course-card > .course-tag { font-size: .7rem; color: var(--brass-600); letter-spacing: .12em; margin: 0 0 .8rem; }
.cards .course-card > p.muted { min-height: 5.4em; }
.course-price, .price-anfrage { min-height: 2.7rem; display: flex; align-items: center; margin: var(--space-2) 0; }

/* — Dozenten optimiert — */
.coach-photo { flex-basis: 34%; }
.coach-info { padding: var(--space-3); }
.coach-info h3 { font-size: var(--text-base); }
.coach-info .role { margin-top: .3rem; }
.coach-info .spec { margin-top: .55rem; line-height: 1.5; }

/* — Schritt-Pfeile mittig auf der Linie — */
.step:not(:last-child)::after { top: -6px; }

/* — USP-Band einzeilig — */
.usp { white-space: nowrap; font-size: .78rem; gap: .55rem; }
.usp svg { width: 18px; height: 18px; }
.usp-strip .container { gap: var(--space-2); }

/* — Werte-Icons optimiert — */
.value .vicon { border: none; background: var(--brass-200); color: var(--brass-600); width: 52px; height: 52px; }
.value .vicon svg { width: 26px; height: 26px; }

/* ============================================================
   18. REFINEMENT v4 (Feedback-Runde 4)
   ============================================================ */

/* — Dozenten: alle Cards gleich hoch, Namen auf einer Höhe — */
.team { align-items: stretch; }
.coach { min-height: 168px; }
.coach-info { justify-content: flex-start; }
.coach-info h3 { min-height: 1.4em; }
.coach-info .spec { display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden; }

/* — Paragraphenabstände generell kleiner — */
.prose > * + * { margin-top: .8rem; }
.intro-points { gap: .65rem; }
.detail-feats { gap: .55rem; }
.course-feats { gap: .55rem; }
.manifest-text .lead, .split .lead { margin-top: var(--space-1); }
.contact-item { margin-top: var(--space-1); }

/* — Kurskarten: Tag viel schmaler, Preise sicher auf einer Höhe — */
.course-card > .course-tag { font-size: .58rem; font-weight: 600; letter-spacing: .14em; margin: 0 0 .55rem; }
.cards .course-card > p.muted { min-height: 6em; }
.course-price, .price-anfrage { min-height: 2.8rem; }

/* — USP-Band: gleiche Abstände — */
.usp-strip .container { display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-3) var(--space-4); }
.usp { flex: 0 1 auto; }
@media (max-width: 760px) { .usp-strip .container { justify-content: flex-start; } .usp { flex: 0 0 45%; } }

/* Hero-Hintergrundvideo */
.hero-bg video { width: 100%; height: 100%; object-fit: cover; }

/* ============================================================
   19. REFINEMENT v5 (Tag-Leiste schmaler + Endlos-Slider)
   ============================================================ */

/* Tag-Leiste oben deutlich schmaler */
.course-card { padding-top: .8rem; }
.course-card > .course-tag { margin: 0 0 .4rem; }

/* Eindrücke: Accordion-Galerie (aktives Bild breit, übrige als Streifen) */
.accordion-gallery { display: flex; gap: var(--space-2); height: 560px; width: 100%; }
.acc-item {
  position: relative; flex: 1 1 0; min-width: 0; overflow: hidden;
  background-size: cover; background-position: center; background-repeat: no-repeat;
  border: 0; padding: 0; margin: 0; cursor: pointer; appearance: none;
  transition: flex-grow .55s var(--ease);
}
.acc-item::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(17,22,10,.78) 0%, rgba(17,22,10,.25) 32%, transparent 60%); opacity: .55; transition: opacity .4s var(--ease); }
.acc-item.is-active { flex-grow: 7; }
.acc-item.is-active::after { opacity: 1; }

.acc-caption { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; display: block; padding: var(--space-4) var(--space-5); text-align: left; color: #fff; opacity: 0; transform: translateY(8px); transition: opacity .4s var(--ease) .1s, transform .4s var(--ease) .1s; white-space: nowrap; overflow: hidden; }
.acc-item.is-active .acc-caption { opacity: 1; transform: none; }
.acc-title { display: block; font-family: var(--font-head); font-size: var(--text-2xl); font-weight: 700; line-height: 1.1; }
.acc-sub { display: block; margin-top: .25rem; font-size: var(--text-base); color: rgba(255,255,255,.85); }

@media (max-width: 760px) {
  .accordion-gallery { height: 420px; }
  .acc-item.is-active { flex-grow: 6; }
  .acc-caption { padding: var(--space-3) var(--space-4); }
  .acc-title { font-size: var(--text-xl); }
  .acc-sub { font-size: var(--text-sm); }
}
@media (prefers-reduced-motion: reduce) { .acc-item { transition: none; } }

/* ============================================================
   20. REFINEMENT v6 (Magazin: Empfohlener Beitrag dezenter)
   ============================================================ */
/* Featured ruhiger: flacher, kleinere Typo, weniger Bildfläche */
.featured-article { grid-template-columns: 1fr 1fr; border-color: var(--cream-100); margin-bottom: var(--space-4); }
.featured-article .fa-media { min-height: 260px; }
.featured-article .fa-body { padding: var(--space-4); }
.featured-article h2 { font-size: var(--text-xl); margin: var(--space-1) 0 var(--space-2); }
.featured-article p { font-size: var(--text-sm); }
/* "Empfohlen"-Flag: scharfkantig, klein, dezent statt Messing-Pille */
.featured-article .fa-flag {
  background: rgba(22,24,28,.55); color: #fff; backdrop-filter: blur(4px);
  border-radius: 0; font-size: .62rem; font-weight: 600; letter-spacing: .12em;
  padding: .3rem .6rem;
}
@media (max-width: 980px) { .featured-article .fa-media { min-height: 220px; } }

/* Weitere Beiträge: Kopfzeile mit "Alle Beiträge"-Link rechts */
.more-head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-3); flex-wrap: wrap; }
.more-head .link-arrow { white-space: nowrap; }

/* Über uns: fünf Werte (3 + 2, mittig) */
.features-5 { grid-template-columns: repeat(6, 1fr); }
.features-5 .feature { grid-column: span 2; }
.features-5 .feature:nth-child(4) { grid-column: 2 / span 2; }
.features-5 .feature:nth-child(5) { grid-column: 4 / span 2; }
@media (max-width: 760px) { .features-5 { grid-template-columns: 1fr; } .features-5 .feature, .features-5 .feature:nth-child(4), .features-5 .feature:nth-child(5) { grid-column: auto; } }

/* Über uns: Eindrücke-Endlos-Slider (Auto-Scroll, eine Richtung) */
.es-slider { overflow: hidden; }
.es-track { display: flex; gap: var(--space-2); width: max-content; animation: es-scroll 40s linear infinite; }
.es-slider:hover .es-track { animation-play-state: paused; }
.es-item { flex: 0 0 auto; width: clamp(220px, 24vw, 320px); height: clamp(220px, 24vw, 320px); margin: 0; overflow: hidden; }
.es-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--ease), filter .4s var(--ease); }
.es-item:hover img { transform: scale(1.05); filter: brightness(1.06); }
@keyframes es-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .es-track { animation: none; } .es-slider { overflow-x: auto; -webkit-mask: none; mask: none; } }
/* Rechtsseiten: Hinweis-Box */
.prose .legal-note { background: var(--cream-100); border-left: 3px solid var(--brass-500); padding: var(--space-3) var(--space-4); font-size: var(--text-sm); color: var(--color-fg-muted); margin-bottom: var(--space-4); }

/* Kontakt: Google-Maps-Einbettung */
.contact-map .map-embed { overflow: hidden; border: 1px solid var(--color-border); margin-top: var(--space-2); }
.contact-map .map-embed iframe { display: block; width: 100%; height: 300px; border: 0; filter: grayscale(0.15); }

/* Rechtsseiten: Quellen-/Copyright-Hinweis (IT-Recht Kanzlei) */
.prose .legal-source { margin-top: var(--space-4); padding-top: var(--space-3); border-top: 1px solid var(--color-border); font-size: var(--text-sm); color: var(--color-fg-muted); }
.prose .legal-source img { display: block; width: auto; max-width: 200px; height: auto; margin: 0 0 .5rem; }

/* ============================================================
   21. RESPONSIVE: Mobile/Tablet-Slider + Header-Fix
   ============================================================ */
/* Header: breiten CTA-Button auf Mobil ausblenden, Logo etwas kleiner */
@media (max-width: 760px) {
  .nav-actions .btn { display: none; }
  .brand img { height: 34px; }
}

/* Linien-Indikator unter den Slidern (nur Mobil/Tablet sichtbar) */
.mslider-lines { display: none; }

@media (max-width: 900px) {
  /* Cards / Workshops / Stimmen -> horizontaler Wisch-Slider (kein Auto-Slide) */
  .cards, .wcards, .quotes {
    display: flex; flex-wrap: nowrap; overflow-x: auto;
    scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch;
    gap: var(--space-3); scrollbar-width: none;
  }
  .cards::-webkit-scrollbar, .wcards::-webkit-scrollbar, .quotes::-webkit-scrollbar { display: none; }
  .cards > *, .wcards > *, .quotes > * { flex: 0 0 86%; scroll-snap-align: center; min-width: 0; }

  /* Eindrücke-Accordion -> Wisch-Slider, Captions dauerhaft sichtbar */
  .accordion-gallery {
    height: auto; overflow-x: auto; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
  }
  .accordion-gallery::-webkit-scrollbar { display: none; }
  .accordion-gallery .acc-item { flex: 0 0 82%; scroll-snap-align: center; height: 380px; transition: none; }
  .accordion-gallery .acc-item::after { opacity: 1; }
  .accordion-gallery .acc-item .acc-caption { opacity: 1; transform: none; }

  /* Linien-Indikator */
  .mslider-lines { display: flex; gap: 7px; justify-content: center; margin-top: var(--space-3); }
  .mslider-lines button { width: 24px; height: 3px; padding: 0; border: 0; background: var(--color-border); cursor: pointer; transition: background .2s, width .2s; }
  .mslider-lines button.active { background: var(--brass-500); width: 38px; }
}

/* Aktuelle Kurstermine: Ergebnis-Liste responsiv (verhindert Überlauf auf Mobil) */
@media (max-width: 1024px) { .results-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 640px)  { .results-grid { grid-template-columns: minmax(0, 1fr); } }

/* Kurstermine-Filter + Cards auf Mobil voll-breit (kein Überlauf) */
@media (max-width: 640px) {
  .rt-filters { flex-direction: column; align-items: stretch; }
  .rt-field { width: 100%; }
  .rt-field select { min-width: 0; width: 100%; }
  .result-card { min-width: 0; }
  .result-card .r-foot { flex-wrap: wrap; gap: .5rem; }
}

/* Dozenten-Cards: auf Mobil/Tablet schrumpfbar (verhindert Seiten-Overflow) */
@media (max-width: 900px) { .team { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) {
  .team { grid-template-columns: minmax(0, 1fr); }
  .coach { min-width: 0; }
  .coach-info { min-width: 0; }
}

/* Schutz gegen horizontalen Overflow auf kleinen Screens */
html, body { overflow-x: hidden; max-width: 100%; }

/* Kurs-Cards: Headline etwas größer, Preis (Präsenz/Online) kleiner & dezenter */
.course-card h3 { font-size: 1.5rem; margin-bottom: var(--space-2); }
.course-price { font-size: 1.6rem; color: var(--ink-700); font-weight: 500; }
.course-price small { font-size: var(--text-xs); color: var(--color-fg-muted); }

/* ============================================================
   22. POLISH: A11y (Focus/Skip-Link) + Mikro-Typografie
   ============================================================ */
/* Sichtbarer Tastatur-Fokus (nur bei Keyboard-Navigation) */
:where(a, button, input, select, textarea, summary, [tabindex]):focus-visible {
  outline: 2px solid var(--brass-500);
  outline-offset: 3px;
}
.site-header:not(.scrolled) .nav-links a:focus-visible { outline-color: var(--cream-50); }

/* Skip-to-Content-Link */
.skip-link {
  position: fixed; left: 12px; top: -60px; z-index: 3000;
  background: var(--forest-700); color: #fff; padding: .65rem 1.1rem;
  font-size: var(--text-sm); font-weight: 600; text-decoration: none;
  transition: top .2s var(--ease);
}
.skip-link:focus { top: 12px; }

/* Mikro-Typografie */
h1, h2, h3, .display, .h1, .h2 { text-wrap: balance; }
p, li, blockquote, figcaption { text-wrap: pretty; }
body { overflow-wrap: break-word; }

/* ===== Refinement #23 — Zwei-Routen-Buchung & CTA-Schreibweise (2026-05-27) ===== */
/* CTAs in normaler Schreibweise statt uppercase */
.btn { text-transform: none; letter-spacing: .005em; font-size: var(--text-sm); }

/* Zwei-Routen-CTA-Gruppe (verbindlich anmelden + informieren nebeneinander) */
.route-cta { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; }
.route-cta .btn { flex: 0 1 auto; }

/* Hinweis-Box: verbindliche Anmeldung ohne Sofortzahlung */
.note-box {
  border: 1px solid #E7E2D2;
  border-left: 3px solid var(--brass-500);
  background: #FBF8EF;
  padding: var(--space-3);
  display: flex; gap: .7rem; align-items: flex-start;
  font-size: var(--text-sm); color: var(--ink-700); line-height: 1.5;
  margin-top: var(--space-2);
}
.note-box svg { width: 20px; height: 20px; flex: none; color: var(--brass-600); margin-top: .15rem; }
.note-box b { color: var(--ink-900); }
.note-box.on-dark { background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.18); border-left-color: var(--brass-400); color: rgba(246,241,230,.9); }
.note-box.on-dark b { color: #fff; }

/* ===== Refinement #24 — Überschriften einfarbig: keine Akzentwort-Highlights (2026-05-27) ===== */
.serif-italic { color: inherit; }
h1 .accent, h2 .accent, h3 .accent, h4 .accent,
.h1 .accent, .h2 .accent, .h3 .accent, .h4 .accent { color: inherit; }

/* ===== Refinement #25 — Vergleichstabelle: mobiler Scroll-Hinweis (2026-05-27) ===== */
.compare-scroll { position: relative; }
.compare-hint { display: none; }
@media (max-width: 700px) {
  .compare-hint {
    display: flex; align-items: center; gap: .5rem;
    position: relative; z-index: 1;          /* über dem rechten Fade */
    margin-bottom: var(--space-2); padding-right: var(--space-3);
    font-size: var(--text-sm); font-weight: 600; color: var(--brass-600);
    line-height: 1.3;
    transition: opacity .25s var(--ease), visibility .25s;
  }
  .compare-hint.is-hidden { opacity: 0; visibility: hidden; }
  .compare-hint svg { width: 22px; height: 22px; flex: none; }
  .compare-hint span { min-width: 0; }
  .compare-hint .swipe { animation: swipeHint 1.6s var(--ease) infinite; }
  .compare-scroll::after {
    content: ""; position: absolute; top: 0; bottom: 0; right: 0; width: 42px;
    background: linear-gradient(to right, rgba(253,253,251,0), var(--cream-50) 88%);
    pointer-events: none; transition: opacity .25s var(--ease);
  }
  .compare-scroll.scrolled-end::after { opacity: 0; }
}
@keyframes swipeHint { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(6px); } }
@media (prefers-reduced-motion: reduce) { .compare-hint .swipe { animation: none; } }

/* ===== Refinement #26 — Mobiles Menü + Hamburger-Sichtbarkeit (2026-05-27) ===== */
/* Hamburger: hell über dem Hero, dunkel im gescrollten (hellen) Header */
.nav-toggle { color: var(--ink-900); border-radius: 0; transition: color .35s var(--ease), filter .35s var(--ease); }
/* über dem Hero: weißes Icon + dezenter Schatten → auf hellen UND dunklen Bildstellen sichtbar */
.site-header:not(.scrolled) .nav-toggle { color: var(--cream-50); filter: drop-shadow(0 1px 3px rgba(12, 16, 9, .6)); }
.site-header.scrolled .nav-toggle { color: var(--ink-900); filter: none; }

@media (max-width: 760px) {
  /* Aufgeräumtes, großzügiges Vollbreiten-Menü */
  .nav-links.open {
    padding: var(--space-2) var(--space-4) var(--space-4);
    gap: 0;
    background: var(--cream-50);
    border-top: 1px solid var(--color-border);
    box-shadow: 0 22px 44px rgba(20, 22, 16, .18);
    animation: navDrop .28s var(--ease);
  }
  .nav-links.open li { width: 100%; }
  .nav-links.open a {
    display: block; width: 100%;
    font-size: var(--text-lg); font-weight: 600; color: var(--ink-900);
    padding: .95rem .2rem;
    border-bottom: 1px solid var(--color-border);
  }
  .nav-links.open li:last-child a { border-bottom: 0; }
  .nav-links.open a::after { display: none; }       /* Unterstrich entfällt bei Blocklinks */
  .nav-links.open a:active { color: var(--brass-600); }
  .nav-links.open a.active { color: var(--brass-600); }
  /* Auch über dem Hero dunkle, gut lesbare Links im offenen Menü */
  .site-header:not(.scrolled) .nav-links.open a { color: var(--ink-900); }
  .site-header:not(.scrolled) .nav-links.open a.active { color: var(--brass-600); }
}
@keyframes navDrop { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .nav-links.open { animation: none; } }

/* ===== Refinement #27 — Magazin „Empfohlen" auf Mobil stapeln (Bild voll sichtbar) ===== */
/* Behebt: spätere globale Regel (1fr 1fr) überschrieb das Stapeln → Bild war schmal. */
@media (max-width: 860px) {
  .featured-article { grid-template-columns: 1fr; }
  .featured-article .fa-media { min-height: 0; aspect-ratio: 16 / 10; }
}

/* ===== Refinement #28 — Cookie-Consent (2026-05-27) ===== */
.cookie-consent {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 2000;
  background: var(--cream-50); border-top: 1px solid var(--color-border);
  box-shadow: 0 -10px 30px rgba(20, 22, 16, .14);
  animation: ccUp .35s var(--ease);
}
.cookie-consent[hidden] { display: none; }
.cc-inner {
  width: 100%; max-width: var(--container); margin-inline: auto;
  padding: var(--space-3); display: flex; align-items: center; gap: var(--space-4);
}
.cc-title { font-family: var(--font-display); font-size: var(--text-md); font-weight: 500; margin-bottom: .15rem; }
.cc-text p { font-size: var(--text-sm); color: var(--color-fg-muted); max-width: 72ch; line-height: 1.5; }
.cc-text a { color: var(--brass-600); text-decoration: underline; }
.cc-actions { display: flex; gap: var(--space-2); flex-shrink: 0; }
@keyframes ccUp { from { transform: translateY(100%); } to { transform: none; } }
@media (prefers-reduced-motion: reduce) { .cookie-consent { animation: none; } }
@media (max-width: 760px) {
  .cc-inner { flex-direction: column; align-items: stretch; gap: var(--space-3); }
  .cc-actions { flex-direction: column-reverse; }
  .cc-actions .btn { width: 100%; justify-content: center; }
}
/* Dauerhaftes Cookie-Einstellungen-Icon unten links (gleiche Höhe wie „nach oben") */
.cookie-settings-btn {
  position: fixed; left: clamp(1rem, 3vw, 2rem); bottom: clamp(1rem, 3vw, 2rem); z-index: 900;
  width: 48px; height: 48px; border-radius: 0;
  display: grid; place-items: center;
  background: var(--forest-700); color: var(--cream-50); border: 1px solid var(--brass-500);
  box-shadow: var(--shadow); cursor: pointer;
  transition: background .2s var(--ease), transform .2s var(--ease);
}
.cookie-settings-btn:hover { background: var(--forest-600); transform: translateY(-2px); }
.cookie-settings-btn svg { width: 22px; height: 22px; }
.cookie-settings-btn[hidden] { display: none; }

/* ===== Refinement #29 — Direktkauf / Checkout (nur in dieser Variante) ===== */
/* Bestellübersicht (Aside) */
.order-summary { background: var(--cream-100); border: 1px solid var(--color-border); padding: var(--space-4); }
.order-summary h3 { font-family: var(--font-display); font-size: var(--text-md); margin-bottom: var(--space-3); }
.order-summary .os-row { display: flex; justify-content: space-between; gap: var(--space-3); padding-block: .5rem; border-bottom: 1px solid var(--color-border); font-size: var(--text-sm); }
.order-summary .os-row span:first-child { color: var(--color-fg-muted); }
.order-summary .os-total { display: flex; justify-content: space-between; align-items: baseline; padding-top: var(--space-3); margin-top: .25rem; }
.order-summary .os-total b { font-family: var(--font-display); font-size: var(--text-xl); color: var(--forest-700); }
.order-summary .os-note { font-size: var(--text-xs); color: var(--color-fg-muted); margin-top: var(--space-2); }
/* Zahlungsarten */
.pay-options { display: grid; gap: .6rem; }
.pay-option { display: flex; align-items: center; gap: .7rem; padding: .8rem 1rem; border: 1px solid var(--color-border); cursor: pointer; transition: border-color .2s var(--ease), background .2s var(--ease); }
.pay-option:hover { border-color: var(--brass-500); }
.pay-option input { width: auto; margin: 0; accent-color: var(--forest-700); }
.pay-option:has(input:checked) { border-color: var(--forest-700); background: var(--cream-100); }
.pay-option .po-label { font-weight: 600; }
.pay-option .po-sub { font-size: var(--text-xs); color: var(--color-fg-muted); }
/* „Zahlungspflichtig bestellen"-Button mit Schloss */
.btn-checkout svg.lock { width: 16px; height: 16px; }

/* ===== Refinement #30 — Warenkorb (nur in dieser Variante) ===== */
/* Header-Icon + Zähler */
.cart-link { position: relative; display: inline-grid; place-items: center; width: 44px; height: 44px; color: inherit; transition: color .35s var(--ease); }
.site-header:not(.scrolled) .cart-link { color: var(--cream-50); }
.site-header.scrolled .cart-link { color: var(--ink-900); }
.cart-link svg { width: 24px; height: 24px; }
.cart-badge { position: absolute; top: 3px; right: 1px; min-width: 18px; height: 18px; padding: 0 4px; background: var(--brass-500); color: var(--forest-900); font-size: .66rem; font-weight: 700; line-height: 1; display: grid; place-items: center; border-radius: var(--radius-pill); }
.cart-badge[hidden] { display: none; }
/* Toast */
.cart-toast { position: fixed; left: 50%; bottom: 24px; transform: translate(-50%, 24px); z-index: 3000; display: flex; align-items: center; gap: .6rem; background: var(--forest-700); color: var(--cream-50); padding: .85rem 1.2rem; box-shadow: var(--shadow); font-size: var(--text-sm); max-width: 92vw; opacity: 0; visibility: hidden; transition: opacity .3s var(--ease), transform .3s var(--ease), visibility .3s; }
.cart-toast.show { opacity: 1; visibility: visible; transform: translate(-50%, 0); }
.cart-toast svg { width: 18px; height: 18px; flex: none; color: var(--brass-400); }
.cart-toast a { color: var(--brass-400); text-decoration: underline; white-space: nowrap; }
@media (prefers-reduced-motion: reduce) { .cart-toast { transition: opacity .2s; } }
/* Warenkorb-Seite */
.cart-list { border-top: 1px solid var(--color-border); margin-bottom: var(--space-4); }
.cart-row { display: grid; grid-template-columns: 1fr auto auto auto; gap: var(--space-4); align-items: center; padding: var(--space-3) 0; border-bottom: 1px solid var(--color-border); }
.cart-row__title { font-family: var(--font-display); font-size: var(--text-md); }
.cart-row__unit { font-size: var(--text-xs); color: var(--color-fg-muted); }
.cart-qty { display: inline-flex; align-items: center; border: 1px solid var(--color-border); }
.cart-qty button { width: 34px; height: 34px; background: none; border: none; cursor: pointer; font-size: 1.1rem; color: var(--ink-700); }
.cart-qty button:hover { background: var(--cream-100); }
.cart-qty span { min-width: 2.2ch; text-align: center; font-variant-numeric: tabular-nums; }
.cart-row__price { font-family: var(--font-display); font-variant-numeric: tabular-nums; min-width: 6ch; text-align: right; }
.cart-row__rm { background: none; border: none; color: var(--ink-300); cursor: pointer; text-decoration: underline; font-size: var(--text-sm); }
.cart-row__rm:hover { color: #9A3B26; }
.cart-foot { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; margin-top: var(--space-4); }
.cart-total { font-family: var(--font-display); font-size: var(--text-xl); }
.cart-total b { color: var(--forest-700); }
.cart-empty { text-align: center; padding: var(--space-6) 0; color: var(--color-fg-muted); }
@media (max-width: 600px) {
  .cart-row { grid-template-columns: 1fr auto; row-gap: .6rem; }
  .cart-row__rm { grid-column: 1 / -1; justify-self: start; }
}

/* Termin-/Datumsauswahl vor dem Warenkorb-Button */
.buy-select { margin-bottom: var(--space-3); max-width: 24rem; }
.buy-select label { display: block; font-size: var(--text-sm); font-weight: 600; color: var(--ink-700); margin-bottom: .35rem; }
.buy-select select, .buy-select input { width: 100%; padding: .7rem .9rem; border: 1px solid var(--color-border); background: #fff; font: inherit; color: var(--ink-900); }
.buy-select select:focus, .buy-select input:focus { outline: none; border-color: var(--forest-700); }
.buy-select.is-invalid select, .buy-select.is-invalid input { border-color: #9A3B26; }
.buy-select.is-invalid::after { content: "Bitte einen Termin wählen."; display: block; color: #9A3B26; font-size: var(--text-xs); margin-top: .35rem; }

/* Kursfinder-Ergebnis: zwei CTAs (Direktkauf + Anfrage) je Termin */
.r-foot { align-items: flex-end; gap: var(--space-3); flex-wrap: wrap; }
.r-actions { display: flex; flex-direction: column; gap: .5rem; align-items: flex-end; }
.r-actions .btn { padding: .55rem .95rem; font-size: .82rem; }
.r-actions .link-arrow { font-size: var(--text-sm); }
@media (max-width: 600px) { .r-foot { align-items: stretch; } .r-actions { align-items: stretch; width: 100%; } .r-actions .btn { justify-content: center; } }
