/*
Theme Name: Somatic AnneHagenow
Theme URI: https://annehagenow.de
Author: Somatic Web (für Anne Hagenow M.A.)
Author URI: https://somatic-web.de
Description: Child-Theme von WP Draft für annehagenow.de. Geforkt aus somatic-aha v1.0.0. Brand-Tokens: warmes tiefes edles Navy + Gold + Sand/Greige. Komponenten-CSS unverändert übernommen — Brand-Anpassungen ausschliesslich im :root-Block (oben) und im BRAND-CUSTOM-Block (am Ende, Sektion 29).
Template: wpdraft
Version: 1.0.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 7.4
License: Proprietary
License URI: https://somatic-web.de
Text Domain: somatic-annehagenow
*/

/* =========================================================================
   SOMATIC ANNEHAGENOW — BEM Master Stylesheet
   Brand: annehagenow.de · Anne Hagenow M.A.
   Design-System-Quelle: ../../design-system/colors_and_type.css
   Voice: Du-Form. Brand-Shift 03.06.2026: warmes tiefes Blau + Gold + Sand/Greige.
   ========================================================================= */

/* === 0. WEBFONTS ========================================================= */
/* Playfair Display + Raleway lokal aus assets/fonts/ — DSGVO-konform, kein CDN. */

/* Playfair Display */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal; font-weight: 400; font-display: swap;
  src: url('assets/fonts/playfair-display-v40-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Playfair Display';
  font-style: italic; font-weight: 400; font-display: swap;
  src: url('assets/fonts/playfair-display-v40-latin-500italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal; font-weight: 500; font-display: swap;
  src: url('assets/fonts/playfair-display-v40-latin-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Playfair Display';
  font-style: italic; font-weight: 500; font-display: swap;
  src: url('assets/fonts/playfair-display-v40-latin-500italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal; font-weight: 600; font-display: swap;
  src: url('assets/fonts/playfair-display-v40-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Playfair Display';
  font-style: italic; font-weight: 600; font-display: swap;
  src: url('assets/fonts/playfair-display-v40-latin-500italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal; font-weight: 700; font-display: swap;
  src: url('assets/fonts/playfair-display-v40-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Playfair Display';
  font-style: italic; font-weight: 700; font-display: swap;
  src: url('assets/fonts/playfair-display-v40-latin-500italic.woff2') format('woff2');
}

/* Raleway */
@font-face {
  font-family: 'Raleway';
  font-style: normal; font-weight: 300; font-display: swap;
  src: url('assets/fonts/raleway-v37-latin-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Raleway';
  font-style: italic; font-weight: 300; font-display: swap;
  src: url('assets/fonts/raleway-v37-latin-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Raleway';
  font-style: normal; font-weight: 400; font-display: swap;
  src: url('assets/fonts/raleway-v37-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Raleway';
  font-style: italic; font-weight: 400; font-display: swap;
  src: url('assets/fonts/raleway-v37-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Raleway';
  font-style: normal; font-weight: 500; font-display: swap;
  src: url('assets/fonts/raleway-v37-latin-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Raleway';
  font-style: italic; font-weight: 500; font-display: swap;
  src: url('assets/fonts/raleway-v37-latin-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Raleway';
  font-style: normal; font-weight: 600; font-display: swap;
  src: url('assets/fonts/raleway-v37-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Raleway';
  font-style: italic; font-weight: 600; font-display: swap;
  src: url('assets/fonts/raleway-v37-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Raleway';
  font-style: normal; font-weight: 700; font-display: swap;
  src: url('assets/fonts/raleway-v37-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Raleway';
  font-style: italic; font-weight: 700; font-display: swap;
  src: url('assets/fonts/raleway-v37-latin-600.woff2') format('woff2');
}

/* === 1. DESIGN TOKENS ==================================================== */
/* annehagenow-Brand-Tokens. somatic-base-Variablennamen bleiben — Komponenten-CSS
   in Sektion 2 bis 28 referenziert diese Namen. Brand-Werte sind unten
   eingetragen. Zusätzlich: annehagenow-eigenes Namespace (--color-*, --text-*,
   --shadow-*, --space-xs..3xl, --radius-sm..2xl, --t-*) für Komponenten
   in Sektion 29 (BRAND-CUSTOM).
   --------------------------------------------------------------------- */
:root {
  /* ===== annehagenow Core-Palette (additional namespace für Brand-Custom) ===== */
  --color-navy:        #142A4A;
  --color-navy-deep:   #0C1D36;
  --color-navy-mid:    #1E3B66;

  --color-gold:        #C8A96E;
  --color-gold-dark:   #A8843E;
  --color-gold-light:  #E2C882;
  --color-gold-pale:   #EFE3C8;

  --color-cream:       #F2EBDD;
  --color-cream-dark:  #E8DFCF;
  --color-cream-soft:  #FBF7EE;

  --color-white:       #FFFFFF;
  --color-black:       #000000;

  /* ===== Sand/Greige-Aliase (für lesbaren Brand-Custom-Code) ===== */
  --color-sand:        #F2EBDD;
  --color-sand-soft:   #FBF7EE;
  --color-sand-dark:   #E8DFCF;
  --color-greige:      #D9CFBC;

  --color-text:        var(--color-navy);
  --color-text-soft:   #3A4A58;
  --color-text-muted:  #5B6E7E;
  --color-text-subtle: rgba(10, 37, 64, 0.52);

  --color-on-dark:        #FFFFFF;
  --color-on-dark-muted:  rgba(255, 255, 255, 0.72);
  --color-on-dark-subtle: rgba(255, 255, 255, 0.55);

  /* Forest-Variante (für Neurobalance / spätere Subseiten — aktuell nicht
     auf dieser Site, bleibt aber im Token-Set) */
  --color-forest:      #162F21;
  --color-forest-deep: #0F2018;
  --color-forest-mid:  #1D4230;
  --color-forest-soft: #244D38;
  --color-warm:        #F2ECE2;

  /* ===== somatic-base-Tokens mit annehagenow-Werten gefuellt =====
     (NICHT umbenennen — Komponenten-CSS in Sektion 2 bis 28 referenziert
     diese Namen.) */
  --crema:            #F2EBDD;                  /* = --color-cream (Sand/Greige) */
  --crema-pura:       #FBF7EE;                  /* = --color-cream-soft */
  --crema-profonda:   #E8DFCF;                  /* = --color-cream-dark */
  --caffelatte:       #EFE3C8;                  /* = --color-gold-pale (warmer Sekundärton) */
  --espresso:         #142A4A;                  /* = --color-navy (warmes Blau) */
  --espresso-tenue:   #3A4A58;                  /* = --color-text-soft */
  --ottone:           #C8A96E;                  /* = --color-gold */
  --ottone-scuro:     #A8843E;                  /* = --color-gold-dark */
  --ottone-chiaro:    #E2C882;                  /* = --color-gold-light */
  --linea:            rgba(20, 42, 74, 0.12);   /* Hairline aus warmem Navy */
  --oliva:            #6B7A3A;                  /* Success-Signal */
  --terracotta:       #B5532A;                  /* Error-Signal */

  /* Semantische Aliase (somatic-base-Struktur unveraendert) */
  --bg:               var(--crema);
  --bg-elevated:      var(--crema-pura);
  --bg-hover:         var(--crema-profonda);
  --bg-inverse:       var(--espresso);
  --fg:               var(--espresso);
  --fg-muted:         var(--espresso-tenue);
  --fg-inverse:       var(--crema-pura);
  --fg-accent:        var(--ottone-scuro);
  --border:           var(--linea);
  --border-strong:    var(--espresso-tenue);
  --border-accent:    var(--ottone);

  /* Schriften — Brand-Overrides */
  --font-display: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-body:    'Raleway', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* Type Scale Desktop */
  --fs-h1:        72px;
  --fs-h2:        48px;
  --fs-h3:        32px;
  --fs-h4:        24px;
  --fs-body-lg:   20px;
  --fs-body:      17px;
  --fs-small:     14px;
  --fs-label:     12px;

  /* Type Scale Mobile */
  --fs-h1-m:      40px;
  --fs-h2-m:      32px;
  --fs-h3-m:      24px;
  --fs-h4-m:      20px;
  --fs-body-lg-m: 18px;
  --fs-body-m:    16px;
  --fs-small-m:   13px;

  /* Line Heights */
  --lh-h1:        1.05;
  --lh-h2:        1.15;
  --lh-h3:        1.25;
  --lh-h4:        1.3;
  --lh-body:      1.6;
  --lh-tight:     1.4;

  /* Spacing (8px Grid — somatic-base-Standard) */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 16px;
  --space-4: 24px;
  --space-5: 32px;
  --space-6: 48px;
  --space-7: 64px;
  --space-8: 96px;
  --space-9: 128px;

  /* annehagenow-Spacing-Alias (für Brand-Custom-Sektion, T-Shirt-Sizing) */
  --space-xs:  8px;
  --space-sm:  16px;
  --space-md:  24px;
  --space-lg:  40px;
  --space-xl:  64px;
  --space-2xl: 96px;
  --space-3xl: 120px;

  /* Layout — Brand-Overrides */
  --container: 1280px;
  --reading:   780px;

  /* Radii — Brand-Overrides */
  --radius-sharp: 0;
  --radius:       8px;     /* annehagenow-Standard-Button (war 4px in somatic-base) */
  --radius-pill:  999px;
  /* annehagenow-spezifische Radien (für Brand-Custom-Sektion) */
  --radius-sm:    6px;
  --radius-md:    8px;
  --radius-lg:    10px;
  --radius-xl:    12px;
  --radius-2xl:   16px;

  /* Motion */
  --transition:      220ms ease-out;
  --transition-slow: 360ms ease-out;
  /* annehagenow-Alias */
  --t-fast: 0.2s ease;
  --t-base: 0.25s ease;
  --t-slow: 0.4s ease;

  /* Accent-Stroke — Brand-Overrides */
  --accent-stroke-w: 36px;   /* annehagenow Gold-Divider ist 36px (war 32px) */
  --accent-stroke-h: 1px;    /* annehagenow: 1px (war 2px) */

  /* annehagenow-Shadows (für Brand-Custom-Sektion) */
  --shadow-card:   0 4px 24px rgba(20, 42, 74, 0.06);
  --shadow-gold:   0 8px 28px rgba(200, 169, 110, 0.28);
  --shadow-deep:   0 24px 64px rgba(20, 42, 74, 0.18);
  --shadow-inset:  inset 0 1px 0 rgba(255, 255, 255, 0.04);

  /* Tracking-Konstanten (für Eyebrows / Caps) */
  --tracking-eyebrow: 0.18em;
  --tracking-caps:    0.08em;
  --tracking-wide:    0.22em;
}

/* Forest-Variante (Neurobalance / ggf. spaetere Subseiten via .theme-forest am body) */
.theme-forest {
  --color-navy:       var(--color-forest);
  --color-navy-deep:  var(--color-forest-deep);
  --color-navy-mid:   var(--color-forest-mid);
  --color-cream:      var(--color-warm);
  /* somatic-base-Aliase ziehen automatisch nach: */
  --espresso:         var(--color-forest);
  --crema:            var(--color-warm);
}

/* === 2. BASE / RESET ===================================================== */
*, *::before, *::after { box-sizing: border-box; }

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

body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-body);
  font-size: var(--fs-body-m);
  line-height: var(--lh-body);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

@media (min-width: 768px) {
  body { font-size: var(--fs-body); }
}

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

a {
  color: var(--fg-accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
  transition: color var(--transition), text-decoration-color var(--transition);
}
a:hover { color: var(--ottone-scuro); text-decoration-color: var(--ottone); }

:focus { outline: none; }
:focus-visible {
  outline: 2px solid var(--ottone-scuro);
  outline-offset: 3px;
  border-radius: var(--radius);
}

::selection { background: var(--ottone-chiaro); color: var(--espresso); }

hr { border: 0; border-top: 1px solid var(--border); margin: var(--space-5) 0; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    transition-duration: 0.001ms !important;
    animation-duration:  0.001ms !important;
    animation-iteration-count: 1 !important;
  }
}

/* === 3. TYPOGRAPHY ======================================================= */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  color: var(--fg);
  margin: 0 0 var(--space-3);
  font-weight: 600;
  letter-spacing: -0.01em;
}

h1 { font-size: var(--fs-h1-m); line-height: var(--lh-h1); letter-spacing: -0.02em; }
h2 { font-size: var(--fs-h2-m); line-height: var(--lh-h2); letter-spacing: -0.015em; }
h3 { font-size: var(--fs-h3-m); line-height: var(--lh-h3); }
h4 { font-size: var(--fs-h4-m); line-height: var(--lh-h4); }

@media (min-width: 768px) {
  h1 { font-size: var(--fs-h1); }
  h2 { font-size: var(--fs-h2); }
  h3 { font-size: var(--fs-h3); }
  h4 { font-size: var(--fs-h4); }
}

/* Editorial Accent: <em> in h1/h2 bleibt normal-weight, italic */
h1 em, h2 em {
  font-style: italic;
  font-weight: 400;
  color: inherit;
}

p { margin: 0 0 var(--space-3); max-width: 70ch; }

small, .text-small { font-size: var(--fs-small-m); }
@media (min-width: 768px) { small, .text-small { font-size: var(--fs-small); } }

strong, b { font-weight: 600; }

blockquote {
  margin: var(--space-5) 0;
  padding: 0 0 0 var(--space-4);
  border-left: 1px solid var(--border-accent);
  font-family: var(--font-display);
  font-size: var(--fs-body-lg-m);
  font-style: italic;
  color: var(--fg);
}
@media (min-width: 768px) { blockquote { font-size: var(--fs-body-lg); } }

/* === 4. CONTAINER ======================================================== */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--space-4);
}
@media (min-width: 1024px) {
  .container { padding-inline: var(--space-5); }
}

.container--narrow { max-width: var(--reading); }
.container--wide   { max-width: 1400px; }

/* === 5. SECTION ========================================================== */
.section {
  padding-block: var(--space-6);
  background: var(--bg);
}
@media (min-width: 768px)  { .section { padding-block: var(--space-7); } }
@media (min-width: 1024px) { .section { padding-block: var(--space-8); } }

.section--dense { padding-block: var(--space-5); }
@media (min-width: 1024px) { .section--dense { padding-block: var(--space-6); } }

.section--dark {
  background: var(--bg-inverse);
  color: var(--fg-inverse);
}
.section--dark h1,
.section--dark h2,
.section--dark h3,
.section--dark h4 { color: var(--fg-inverse); }
.section--dark a { color: var(--ottone-chiaro); }
.section--dark .eyebrow { color: var(--ottone-chiaro); }

.section--elevated { background: var(--bg-elevated); }

.section--hero {
  padding-block: var(--space-7) var(--space-6);
}
@media (min-width: 1024px) {
  .section--hero { padding-block: var(--space-9) var(--space-8); }
}

/* === 6. EYEBROW LABEL ==================================================== */
.eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--fs-label);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: var(--space-3);
}

/* === 7. ACCENT STROKE ==================================================== */
.accent-stroke {
  display: block;
  width: var(--accent-stroke-w);
  height: var(--accent-stroke-h);
  background: var(--border-accent);
  border: 0;
  margin: var(--space-3) 0 var(--space-4);
}
.accent-stroke--center  { margin-inline: auto; }
.accent-stroke--on-dark { background: var(--ottone-chiaro); }

/* === 8. BUTTONS ========================================================== */
.btn {
  --btn-bg:     var(--espresso);
  --btn-fg:     var(--crema-pura);
  --btn-border: var(--espresso);
  --btn-bg-h:   var(--espresso-tenue);

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 16px 32px;
  background: var(--btn-bg);
  color: var(--btn-fg);
  border: 1px solid var(--btn-border);
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--transition),
              color var(--transition),
              border-color var(--transition);
}
.btn:hover  { background: var(--btn-bg-h); color: var(--btn-fg); border-color: var(--btn-bg-h); }
.btn:active { transform: translateY(1px); }
.btn:disabled, .btn[aria-disabled="true"] {
  opacity: 0.5; cursor: not-allowed; pointer-events: none;
}

.btn--primary {
  --btn-bg: var(--espresso);
  --btn-fg: var(--crema-pura);
  --btn-border: var(--espresso);
  --btn-bg-h: var(--espresso-tenue);
}

.btn--secondary {
  --btn-bg: transparent;
  --btn-fg: var(--espresso);
  --btn-border: var(--espresso);
  --btn-bg-h: var(--espresso);
}
.btn--secondary:hover { color: var(--crema-pura); }

.btn--ghost {
  --btn-bg: transparent;
  --btn-fg: var(--fg);
  --btn-border: transparent;
  --btn-bg-h: var(--bg-hover);
  padding: 12px 20px;
}

.btn--on-dark {
  --btn-bg: var(--crema-pura);
  --btn-fg: var(--espresso);
  --btn-border: var(--crema-pura);
  --btn-bg-h: var(--crema);
}
.btn--on-dark.btn--secondary {
  --btn-bg: transparent;
  --btn-fg: var(--crema-pura);
  --btn-border: var(--crema-pura);
  --btn-bg-h: var(--crema-pura);
}
.btn--on-dark.btn--secondary:hover { color: var(--espresso); }

.btn--block { display: flex; width: 100%; }

.btn__icon { width: 18px; height: 18px; flex-shrink: 0; }

/* === 9. HERO ============================================================= */
.hero {
  --hero-headline: clamp(var(--fs-h1-m), 5vw + 1rem, var(--fs-h1));
  padding-block: var(--space-7);
}
@media (min-width: 1024px) { .hero { padding-block: var(--space-9) var(--space-8); } }

.hero__headline {
  font-family: var(--font-display);
  font-size: var(--hero-headline);
  line-height: var(--lh-h1);
  letter-spacing: -0.02em;
  font-weight: 600;
  margin: 0 0 var(--space-4);
  max-width: 18ch;
}

.hero__lede {
  font-size: var(--fs-body-lg-m);
  line-height: 1.5;
  color: var(--fg-muted);
  max-width: 56ch;
  margin: 0 0 var(--space-5);
}
@media (min-width: 768px) { .hero__lede { font-size: var(--fs-body-lg); } }

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.hero--dark { background: var(--bg-inverse); color: var(--fg-inverse); }
.hero--dark .hero__headline { color: var(--fg-inverse); }
.hero--dark .hero__lede     { color: var(--ottone-chiaro); }

.hero--split .hero__grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 1024px) {
  .hero--split .hero__grid {
    grid-template-columns: 1.1fr 0.9fr;
    gap: var(--space-7);
  }
}

.hero__media img,
.hero__media picture { border-radius: var(--radius); }

/* === 10. STATS BLOCK ===================================================== */
.stats {
  display: grid;
  gap: var(--space-4);
  grid-template-columns: 1fr;
  padding-block: var(--space-5);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
@media (min-width: 768px)  { .stats { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .stats { grid-template-columns: repeat(4, 1fr); gap: var(--space-5); } }

.stats__item { text-align: left; }
.stats--center .stats__item { text-align: center; }

.stats__value {
  font-family: var(--font-display);
  font-size: var(--fs-h2-m);
  line-height: 1;
  color: var(--fg);
  display: block;
  margin-bottom: var(--space-2);
  font-weight: 600;
}
@media (min-width: 1024px) { .stats__value { font-size: var(--fs-h2); } }

.stats__label {
  font-size: var(--fs-small-m);
  color: var(--fg-muted);
  letter-spacing: 0.04em;
}
@media (min-width: 768px) { .stats__label { font-size: var(--fs-small); } }

/* === 11. PROCESS STEPS =================================================== */
.process {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 768px)  { .process { grid-template-columns: repeat(2, 1fr); gap: var(--space-6); } }
@media (min-width: 1024px) { .process { grid-template-columns: repeat(4, 1fr); } }

.process__step {
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
}

.process__number {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  letter-spacing: 0.12em;
  color: var(--fg-accent);
  margin-bottom: var(--space-3);
  font-style: italic;
  font-weight: 400;
}

.process__title {
  font-family: var(--font-display);
  font-size: var(--fs-h4-m);
  line-height: var(--lh-h4);
  margin: 0 0 var(--space-2);
}
@media (min-width: 768px) { .process__title { font-size: var(--fs-h4); } }

.process__text {
  color: var(--fg-muted);
  font-size: var(--fs-body-m);
  margin: 0;
}
@media (min-width: 768px) { .process__text { font-size: var(--fs-body); } }

/* === 12. CARD ============================================================ */
.card {
  --card-bg:     var(--bg-elevated);
  --card-fg:     var(--fg);
  --card-border: transparent;
  --card-pad:    var(--space-4);

  background: var(--card-bg);
  color: var(--card-fg);
  border: 1px solid var(--card-border);
  border-radius: var(--radius);
  padding: var(--card-pad);
  transition: border-color var(--transition), background-color var(--transition);
}
@media (min-width: 768px) { .card { --card-pad: var(--space-5); } }

.card__eyebrow { margin-bottom: var(--space-2); }

.card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  background: var(--bg);
  border-radius: var(--radius);
  margin-bottom: var(--space-3);
  color: var(--fg-accent);
}
.card__icon svg { width: 24px; height: 24px; }

.card__title {
  font-family: var(--font-display);
  font-size: var(--fs-h4-m);
  line-height: var(--lh-h4);
  margin: 0 0 var(--space-2);
}
@media (min-width: 768px) { .card__title { font-size: var(--fs-h4); } }

.card__text { color: var(--fg-muted); margin: 0 0 var(--space-3); }
.card__text:last-child { margin-bottom: 0; }

.card__actions { margin-top: var(--space-4); display: flex; gap: var(--space-3); flex-wrap: wrap; }

.card--bordered { --card-border: var(--border); --card-bg: transparent; }
.card--elevated { --card-border: var(--border); }
.card--dark     { --card-bg: var(--bg-inverse); --card-fg: var(--fg-inverse); }
.card--dark .card__title { color: var(--fg-inverse); }
.card--dark .card__text  { color: var(--ottone-chiaro); }

.card--interactive { cursor: pointer; }
.card--interactive:hover { --card-border: var(--border-strong); }
.card--interactive:has(a:focus-visible) { --card-border: var(--ottone-scuro); }

/* === 13. CARD GRID ======================================================= */
.card-grid {
  display: grid;
  gap: var(--space-4);
  grid-template-columns: 1fr;
}
@media (min-width: 768px) { .card-grid { gap: var(--space-5); } }

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

@media (min-width: 768px)  { .card-grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .card-grid--3 { grid-template-columns: repeat(3, 1fr); } }

@media (min-width: 768px)  { .card-grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .card-grid--4 { grid-template-columns: repeat(4, 1fr); } }

/* === 14. PRICING CARD ==================================================== */
.pricing-card {
  --pc-bg:     var(--bg-elevated);
  --pc-border: var(--border);
  --pc-fg:     var(--fg);

  display: flex;
  flex-direction: column;
  background: var(--pc-bg);
  color: var(--pc-fg);
  border: 1px solid var(--pc-border);
  border-radius: var(--radius);
  padding: var(--space-5);
  transition: border-color var(--transition);
}
@media (min-width: 1024px) { .pricing-card { padding: var(--space-6); } }

.pricing-card__tier {
  font-family: var(--font-body);
  font-size: var(--fs-label);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin: 0 0 var(--space-3);
}

.pricing-card__price {
  font-family: var(--font-display);
  font-size: var(--fs-h2-m);
  line-height: 1;
  margin: 0 0 var(--space-2);
  letter-spacing: -0.02em;
  font-weight: 600;
}
@media (min-width: 1024px) { .pricing-card__price { font-size: var(--fs-h2); } }

.pricing-card__price-suffix {
  font-family: var(--font-body);
  font-size: var(--fs-small);
  color: var(--fg-muted);
  font-weight: 400;
  letter-spacing: 0;
}

.pricing-card__description {
  color: var(--fg-muted);
  margin: 0 0 var(--space-4);
  font-size: var(--fs-body-m);
}

.pricing-card__features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  border-top: 1px solid var(--border);
  padding-top: var(--space-4);
}

.pricing-card__feature {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: var(--fs-body-m);
  line-height: var(--lh-body);
}
.pricing-card__feature-icon {
  width: 18px; height: 18px; flex-shrink: 0;
  color: var(--fg-accent);
  margin-top: 4px;
}

.pricing-card__cta { margin-top: auto; }

.pricing-card--highlighted {
  --pc-bg: var(--bg-inverse);
  --pc-fg: var(--fg-inverse);
  --pc-border: var(--espresso);
}
.pricing-card--highlighted .pricing-card__tier         { color: var(--ottone-chiaro); }
.pricing-card--highlighted .pricing-card__description  { color: var(--ottone-chiaro); }
.pricing-card--highlighted .pricing-card__features     { border-top-color: var(--espresso-tenue); }
.pricing-card--highlighted .pricing-card__feature-icon { color: var(--ottone-chiaro); }

/* === 15. TESTIMONIAL ===================================================== */
.testimonial {
  padding: var(--space-5);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-elevated);
}
@media (min-width: 1024px) { .testimonial { padding: var(--space-6); } }

.testimonial__stars {
  display: inline-flex;
  gap: 2px;
  color: var(--ottone);
  margin-bottom: var(--space-3);
}
.testimonial__stars svg { width: 16px; height: 16px; fill: currentColor; stroke: none; }

.testimonial__quote {
  font-family: var(--font-display);
  font-size: var(--fs-body-lg-m);
  line-height: 1.5;
  font-style: italic;
  margin: 0 0 var(--space-4);
  color: var(--fg);
}
@media (min-width: 768px) { .testimonial__quote { font-size: var(--fs-body-lg); } }

.testimonial__attribution {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
}

.testimonial__avatar {
  width: 48px; height: 48px;
  border-radius: var(--radius-pill);
  object-fit: cover;
  flex-shrink: 0;
}

.testimonial__author {
  display: block;
  font-weight: 600;
  font-size: var(--fs-body-m);
  color: var(--fg);
  margin: 0;
}

.testimonial__role {
  display: block;
  font-size: var(--fs-small-m);
  color: var(--fg-muted);
  margin: 0;
}
@media (min-width: 768px) { .testimonial__role { font-size: var(--fs-small); } }

/* === 16. FAQ ACCORDION (native <details>/<summary>) ====================== */
.faq { display: flex; flex-direction: column; }

.faq__item {
  border-top: 1px solid var(--border);
}
.faq__item:last-child { border-bottom: 1px solid var(--border); }

.faq__question { list-style: none; }
.faq__question::-webkit-details-marker { display: none; }
.faq__question::marker { content: ""; }

.faq__question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) 0;
  cursor: pointer;
  font-family: var(--font-display);
  font-size: var(--fs-h4-m);
  line-height: var(--lh-h4);
  color: var(--fg);
  font-weight: 600;
  transition: color var(--transition);
}
@media (min-width: 768px) { .faq__question { font-size: var(--fs-h4); padding: var(--space-5) 0; } }

.faq__question:hover { color: var(--fg-accent); }
.faq__question:focus-visible {
  outline: 2px solid var(--ottone-scuro);
  outline-offset: 4px;
}

.faq__question::after {
  content: "";
  width: 12px;
  height: 12px;
  flex-shrink: 0;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  transition: transform var(--transition);
}
.faq__item[open] > .faq__question::after { transform: rotate(-135deg) translateY(-2px); }

.faq__answer {
  padding: 0 0 var(--space-5);
  color: var(--fg-muted);
  font-size: var(--fs-body-m);
  line-height: var(--lh-body);
  max-width: 70ch;
}
@media (min-width: 768px) { .faq__answer { font-size: var(--fs-body); } }
.faq__answer > :last-child { margin-bottom: 0; }

/* Progressive Enhancement: details-content Animation wo unterstützt */
@supports (interpolate-size: allow-keywords) {
  :root { interpolate-size: allow-keywords; }
  .faq__item::details-content {
    block-size: 0;
    overflow: clip;
    opacity: 0;
    transition: block-size var(--transition-slow),
                opacity var(--transition),
                content-visibility var(--transition-slow) allow-discrete;
  }
  .faq__item[open]::details-content {
    block-size: auto;
    opacity: 1;
  }
}

/* === 17. CTA BLOCK ======================================================= */
.cta-block {
  text-align: center;
  padding: var(--space-6) var(--space-4);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
@media (min-width: 1024px) { .cta-block { padding: var(--space-8) var(--space-6); } }

.cta-block--dark {
  background: var(--bg-inverse);
  color: var(--fg-inverse);
  border-color: var(--espresso);
}
.cta-block--dark .cta-block__title { color: var(--fg-inverse); }
.cta-block--dark .cta-block__text  { color: var(--ottone-chiaro); }

.cta-block__title {
  font-family: var(--font-display);
  font-size: var(--fs-h2-m);
  line-height: var(--lh-h2);
  margin: 0 auto var(--space-3);
  max-width: 20ch;
}
@media (min-width: 1024px) { .cta-block__title { font-size: var(--fs-h2); } }

.cta-block__text {
  color: var(--fg-muted);
  max-width: 56ch;
  margin: 0 auto var(--space-5);
  font-size: var(--fs-body-lg-m);
}
@media (min-width: 768px) { .cta-block__text { font-size: var(--fs-body-lg); } }

.cta-block__actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: center;
}

/* === 18. CONTACT INFO ==================================================== */
.contact-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  list-style: none;
  padding: 0;
  margin: 0;
}

.contact-info__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--fs-body-m);
  color: var(--fg);
}
@media (min-width: 768px) { .contact-info__item { font-size: var(--fs-body); } }

.contact-info__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  color: var(--fg-accent);
  background: var(--bg-elevated);
  border-radius: var(--radius);
}
.contact-info__icon svg { width: 20px; height: 20px; }

.contact-info__label {
  display: block;
  font-size: var(--fs-label);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 2px;
}

.contact-info__value { color: var(--fg); }
.contact-info__value a { color: inherit; text-decoration-color: var(--border-accent); }

/* === 19. NEWSLETTER ====================================================== */
.newsletter {
  padding: var(--space-5);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-elevated);
}
@media (min-width: 1024px) { .newsletter { padding: var(--space-6); } }

.newsletter--inline {
  background: transparent;
  border: 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  border-radius: 0;
}

.newsletter__title {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  margin: 0 0 var(--space-2);
}

.newsletter__text {
  color: var(--fg-muted);
  margin: 0 0 var(--space-4);
  font-size: var(--fs-body-m);
}

.newsletter__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
@media (min-width: 768px) {
  .newsletter__form { flex-direction: row; align-items: stretch; }
}

.newsletter__input {
  flex: 1 1 auto;
  padding: 14px 16px;
  font-family: var(--font-body);
  font-size: var(--fs-body-m);
  color: var(--fg);
  background: var(--bg);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  transition: border-color var(--transition);
}
.newsletter__input::placeholder { color: var(--fg-muted); }
.newsletter__input:focus-visible {
  outline: 2px solid var(--ottone-scuro);
  outline-offset: 2px;
  border-color: var(--espresso);
}

/* === 20. AUTHOR / CURATOR TAG ============================================ */
.author-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 6px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  background: var(--bg-elevated);
  font-size: var(--fs-label);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-muted);
  font-weight: 600;
}
.author-tag__avatar {
  width: 20px; height: 20px;
  border-radius: var(--radius-pill);
  object-fit: cover;
}
.author-tag__name { color: var(--fg); }

.author-tag--quiet { border-color: transparent; background: transparent; padding-inline: 0; }

/* === 21. HAIRLINE DIVIDER ================================================ */
.hairline {
  border: 0;
  border-top: 1px solid var(--border);
  margin: var(--space-5) 0;
  height: 0;
}
.hairline--strong { border-top-color: var(--border-strong); }
.hairline--short  { width: 64px; }
.hairline--center { margin-inline: auto; }

/* === 22. IMAGES ========================================================== */
.image--rounded { border-radius: var(--radius); }
.image--avatar {
  border-radius: var(--radius-pill);
  width: 96px; height: 96px;
  object-fit: cover;
}
.image--full  { width: 100%; height: auto; display: block; }
.image--frame { border: 1px solid var(--border); border-radius: var(--radius); padding: var(--space-2); background: var(--bg-elevated); }

/* === 23. FORM FIELDS ===================================================== */
.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.form-field__label {
  font-size: var(--fs-label);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
  font-weight: 600;
}

.form-field__input,
.form-field__textarea,
.form-field__select {
  padding: 12px 14px;
  font-family: var(--font-body);
  font-size: var(--fs-body-m);
  color: var(--fg);
  background: var(--bg);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  transition: border-color var(--transition);
  width: 100%;
}
.form-field__textarea { min-height: 140px; resize: vertical; }

.form-field__input:focus-visible,
.form-field__textarea:focus-visible,
.form-field__select:focus-visible {
  outline: 2px solid var(--ottone-scuro);
  outline-offset: 2px;
  border-color: var(--espresso);
}

.form-field__hint  { font-size: var(--fs-small-m); color: var(--fg-muted); }
.form-field__error { font-size: var(--fs-small-m); color: var(--terracotta); font-weight: 600; }

.form-field:has(:user-invalid) .form-field__input,
.form-field:has(:user-invalid) .form-field__textarea {
  border-color: var(--terracotta);
}

/* === 24. HEADER & NAV ==================================================== */
.site-header {
  position: relative;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding-block: var(--space-3);
}

.site-header__brand {
  font-family: var(--font-display);
  font-size: var(--fs-h4-m);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fg);
  text-decoration: none;
}
@media (min-width: 768px) { .site-header__brand { font-size: var(--fs-h4); } }

.site-nav { display: none; }
@media (min-width: 1024px) {
  .site-nav { display: flex; align-items: center; gap: var(--space-5); }
}

.site-nav__list {
  list-style: none;
  display: flex;
  gap: var(--space-5);
  margin: 0;
  padding: 0;
}
.site-nav__link {
  font-size: var(--fs-small);
  letter-spacing: 0.04em;
  color: var(--fg);
  text-decoration: none;
  padding: var(--space-2) 0;
  border-bottom: 1px solid transparent;
  transition: color var(--transition), border-color var(--transition);
}
.site-nav__link:hover,
.site-nav__link[aria-current="page"] {
  color: var(--fg-accent);
  border-bottom-color: var(--border-accent);
}

.menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--fg);
  cursor: pointer;
  transition: background-color var(--transition), border-color var(--transition);
}
.menu-toggle:hover { background: var(--bg-hover); border-color: var(--border-strong); }
@media (min-width: 1024px) { .menu-toggle { display: none; } }

.menu-toggle__bar {
  display: block;
  width: 18px;
  height: 1.5px;
  background: currentColor;
  position: relative;
}
.menu-toggle__bar::before,
.menu-toggle__bar::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 1.5px;
  background: currentColor;
  transition: transform var(--transition), top var(--transition);
}
.menu-toggle__bar::before { top: -6px; }
.menu-toggle__bar::after  { top:  6px; }

.menu-toggle[aria-expanded="true"] .menu-toggle__bar { background: transparent; }
.menu-toggle[aria-expanded="true"] .menu-toggle__bar::before { top: 0; transform: rotate(45deg); }
.menu-toggle[aria-expanded="true"] .menu-toggle__bar::after  { top: 0; transform: rotate(-45deg); }

.site-nav--mobile {
  display: none;
  position: absolute;
  inset: 100% 0 auto 0;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  padding: var(--space-4);
  z-index: 50;
}
.site-header:has(.menu-toggle[aria-expanded="true"]) .site-nav--mobile { display: block; }
@media (min-width: 1024px) { .site-nav--mobile { display: none !important; } }

.site-nav--mobile .site-nav__list { flex-direction: column; gap: var(--space-3); }

/* === 25. FOOTER ========================================================== */
.site-footer {
  background: var(--bg-inverse);
  color: var(--fg-inverse);
  padding-block: var(--space-7) var(--space-5);
  font-size: var(--fs-small-m);
}
@media (min-width: 768px) { .site-footer { font-size: var(--fs-small); } }

.site-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 768px)  { .site-footer__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .site-footer__grid { grid-template-columns: repeat(4, 1fr); gap: var(--space-6); } }

.site-footer__column { display: flex; flex-direction: column; gap: var(--space-3); }

.site-footer__heading {
  font-family: var(--font-body);
  font-size: var(--fs-label);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ottone-chiaro);
  margin: 0 0 var(--space-2);
  font-weight: 600;
}

.site-footer__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-2); }

.site-footer a {
  color: var(--crema-pura);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--transition), color var(--transition);
}
.site-footer a:hover { color: var(--ottone-chiaro); border-bottom-color: var(--ottone); }

.site-footer__bottom {
  margin-top: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid var(--espresso-tenue);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  color: var(--ottone-chiaro);
}
@media (min-width: 768px) {
  .site-footer__bottom { flex-direction: row; justify-content: space-between; align-items: center; }
}

/* === 26. ICON UTILITIES (für inline Lucide SVG) ========================== */
.icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  vertical-align: -0.125em;
}
.icon--sm { font-size: 16px; }
.icon--md { font-size: 20px; }
.icon--lg { font-size: 24px; }
.icon--xl { font-size: 32px; }

/* === 27. ACCESSIBILITY HELPERS =========================================== */
.visually-hidden,
.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0);
  white-space: nowrap; border: 0;
}

.skip-link {
  position: absolute;
  top: -100px;
  left: var(--space-3);
  padding: 12px 16px;
  background: var(--espresso);
  color: var(--crema-pura);
  font-weight: 600;
  text-decoration: none;
  z-index: 100;
  border-radius: var(--radius);
  transition: top var(--transition);
}
.skip-link:focus-visible { top: var(--space-3); }

/* === 28. PRINT =========================================================== */
@media print {
  :root {
    --bg: #fff;
    --bg-elevated: #fff;
    --bg-inverse: #fff;
    --fg: #000;
    --fg-muted: #333;
    --fg-inverse: #000;
    --border: #999;
    --border-strong: #000;
  }
  body { background: #fff; color: #000; font-size: 11pt; line-height: 1.4; }
  .site-header, .site-footer, .menu-toggle, .site-nav,
  .newsletter, .cta-block, .hero__actions {
    display: none !important;
  }
  .section, .section--dark { background: #fff !important; color: #000 !important; padding-block: 12pt; }
  h1, h2, h3, h4 { color: #000 !important; page-break-after: avoid; }
  p, blockquote, .card, .pricing-card { page-break-inside: avoid; orphans: 3; widows: 3; }
  a { color: #000; text-decoration: underline; }
  a[href^="http"]::after { content: " (" attr(href) ")"; font-size: 9pt; color: #555; }
  .btn { border: 1px solid #000 !important; background: #fff !important; color: #000 !important; padding: 4pt 8pt; }
  .faq__item > .faq__answer { display: block; padding: 4pt 0 8pt; }
  .faq__question::after { display: none; }
}

/* === 29. BRAND-CUSTOM (annehagenow.de) ============================= */
/* annehagenow-spezifische Patterns aus dem Claude-Design-System, die der
   somatic-base-Default nicht abdeckt. Nicht in Sektion 2 bis 28 einmischen.
   Quellen: design-system/colors_and_type.css + ui_kits/website/*.jsx
   --------------------------------------------------------------------- */

/* ----- Hero-Headline (Playfair 700, fluide, mit Italic-Gold-Akzent) ----- */
.h-hero {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2.5rem, 5.6vw, 4.625rem);   /* 40 → 74px */
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--color-on-dark);
  margin: 0;
}
.h-hero em { font-style: italic; color: var(--color-gold-light); font-weight: 400; }

/* ----- Brand-Headings (Playfair, mit Italic-Gold-Akzent via <em>) -----
   somatic-base verwendet sans-serif als Default für h1/h2 (font-display = font-body).
   Hier ueberschreiben wir mit Brand-Playfair fuer alle Brand-Sektionen. */
.h1, .h2, .h3 {
  font-family: var(--font-display);
  color: var(--color-navy);
  font-weight: 400;
  letter-spacing: -0.005em;
}
.h1 { font-size: clamp(2rem,   4vw,  3rem);     line-height: 1.2;  margin: 0 0 var(--space-md); }
.h2 { font-size: clamp(1.75rem, 3vw, 2.625rem); line-height: 1.25; margin: 0 0 var(--space-md); }
.h3 { font-size: clamp(1.375rem, 2vw, 1.625rem); line-height: 1.3; font-weight: 500; margin: 0 0 var(--space-sm); }
.h1 em, .h2 em, .h3 em { font-style: italic; color: var(--color-gold); font-weight: 400; }

/* Dark-Surface-Override fuer .h1/.h2/.h3 in Sektion .section--dark */
.section--dark .h1, .section--dark .h2, .section--dark .h3 { color: var(--color-on-dark); }
.section--dark .h1 em, .section--dark .h2 em, .section--dark .h3 em { color: var(--color-gold-light); }

/* ----- Eyebrow-Variants (Gold statt fg-muted) ----- */
.eyebrow {
  color: var(--color-gold);              /* override somatic-base default */
  font-weight: 700;
  letter-spacing: var(--tracking-eyebrow);
}
.eyebrow--on-dark { color: var(--color-gold-light); }
.eyebrow--muted   { color: var(--color-text-subtle); }

/* ----- Body / Lead / Caption / Signature / Italic-Quote ----- */
.lead {
  font-family: var(--font-body);
  font-size: clamp(1rem, 1.5vw, 1.25rem);   /* 16 → 20px */
  font-weight: 400;
  line-height: 1.7;
  color: var(--color-text-soft);
}
.body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--color-text);
}
.caption {
  font-family: var(--font-body);
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--color-text-muted);
}
.signature {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-text-subtle);
}
.quote-italic {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.125rem, 1.6vw, 1.375rem);
  line-height: 1.55;
  color: var(--color-text-soft);
}
.quote-italic--on-dark { color: var(--color-on-dark-muted); }

/* ----- Gold-Divider (36px Line) ----- */
.divider-gold {
  display: inline-block;
  width: 36px;
  height: 1px;
  background: var(--color-gold);
  border: 0;
  margin: var(--space-3) 0;
}
.divider-gold--center { display: block; margin-inline: auto; }

/* ----- Roman-Numeral (Playfair italic, gold, gross) ----- */
.roman {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 3rem;          /* 48px */
  color: var(--color-gold);
  line-height: 1;
}

/* ----- Section-Header (Eyebrow + Headline + Divider + Lead, mittig) ----- */
.section-header {
  text-align: center;
  max-width: 36rem;
  margin: 0 auto var(--space-7);
}

/* ----- Section-Background-Variants (Brand-Cream, Brand-Navy) -----
   somatic-base hat .section--dark mit --bg-inverse. Brand-spezifisch
   wollen wir explizit auf --color-cream und --color-navy, damit Sektionen
   konsistent benannt werden. */
.section--cream { background: var(--color-cream); }
.section--navy  { background: var(--color-navy); color: var(--color-on-dark); }
.section--navy .h1, .section--navy .h2, .section--navy .h3,
.section--navy h1, .section--navy h2, .section--navy h3 { color: var(--color-on-dark); }

/* ----- Button-Brand-Overrides (Gold-Gradient-Primary, Ghost auf Dark) -----
   Brand-Verbot in design-system/SKILL.md: keine Gradients — Ausnahme:
   der Gold-Button-Gradient und der Hero-Diagonal-Overlay. */
.btn-primary {
  background: linear-gradient(135deg, #C9A45A 0%, #E2C882 50%, #C8A050 100%);
  color: var(--color-navy);
  border: 1px solid transparent;
  box-shadow: var(--shadow-gold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  font-weight: 700;
  padding: 18px 36px;
  border-radius: var(--radius-md);
}
.btn-primary:hover { background: linear-gradient(135deg, #D4B070 0%, #ECD498 50%, #D2A862 100%); box-shadow: 0 12px 36px rgba(200, 169, 110, 0.40); }

.btn-secondary {
  background: transparent;
  color: var(--color-navy);
  border: 1px solid rgba(10, 37, 64, 0.20);
  font-weight: 500;
  padding: 18px 36px;
  border-radius: var(--radius-md);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
}
.btn-secondary:hover { background: rgba(10, 37, 64, 0.04); color: var(--color-navy); }

.btn-ghost {
  background: rgba(200, 169, 110, 0.12);
  color: var(--color-gold-light);
  border: 1px solid rgba(200, 169, 110, 0.35);
  border-radius: var(--radius-lg);
  padding: 16px 28px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.btn-ghost:hover { background: rgba(200, 169, 110, 0.18); color: var(--color-gold-light); border-color: rgba(200, 169, 110, 0.50); }

.btn-sm { padding: 14px 24px; font-size: 0.6875rem; }
.btn-lg { padding: 22px 44px; }

/* ----- Tag-Pills ----- */
.tag-pill {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-navy);
  background: transparent;
  border: 1px solid rgba(10, 37, 64, 0.20);
  border-radius: var(--radius-pill);
  padding: 8px 16px;
}
.tag-pill--gold {
  color: var(--color-navy);
  background: rgba(200, 169, 110, 0.18);
  border-color: rgba(200, 169, 110, 0.50);
}

/* ----- Cards (Cream-Default + Navy-Variant + Stat-Card) -----
   Ergaenzen somatic-base .card: Brand-spezifische Padding/Radius/Shadow. */
.card {
  background: var(--color-cream);
  border-radius: var(--radius-2xl);
  padding: clamp(1.75rem, 3vw, 3rem);
  box-shadow: var(--shadow-card);
  border: 0;
}
.card--navy {
  background: var(--color-navy);
  color: var(--color-on-dark);
  box-shadow: var(--shadow-deep);
}
.card--navy .h3, .card--navy h3 { color: var(--color-on-dark); }

.stat-card {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-lg) var(--space-md);
  box-shadow: var(--shadow-card);
  text-align: center;
}

/* ----- FAQ (Brand-Variant — italic Playfair Frage, Gold-Chevron) -----
   ergaenzt somatic-base .faq__item / .faq__question — die BEM-Bridge
   verwendet die kuerzeren annehagenow-Klassen .faq-item / .faq-answer / .chevron. */
.faq-item {
  border-bottom: 1px solid rgba(10, 37, 64, 0.10);
}
.faq-item summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  padding: 1.25rem 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.125rem;
  color: var(--color-navy);
  transition: color var(--t-fast);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { color: var(--color-gold-dark); }
.faq-item .chevron {
  display: inline-flex;
  transition: transform var(--t-base);
  color: var(--color-gold);
}
.faq-item[open] .chevron { transform: rotate(180deg); }
.faq-answer {
  padding: 0 0 1.25rem;
  color: var(--color-text-muted);
  max-width: 70ch;
}

/* ----- Form-Field (Brand-Cream-Backdrop, Gold-Focus-Ring) ----- */
.field {
  width: 100%;
  font-family: var(--font-body);
  font-size: 1rem;
  padding: 16px 20px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(10, 37, 64, 0.20);
  background: var(--color-white);
  color: var(--color-navy);
  transition: border var(--t-fast), box-shadow var(--t-fast);
}
.field:focus { outline: none; border-color: var(--color-gold); box-shadow: 0 0 0 3px rgba(200, 169, 110, 0.18); }
.field::placeholder { color: var(--color-text-muted); }

/* ----- Hero-Diagonal-Overlay (das EINE erlaubte Gradient-Pattern) ----- */
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg,
    rgba(10, 37, 64, 0)    0%,
    rgba(10, 37, 64, 0)    30%,
    rgba(10, 37, 64, 0.52) 58%,
    rgba(10, 37, 64, 0.88) 100%);
  z-index: 1;
  pointer-events: none;
}

/* ----- Container-Narrow-Override (Brand-Reading-Width 780px) -----
   somatic-base hat .container--narrow auf 680px. annehagenow-Brand braucht 780px. */
.container--narrow { max-width: var(--reading); }

/* ----- Brand-Utilities ----- */
.text-center { text-align: center; }
.bg-cream { background: var(--color-cream); }
.bg-cream-soft { background: var(--color-cream-soft); }
.bg-navy { background: var(--color-navy); color: var(--color-on-dark); }
.text-gold { color: var(--color-gold); }
.text-navy { color: var(--color-navy); }
.text-muted { color: var(--color-text-muted); }
.italic-em em { font-style: italic; color: var(--color-gold); font-weight: 400; }

/* ----- annehagenow Layout-Utilities (für Sektions-HTML statt inline styles) ----- */
.hero__actions--center { justify-content: center; }
.u-mt-5 { margin-top: var(--space-5); }
.u-mt-6 { margin-top: var(--space-6); }
.u-mb-7 { margin-bottom: var(--space-7); }
.u-my-7 { margin-top: var(--space-7); margin-bottom: var(--space-7); }
.calendly-embed {
  min-width: 320px;
  height: 750px;
}

/* ============================================================ */
/* ===== 30. ANNEHAGENOW HOT-FIXES (Lesbarkeit, Header, Footer) */
/* ============================================================ */

/* --- Dark Cards: Lesbarkeit aller Texte sicherstellen --- */
.card--dark,
.card--dark p,
.card--dark ul,
.card--dark li,
.card--dark span,
.card--dark .lead {
  color: var(--color-on-dark) !important;
}
.card--dark h1,
.card--dark h2,
.card--dark h3,
.card--dark h4 {
  color: var(--color-on-dark) !important;
}
.card--dark .tag-pill,
.card--dark .tag-pill--gold {
  color: var(--color-gold-light) !important;
  border-color: var(--color-gold) !important;
}

/* --- Pricing-Card highlighted (Reformation): weisser Text auf Navy --- */
.pricing-card--highlighted,
.pricing-card--highlighted p,
.pricing-card--highlighted ul,
.pricing-card--highlighted li,
.pricing-card--highlighted .lead {
  color: var(--color-on-dark) !important;
}
.pricing-card--highlighted h1,
.pricing-card--highlighted h2,
.pricing-card--highlighted h3,
.pricing-card--highlighted h4 {
  color: var(--color-on-dark) !important;
}
.pricing-card--highlighted .tag-pill,
.pricing-card--highlighted .tag-pill--gold {
  color: var(--color-gold-light) !important;
  border-color: var(--color-gold) !important;
}
.pricing-card--highlighted .text-gold,
.pricing-card--highlighted .h-hero {
  color: var(--color-gold-light) !important;
}
.pricing-card--highlighted .text-muted,
.pricing-card--highlighted .caption {
  color: rgba(255,255,255,0.72) !important;
}

/* --- Dark Sections: alle Headings + Body weiss --- */
.section--dark h1,
.section--dark h2,
.section--dark h3,
.section--dark h4,
.section--dark p,
.section--dark li,
.section--dark .lead,
.section--dark .hero__headline {
  color: var(--color-on-dark);
}
.section--dark .lead { color: var(--color-on-dark-muted); }
.section--dark .caption { color: rgba(255,255,255,0.65); }

/* --- Image-Hero Pattern: Text auf Background-Image weiss --- */
section[style*="#142A4A"] .hero__headline,
section[style*="#142A4A"] h1,
section[style*="#142A4A"] h2,
section[style*="#142A4A"] p,
section[style*="#142A4A"] .lead {
  color: var(--color-on-dark);
}
section[style*="#142A4A"] em { color: var(--color-gold-light); }

/* --- Hero Buttons auf dunklem Background --- */
.section--dark .btn--ghost,
section[style*="#142A4A"] .btn--ghost {
  color: var(--color-on-dark);
  border-color: rgba(255,255,255,0.5);
}
.section--dark .btn--ghost:hover,
section[style*="#142A4A"] .btn--ghost:hover {
  background: rgba(255,255,255,0.08);
  border-color: var(--color-gold);
}

/* ============================================================ */
/* ===== HEADER — AHA-Stil (groß, klar, präsent) =============== */
/* ============================================================ */
.site-header {
  background: var(--color-cream-soft);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--linea);
  position: sticky;
  top: 0;
  z-index: 100;
  transition: background var(--transition), box-shadow var(--transition);
}
.site-header.is-scrolled {
  background: rgba(251,247,238,0.96);
  backdrop-filter: blur(8px);
  box-shadow: 0 1px 0 var(--linea);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
}
.site-header__brand {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.01em;
  color: var(--color-navy);
  text-decoration: none;
  line-height: 1;
}
.site-header__brand:hover { color: var(--color-gold-dark); }

.site-nav { display: none; align-items: center; gap: var(--space-5); }
@media (min-width: 1024px) { .site-nav { display: flex; } }

.site-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: var(--space-5);
  align-items: center;
}
.site-nav__link {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-text);
  text-decoration: none;
  font-weight: 500;
  transition: color var(--transition);
  position: relative;
  padding: var(--space-2) 0;
}
.site-nav__link:hover { color: var(--color-gold-dark); }
.site-nav__link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 1px;
  background: var(--color-gold);
  transition: width var(--transition);
}
.site-nav__link:hover::after { width: 100%; }

.site-header .btn--primary {
  padding: 0.875rem 1.5rem;
  font-size: 0.8125rem;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  background: var(--color-navy);
  color: var(--color-on-dark);
  border: 1px solid var(--color-navy);
  border-radius: var(--radius);
  text-decoration: none;
  font-weight: 500;
  transition: background var(--transition), border-color var(--transition);
}
.site-header .btn--primary:hover {
  background: var(--color-gold-dark);
  border-color: var(--color-gold-dark);
}

/* Mobile Menu Toggle */
.menu-toggle { display: flex; }
@media (min-width: 1024px) { .menu-toggle { display: none; } }
.menu-toggle {
  background: none;
  border: none;
  padding: var(--space-2);
  cursor: pointer;
  flex-direction: column;
  gap: 5px;
  width: 32px;
  height: 32px;
  justify-content: center;
}
.menu-toggle__bar,
.menu-toggle::before,
.menu-toggle::after {
  content: '';
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--color-navy);
  transition: transform var(--transition);
}
.site-nav--mobile { display: none; }
.site-nav--mobile.is-open {
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 80px;
  left: 0;
  right: 0;
  background: var(--color-cream);
  padding: var(--space-5);
  gap: var(--space-3);
  border-top: 1px solid var(--linea);
  z-index: 99;
}
.site-nav--mobile.is-open .site-nav__list {
  flex-direction: column;
  align-items: stretch;
  width: 100%;
  gap: var(--space-3);
}

/* ============================================================ */
/* ===== FOOTER — AHA-Stil (Navy, 4 Spalten, edel) ============= */
/* ============================================================ */
.site-footer {
  background: var(--color-navy-deep);
  color: var(--color-on-dark);
  padding: var(--space-8) 0 var(--space-5);
  margin-top: var(--space-8);
}
.site-footer .container { max-width: 1280px; }

.site-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
@media (min-width: 768px) {
  .site-footer__grid {
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: var(--space-5);
  }
}

.site-footer__column { display: flex; flex-direction: column; gap: var(--space-3); }
.site-footer__heading {
  font-family: var(--font-body);
  font-size: 0.75rem;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-gold);
  margin: 0 0 var(--space-3);
  font-weight: 600;
}
.site-footer p {
  font-family: var(--font-body);
  font-size: 0.9375rem;
  line-height: 1.65;
  color: rgba(255,255,255,0.78);
  margin: 0;
}
.site-footer__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.site-footer__list li {
  font-family: var(--font-body);
  font-size: 0.9375rem;
  line-height: 1.5;
  color: rgba(255,255,255,0.78);
}
.site-footer__list a {
  color: rgba(255,255,255,0.78);
  text-decoration: none;
  transition: color var(--transition);
}
.site-footer__list a:hover { color: var(--color-gold-light); }
.site-footer__bottom {
  margin-top: var(--space-7);
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255,255,255,0.12);
  text-align: center;
  font-size: 0.8125rem;
  letter-spacing: var(--tracking-caps);
  color: rgba(255,255,255,0.55);
}


/* ============================================================ */
/* ===== 31. ANNEHAGENOW POLISH v3 (Buttons, Karten, Spacing) == */
/* ============================================================ */

/* --- Body-Font kleiner: Raleway 16px statt 17px Default --- */
body { font-size: 16px; }
.lead { font-size: 1rem; line-height: 1.65; }
@media (min-width: 768px) {
  body { font-size: 16px; }
  .lead { font-size: 1.0625rem; line-height: 1.65; }
}

/* --- card--dark: WIRKLICH navy als BG (Cards in der Format-Sektion) --- */
.card--dark {
  background: var(--color-navy-mid) !important;
  border: 1px solid rgba(255,255,255,0.06);
}
.card--dark h3,
.card--dark h4,
.card--dark .card__title {
  color: var(--color-on-dark) !important;
  font-weight: 500;
}
.card--dark p,
.card--dark .card__text {
  color: rgba(255,255,255,0.78) !important;
}

/* --- Karten gleiche Höhe innerhalb Card-Grid --- */
.card-grid {
  align-items: stretch;
}
.card-grid > .card,
.card-grid > .pricing-card,
.card-grid > article {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.card-grid > .card > *:last-child,
.card-grid > .pricing-card > *:last-child {
  margin-top: auto;
}
.card-grid .btn,
.card-grid .btn--block {
  margin-top: auto;
}

/* --- Pricing-Card highlighted: button muss sichtbar sein --- */
.pricing-card--highlighted .btn--primary,
.pricing-card--highlighted .btn {
  background: var(--color-gold) !important;
  color: var(--color-navy-deep) !important;
  border-color: var(--color-gold) !important;
}
.pricing-card--highlighted .btn--primary:hover {
  background: var(--color-gold-light) !important;
  border-color: var(--color-gold-light) !important;
}
.pricing-card--highlighted .btn--block {
  display: block;
  width: 100%;
  text-align: center;
}

/* --- Pricing-Card padding und equal heights --- */
.pricing-card {
  padding: var(--space-5) var(--space-4);
  display: flex;
  flex-direction: column;
  height: 100%;
}
@media (min-width: 768px) {
  .pricing-card { padding: var(--space-6) var(--space-5); }
}
.pricing-card ul { list-style: none; padding: 0; margin: 0 0 var(--space-4); }
.pricing-card li {
  padding: var(--space-2) 0;
  border-bottom: 1px solid rgba(20,42,74,0.08);
  font-size: 0.9375rem;
}
.pricing-card--highlighted li {
  border-bottom-color: rgba(255,255,255,0.1);
}

/* --- Buttons: konsistent, klar, sichtbar --- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.875rem 1.75rem;
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: var(--radius);
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
  line-height: 1.2;
}
.btn--primary {
  background: var(--color-navy);
  color: var(--color-on-dark);
  border-color: var(--color-navy);
}
.btn--primary:hover {
  background: var(--color-gold-dark);
  border-color: var(--color-gold-dark);
}
.btn--secondary {
  background: transparent;
  color: var(--color-navy);
  border-color: var(--color-navy);
}
.btn--secondary:hover {
  background: var(--color-navy);
  color: var(--color-on-dark);
}
.btn--ghost {
  background: transparent;
  border-color: var(--color-navy);
  color: var(--color-navy);
}
.btn--block {
  display: block;
  width: 100%;
  text-align: center;
}

/* --- CTA-Blocks: Button mittig --- */
.cta-block .btn,
.cta-block .hero__actions {
  margin-left: auto;
  margin-right: auto;
  justify-content: center;
}
.hero__actions--center,
.cta-block .hero__actions--center {
  justify-content: center;
}
.text-center > .btn,
.text-center > a.btn {
  display: inline-flex;
  margin: 0 auto;
}

/* --- Lese-Empfehlung Block: Buch-Layout --- */
.book-block {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
  align-items: center;
  background: var(--color-cream-dark);
  padding: var(--space-6);
  border-radius: var(--radius-md);
}
@media (min-width: 768px) {
  .book-block { grid-template-columns: 1fr 1.5fr; gap: var(--space-6); }
}
.book-block__cover {
  text-align: center;
}
.book-block__cover img {
  max-width: 240px;
  width: 100%;
  height: auto;
  box-shadow: var(--shadow-deep);
  border-radius: 4px;
}
@media (min-width: 768px) {
  .book-block__cover img { max-width: 280px; }
}
.book-block__content h2,
.book-block__content h3 { margin-top: 0; }

/* --- Sektion-Übergänge: dezenter Wechsel --- */
.section { padding-block: var(--space-7); }
@media (min-width: 768px) { .section { padding-block: var(--space-8); } }

.section--cream { background: var(--color-cream); }
.section--cream + .section--cream { padding-top: 0; }
.section--cream + .section,
.section + .section--cream,
.section + .section--dark {
  border-top: 1px solid var(--linea);
}
.section--dark + .section--dark { padding-top: 0; }

/* leichte alternierende Tönung */
section.section:nth-of-type(odd):not(.section--dark):not(.section--cream) {
  background: var(--color-cream-soft);
}

/* --- Hairline für Section-Trennung --- */
.section-divider {
  height: 1px;
  background: var(--linea);
  max-width: 80px;
  margin: 0 auto;
}

/* --- Section-Header: mehr Atmung --- */
.section-header {
  margin-bottom: var(--space-6);
}
.section-header h2 {
  margin-top: var(--space-2);
  margin-bottom: var(--space-4);
}

/* --- FAQ: bessere Lesbarkeit --- */
.faq-item {
  border-bottom: 1px solid var(--linea);
  padding: var(--space-4) 0;
}
.faq-item summary {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--color-navy);
  cursor: pointer;
  list-style: none;
  position: relative;
  padding-right: 32px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 0;
  font-size: 1.5rem;
  color: var(--color-gold);
  transition: transform var(--transition);
}
.faq-item[open] summary::after { content: '−'; }
.faq-answer {
  padding-top: var(--space-3);
  color: var(--color-text-soft);
  font-size: 0.9375rem;
  line-height: 1.65;
}

/* --- Testimonial-Cards: einheitliche Höhe + bessere Lesbarkeit --- */
.testimonial {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--color-cream-soft);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  border: 1px solid var(--linea);
}
.testimonial .quote-italic {
  font-style: italic;
  color: var(--color-text);
  font-size: 0.9375rem;
  line-height: 1.6;
  margin: 0 0 var(--space-4);
  flex: 1;
}
.testimonial .quote-italic--on-dark {
  color: var(--color-text);
  font-style: italic;
}
.section--dark .testimonial {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.1);
}
.section--dark .testimonial .quote-italic {
  color: rgba(255,255,255,0.92);
}
.testimonial .author-tag {
  font-size: 0.75rem;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-top: auto;
  font-style: normal;
}
.section--dark .testimonial .author-tag {
  color: rgba(255,255,255,0.55);
}

/* --- Container generell mehr Atmung --- */
@media (min-width: 1024px) {
  .container { padding-left: var(--space-5); padding-right: var(--space-5); }
}


/* ============================================================ */
/* ===== 32. ANNEHAGENOW v4 — Section-Backgrounds 4-Farben ===== */
/* ============================================================ */

/* Klare 4-Farben Section-Hierarchie:
   - default white/cream-soft  (#FBF7EE)
   - section--cream             beige  (#F2EBDD)
   - section--greige            greige (#E8DFCF)
   - section--dark              navy   (#142A4A)
   Übergänge: alternieren, nie zwei gleiche aufeinander.
*/

.section--greige {
  background: var(--color-cream-dark);
  color: var(--color-text);
}
.section--greige h1,
.section--greige h2,
.section--greige h3,
.section--greige h4 { color: var(--color-navy); }

/* Hairline-Trenner zwischen Sektionen (außer Dark→Dark) */
.section + .section { border-top: 1px solid rgba(20,42,74,0.06); }
.section--dark + .section--dark,
.section--dark + .section { border-top: 1px solid rgba(255,255,255,0.06); }
.section + .section--dark { border-top: 0; }

/* Subtile Gold-Akzentlinie zwischen Hero und erstem Section */
.section--hero + .section,
section[style*="#142A4A"] + .section {
  border-top: 0;
  position: relative;
}
.section--hero + .section::before,
section[style*="#142A4A"] + .section::before {
  content: '';
  display: block;
  width: 64px;
  height: 1px;
  background: var(--color-gold);
  margin: 0 auto var(--space-5);
}


/* ============================================================ */
/* ===== 33. ANNEHAGENOW v5 — Footer im Screenshot-Stil ======== */
/* ============================================================ */

.site-footer {
  background: var(--color-navy-deep);
  color: var(--color-on-dark);
  padding: var(--space-7) 0 var(--space-4);
  margin-top: var(--space-8);
}

/* Claim oben mit Gold-Diamant-Trenner */
.site-footer__claim {
  text-align: center;
  padding-bottom: var(--space-6);
  margin-bottom: var(--space-6);
}
.site-footer__claim-line {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.25rem, 2vw, 1.75rem);
  line-height: 1.4;
  color: var(--color-on-dark);
  margin: 0 0 var(--space-4);
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
}
.site-footer__claim-line em {
  color: var(--color-gold);
  font-style: italic;
  font-weight: 400;
}
.site-footer__diamond {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  max-width: 480px;
  margin: 0 auto;
}
.site-footer__diamond-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--color-gold) 50%, var(--color-gold) 100%);
}
.site-footer__diamond-line:last-child {
  background: linear-gradient(90deg, var(--color-gold) 0%, var(--color-gold) 50%, transparent 100%);
}
.site-footer__diamond-shape {
  color: var(--color-gold);
  font-size: 0.875rem;
  line-height: 1;
}

/* Grid 4 Spalten */
.site-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  padding-bottom: var(--space-6);
}
@media (min-width: 768px) {
  .site-footer__grid { grid-template-columns: 1.3fr 1fr 1fr 1.1fr; gap: var(--space-5); }
}

.site-footer__column { display: flex; flex-direction: column; }
.site-footer__heading {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-gold);
  margin: 0 0 var(--space-3);
  font-weight: 600;
  position: relative;
  padding-bottom: var(--space-2);
}
.site-footer__heading::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 24px;
  height: 1px;
  background: var(--color-gold);
  opacity: 0.6;
}

.site-footer__lead {
  font-family: var(--font-body);
  font-size: 0.875rem;
  line-height: 1.65;
  color: rgba(255,255,255,0.72);
  margin: 0 0 var(--space-4);
}

/* Contact-Liste mit Icons */
.site-footer__contact {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.site-footer__contact li {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  line-height: 1.55;
  color: rgba(255,255,255,0.72);
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
}
.site-footer__contact a {
  color: rgba(255,255,255,0.72);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--transition), color var(--transition);
}
.site-footer__contact a:hover {
  color: var(--color-gold-light);
  border-bottom-color: var(--color-gold-light);
}
.site-footer__icon {
  color: var(--color-gold);
  flex-shrink: 0;
  margin-top: 2px;
}

/* Standard-Liste mit Bullets */
.site-footer__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.site-footer__list li {
  font-family: var(--font-body);
  font-size: 0.875rem;
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
  position: relative;
  padding-left: 18px;
}
.site-footer__list li::before {
  content: '•';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-gold);
  font-size: 1rem;
  line-height: 1.4;
}
.site-footer__list a {
  color: rgba(255,255,255,0.78);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--transition), color var(--transition);
}
.site-footer__list a:hover {
  color: var(--color-gold-light);
  border-bottom-color: rgba(200,169,110,0.5);
}

/* Bücher-Liste: Icon statt Bullet */
.site-footer__list--books li {
  padding-left: 0;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.site-footer__list--books li::before { display: none; }
.site-footer__list--books .site-footer__icon {
  margin-top: 0;
}

/* CTA-Bereich rechts */
.site-footer__cta-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.2;
  color: var(--color-on-dark);
  margin: 0 0 var(--space-2);
}
.site-footer__cta-minutes {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: 1.125rem;
  color: var(--color-gold);
  margin: 0 0 var(--space-3);
}
.site-footer__cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  background: var(--color-gold);
  color: var(--color-navy-deep);
  font-family: var(--font-body);
  font-size: 0.75rem;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  font-weight: 600;
  padding: 0.875rem 1.25rem;
  text-decoration: none;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-3);
  transition: background var(--transition);
  border: 1px solid var(--color-gold);
}
.site-footer__cta-btn:hover {
  background: var(--color-gold-light);
}
.site-footer__cta-btn--ghost {
  background: transparent;
  color: var(--color-gold);
  border-color: rgba(200,169,110,0.4);
}
.site-footer__cta-btn--ghost:hover {
  background: rgba(200,169,110,0.08);
  border-color: var(--color-gold);
  color: var(--color-gold);
}

/* Bottom-Leiste */
.site-footer__bottom {
  border-top: 1px solid rgba(200,169,110,0.18);
  padding-top: var(--space-4);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  text-align: center;
  font-size: 0.75rem;
  letter-spacing: var(--tracking-caps);
  color: rgba(255,255,255,0.5);
}
@media (min-width: 768px) {
  .site-footer__bottom {
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    text-align: left;
  }
  .site-footer__bottom > p { margin: 0; }
}
.site-footer__legal {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: var(--space-3);
  justify-content: center;
}
.site-footer__legal a {
  color: rgba(255,255,255,0.55);
  text-decoration: none;
  letter-spacing: var(--tracking-caps);
}
.site-footer__legal a:hover { color: var(--color-gold-light); }
.site-footer__top {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-gold);
  text-decoration: none;
  justify-self: end;
  font-size: 0.75rem;
  letter-spacing: var(--tracking-caps);
}
.site-footer__top:hover { color: var(--color-gold-light); }


/* ============================================================ */
/* ===== 34. ANNEHAGENOW v6 — Mehr Weißraum, Hierarchie ======== */
/* ============================================================ */

/* section--breath: deutlich mehr Padding für Atmung */
.section--breath {
  padding-block: var(--space-8);
}
@media (min-width: 768px) {
  .section--breath { padding-block: var(--space-9); }
}

/* Kürzere, ruhigere Headlines auf Inhaltsseiten */
.section--breath h2 {
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  line-height: 1.2;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0 0 var(--space-4);
}
.section--breath .section-header {
  margin-bottom: var(--space-6);
}
.section--breath .eyebrow {
  margin-bottom: var(--space-3);
}

/* Outcomes-Grid (Was sich verändern kann) */
.outcomes-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  max-width: 720px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .outcomes-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-5);
  }
}
.outcomes-grid__item {
  font-family: var(--font-display);
  font-size: 1.125rem;
  line-height: 1.5;
  color: var(--color-navy);
  margin: 0;
  padding: var(--space-4) 0;
  border-bottom: 1px solid rgba(20,42,74,0.08);
}
.outcomes-grid__item em {
  color: var(--color-gold-dark);
  font-style: italic;
}

/* Themes-List (Womit wir arbeiten — 6 Bereiche) */
.themes-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  max-width: 880px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .themes-list { grid-template-columns: 1fr 1fr; gap: var(--space-5) var(--space-6); }
}
.themes-list__item {
  padding: var(--space-4) 0;
  border-bottom: 1px solid rgba(20,42,74,0.08);
}
.themes-list__item h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.375rem;
  line-height: 1.25;
  margin: 0 0 var(--space-2);
  color: var(--color-navy);
}
.themes-list__item p {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--color-text-soft);
  margin: 0;
}

/* How-List (So arbeiten wir) */
.how-list {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 560px;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.how-list li {
  position: relative;
  padding: var(--space-3) 0 var(--space-3) var(--space-5);
  border-bottom: 1px solid rgba(20,42,74,0.08);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.55;
  color: var(--color-navy);
}
.how-list li::before {
  content: '✦';
  position: absolute;
  left: 0;
  top: var(--space-3);
  color: var(--color-gold);
  font-size: 0.875rem;
}

/* Investment-Grid (zwei Wege) */
.investment-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  max-width: 640px;
  margin: var(--space-6) auto 0;
  align-items: center;
}
@media (min-width: 640px) {
  .investment-grid { grid-template-columns: 1fr auto 1fr; }
}
.investment-grid__item {
  text-align: center;
  padding: var(--space-5);
}
.investment-grid__label {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-gold);
  margin: 0 0 var(--space-2);
}
.investment-grid__price {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.5rem, 5vw, 3.5rem);
  line-height: 1;
  color: var(--color-on-dark);
  margin: 0 0 var(--space-2);
}
.investment-grid__note {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.6);
  margin: 0;
}
.investment-grid__divider {
  text-align: center;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  color: var(--color-gold);
  position: relative;
}
@media (min-width: 640px) {
  .investment-grid__divider {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 1px;
    background: rgba(200,169,110,0.3);
  }
  .investment-grid__divider span {
    background: var(--color-navy-deep);
    padding: 0 var(--space-3);
    display: inline-block;
  }
}

