/* ============================================================
   Lokale Schriften (selbst gehostet – keine Google-Verbindung)
   ============================================================ */
@font-face{font-family:'Fraunces';src:url('../assets/fonts/fraunces.woff2') format('woff2');font-weight:300 500;font-style:normal;font-display:swap;}
@font-face{font-family:'Fraunces';src:url('../assets/fonts/fraunces-italic.woff2') format('woff2');font-weight:300 500;font-style:italic;font-display:swap;}
@font-face{font-family:'Plus Jakarta Sans';src:url('../assets/fonts/jakarta.woff2') format('woff2');font-weight:400 700;font-style:normal;font-display:swap;}
@font-face{font-family:'Caveat';src:url('../assets/fonts/caveat.woff2') format('woff2');font-weight:400 700;font-style:normal;font-display:swap;}

/* ============================================================
   the becoming — Design System
   Aesthetik: "Licht & Weite" — warm, editorial, refined luxury
   ------------------------------------------------------------
   Schriften:  Fraunces (Display, warm & editorial)
               Plus Jakarta Sans (Body, klar & ruhig)
               Caveat (nur als handschriftlicher Signatur-Akzent)
   ============================================================ */

/* ---------- 1. Design Tokens ---------- */
:root {
  /* Farben */
  --navy:        #15303b;   /* tiefes Petrol-Navy, Markenfarbe   */
  --navy-deep:   #102530;   /* dunkler für Tiefe                 */
  --gold:        #bf9b54;   /* warmes Messing-Gold (Akzent)      */
  --gold-soft:   #d7bd86;   /* helleres Gold für Verläufe        */
  --gold-deep:   #a07f3c;   /* dunkleres Gold für Text auf Hell  */
  --cream:       #faf5ec;   /* warmes Papier (Haupt-Hintergrund) */
  --cream-2:     #f3ebdd;   /* zweite Sand-Ebene                 */
  --white:       #fffdf9;   /* nahezu weiß, warm                 */
  --ink:         #2a2722;   /* warmer Anthrazit (Fließtext)      */
  --ink-soft:    #5b554c;   /* gedämpfter Text                   */
  --line:        #e4d9c5;   /* Hairlines auf Hell                */
  --line-gold:   rgba(191,155,84,.45);

  /* Typografie */
  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body:    'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-script:  'Caveat', cursive;

  /* Raum */
  --wrap:      1180px;
  --wrap-text: 720px;
  --gutter:    clamp(1.25rem, 5vw, 3.5rem);
  --section-y: clamp(4.5rem, 11vw, 9.5rem);

  /* Sonstiges */
  --radius:    18px;
  --radius-lg: 28px;
  --shadow-sm: 0 2px 14px rgba(21,48,59,.06);
  --shadow:    0 18px 50px -22px rgba(21,48,59,.28);
  --shadow-lg: 0 40px 90px -40px rgba(21,48,59,.45);
  --ease:      cubic-bezier(.22,.61,.36,1);
}

/* ---------- 2. Reset & Basis ---------- */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }

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

body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.7;
  font-size: clamp(1rem, .55vw + .9rem, 1.075rem);
  font-weight: 400;
  letter-spacing: .002em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* dezente Papier-Textur über allem */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none; z-index: 1;
  opacity: .04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img { max-width: 100%; display: block; height: auto; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

/* ---------- 3. Typografie ---------- */
h1,h2,h3,h4 {
  font-family: var(--font-display);
  font-weight: 380;
  line-height: 1.08;
  letter-spacing: -.012em;
  color: var(--navy);
  font-optical-sizing: auto;
}

.display {
  font-size: clamp(2.6rem, 7vw, 5.4rem);
  font-weight: 340;
  line-height: 1.02;
}
.h-xl { font-size: clamp(2rem, 4.5vw, 3.4rem); }
.h-lg { font-size: clamp(1.7rem, 3.4vw, 2.6rem); }
.h-md { font-size: clamp(1.35rem, 2.2vw, 1.85rem); }

.serif-it { font-style: italic; font-weight: 340; }

/* Handschrift-Akzent — sehr sparsam, max. 1× pro Abschnitt */
.script {
  font-family: var(--font-script);
  font-weight: 600;
  color: var(--gold-deep);
  line-height: 1;
  letter-spacing: .01em;
}

/* Eyebrow / Kapitel-Label — ersetzt den Canva-Script-Look */
.eyebrow {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: .74rem;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold-deep);
  display: inline-flex;
  align-items: center;
  gap: .85em;
}
.eyebrow::before {
  content: "";
  width: 30px; height: 1px;
  background: var(--gold);
}
.eyebrow.center::after {
  content: "";
  width: 30px; height: 1px;
  background: var(--gold);
}

.lead {
  font-size: clamp(1.1rem, 1.4vw, 1.32rem);
  line-height: 1.6;
  color: var(--ink-soft);
  font-weight: 400;
}

p + p { margin-top: 1.1em; }
strong { font-weight: 600; color: var(--ink); }

/* ---------- 4. Layout-Helfer ---------- */
.wrap { max-width: var(--wrap); margin-inline: auto; padding-inline: var(--gutter); position: relative; z-index: 2; }
.wrap-text { max-width: var(--wrap-text); }
.section { padding-block: var(--section-y); position: relative; }
.center { text-align: center; }
.mx-auto { margin-inline: auto; }

.bg-cream  { background: var(--cream); }
.bg-cream2 { background: var(--cream-2); }
.bg-white  { background: var(--white); }
.bg-navy   { background: var(--navy); color: var(--cream); }
.bg-navy h1,.bg-navy h2,.bg-navy h3 { color: var(--white); }
.bg-navy .lead { color: rgba(250,245,236,.78); }
.bg-navy .eyebrow { color: var(--gold-soft); }
.bg-navy .eyebrow::before,.bg-navy .eyebrow::after { background: var(--gold-soft); }

/* sanfter Verlaufsrand zwischen Sektionen */
.edge-top { box-shadow: inset 0 1px 0 var(--line); }

/* ---------- 5. Gold-Siegel (Markenmotiv) ---------- */
.seal {
  width: 78px; height: 78px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: radial-gradient(circle at 32% 28%, var(--gold-soft), var(--gold) 55%, var(--gold-deep) 100%);
  box-shadow: 0 10px 28px -10px rgba(160,127,60,.7), inset 0 0 0 1px rgba(255,255,255,.25);
  font-family: var(--font-script);
  font-size: 1.5rem;
  color: var(--navy-deep);
  line-height: .9;
  text-align: center;
  flex: none;
}
.seal span { display: block; font-size: .58rem; font-family: var(--font-body); letter-spacing: .18em; text-transform: uppercase; opacity: .7; }

/* ---------- 6. Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .7em;
  padding: 1.05em 2.3em;
  border-radius: 999px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: .98rem;
  letter-spacing: .01em;
  line-height: 1;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), background .4s var(--ease);
  position: relative;
  will-change: transform;
}
.btn-gold {
  background: linear-gradient(135deg, var(--gold-soft), var(--gold) 60%, var(--gold-deep));
  color: var(--navy-deep);
  box-shadow: 0 14px 34px -14px rgba(160,127,60,.8);
}
.btn-gold:hover { transform: translateY(-3px); box-shadow: 0 22px 44px -16px rgba(160,127,60,.9); }
.btn-ghost {
  border: 1px solid var(--line-gold);
  color: var(--gold-deep);
}
.btn-ghost:hover { background: rgba(191,155,84,.08); transform: translateY(-2px); }
.btn .arrow { transition: transform .4s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }
.bg-navy .btn-ghost { color: var(--gold-soft); border-color: rgba(215,189,134,.4); }

/* ---------- 7. Navigation ---------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 1.1rem 0;
  transition: background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.nav.scrolled {
  background: rgba(250,245,236,.82);
  backdrop-filter: blur(16px) saturate(1.2);
  -webkit-backdrop-filter: blur(16px) saturate(1.2);
  padding: .7rem 0;
  box-shadow: 0 1px 0 var(--line), 0 10px 30px -24px rgba(21,48,59,.5);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.brand {
  font-family: var(--font-display);
  font-size: 1.45rem;
  font-weight: 360;
  color: var(--navy);
  letter-spacing: -.01em;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  gap: .7rem;
}
.brand .logo { width: 46px; height: 46px; flex: none; display: block; transition: width .5s var(--ease), height .5s var(--ease); }
.nav.scrolled .brand .logo { width: 40px; height: 40px; }
.brand .brand-text { display: flex; flex-direction: column; }
.brand .script-sm { font-family: var(--font-script); font-size: 1.05rem; color: var(--gold-deep); display:block; letter-spacing: 0; margin-top: -2px; }
.footer .brand .logo { width: 54px; height: 54px; }
.nav-links { display: flex; align-items: center; gap: 2.1rem; list-style: none; }
.nav-links a {
  font-size: .92rem; font-weight: 500; color: var(--ink-soft);
  position: relative; transition: color .3s var(--ease);
}
.nav-links a::after {
  content:""; position:absolute; left:0; bottom:-6px; height:1.5px; width:0;
  background: var(--gold); transition: width .35s var(--ease);
}
.nav-links a:hover, .nav-links a.active { color: var(--navy); }
.nav-links a:hover::after, .nav-links a.active::after { width: 100%; }
.nav-cta { padding: .7em 1.5em; font-size: .9rem; }

.nav-toggle { display: none; width: 30px; height: 22px; position: relative; z-index: 110; }
.nav-toggle span { position:absolute; left:0; height:2px; width:100%; background: var(--navy); border-radius: 2px; transition: .4s var(--ease); }
.nav-toggle span:nth-child(1){ top:0; }
.nav-toggle span:nth-child(2){ top:10px; }
.nav-toggle span:nth-child(3){ top:20px; }
.nav-open .nav-toggle span:nth-child(1){ top:10px; transform: rotate(45deg); }
.nav-open .nav-toggle span:nth-child(2){ opacity:0; }
.nav-open .nav-toggle span:nth-child(3){ top:10px; transform: rotate(-45deg); }

/* ---------- 8. Hero ---------- */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex; align-items: flex-end;
  color: var(--cream);
  overflow: hidden;
}
.hero-media { position: absolute; inset: 0; z-index: 0; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; }
.hero-media::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(16,37,48,.55) 0%, rgba(16,37,48,.15) 35%, rgba(16,37,48,.65) 100%);
}
.hero-inner { position: relative; z-index: 2; padding-bottom: clamp(4rem, 9vw, 8rem); padding-top: 8rem; width: 100%; }
.hero .display { color: var(--white); max-width: 13ch; text-shadow: 0 2px 30px rgba(16,37,48,.4); }
.hero .display em { font-style: italic; color: var(--gold-soft); }
.hero-sub { max-width: 46ch; margin-top: 1.6rem; color: rgba(250,245,236,.9); font-size: clamp(1.05rem,1.4vw,1.25rem); }
.hero-actions { margin-top: 2.5rem; display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; }
.hero-eyebrow { color: var(--gold-soft); }
.hero-eyebrow::before { background: var(--gold-soft); }
.scroll-hint { position:absolute; bottom: 1.6rem; left:50%; transform: translateX(-50%); z-index:3; color: rgba(250,245,236,.7); font-size:.7rem; letter-spacing:.25em; text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:.6rem; }
.scroll-hint .dot { width:1px; height: 38px; background: linear-gradient(var(--gold-soft), transparent); animation: drift 2.4s var(--ease) infinite; }
@keyframes drift { 0%{ transform: scaleY(.3); transform-origin: top; opacity:.4;} 50%{ transform: scaleY(1); opacity:1;} 100%{ transform: scaleY(.3); transform-origin: bottom; opacity:.4;} }

/* ---------- 9. Bild-Platzhalter (austauschbar) ---------- */
.ph {
  position: relative;
  background:
    linear-gradient(135deg, rgba(191,155,84,.14), rgba(21,48,59,.10)),
    var(--cream-2);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: grid; place-items: center;
  color: var(--ink-soft);
  isolation: isolate;
}
.ph::after {
  content: attr(data-label);
  font-size: .72rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--gold-deep); opacity: .8; padding: 1rem; text-align:center;
  font-weight: 600;
}
.ph::before {
  content:""; position:absolute; inset:0; z-index:-1; opacity:.5;
  background-image: radial-gradient(circle at 30% 25%, rgba(215,189,134,.5), transparent 45%),
                    radial-gradient(circle at 75% 80%, rgba(21,48,59,.18), transparent 50%);
}
.ph img { position:absolute; inset:0; width:100%; height:100%; object-fit: cover; }
.r-portrait { aspect-ratio: 4/5; }
.r-square   { aspect-ratio: 1/1; }
.r-wide     { aspect-ratio: 16/10; }
.r-circle   { aspect-ratio: 1/1; border-radius: 50%; }

/* ---------- 10. Grids & Module ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.split.narrow-media { grid-template-columns: 1.15fr .85fr; }
.split.media-left { direction: rtl; }
.split.media-left > * { direction: ltr; }

.stack-sm > * + * { margin-top: 1rem; }
.stack > * + * { margin-top: 1.6rem; }
.mt-1{margin-top:1rem;} .mt-2{margin-top:2rem;} .mt-3{margin-top:3rem;}

/* Karten / Wertversprechen */
.cards { display: grid; gap: 1.4rem; }
.cards-3 { grid-template-columns: repeat(3, 1fr); }
.card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: clamp(1.6rem, 3vw, 2.4rem);
  box-shadow: var(--shadow-sm);
  transition: transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
}
.card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: var(--line-gold); }
.card .ic {
  width: 46px; height: 46px; border-radius: 50%;
  background: linear-gradient(135deg, var(--gold-soft), var(--gold-deep));
  display:grid; place-items:center; margin-bottom: 1.1rem;
  color: var(--navy-deep); font-family: var(--font-display); font-size: 1.2rem;
}
.card h3 { margin-bottom: .5rem; }

/* "Wie wäre es, wenn" Liste */
.imagine-list { list-style:none; display:grid; gap: 1.1rem; counter-reset: im; }
.imagine-list li {
  padding-left: 3.2rem; position: relative; font-size: clamp(1.1rem,1.6vw,1.35rem);
  font-family: var(--font-display); font-weight: 360; color: var(--navy); line-height:1.35;
}
.imagine-list li::before {
  counter-increment: im; content: "0" counter(im);
  position:absolute; left:0; top:.15em; font-family: var(--font-body);
  font-size: .8rem; letter-spacing:.1em; color: var(--gold-deep); font-weight:700;
  border-bottom: 1px solid var(--line-gold); padding-bottom: 2px;
}

/* Reise / Transformation Liste mit Häkchen-Strich */
.glow-list { list-style:none; display:grid; gap: 1rem; }
.glow-list li { position: relative; padding-left: 1.9rem; color: var(--ink); }
.glow-list li::before { content:""; position:absolute; left:0; top:.7em; width:9px; height:9px; border-radius:50%; background: var(--gold); box-shadow: 0 0 0 4px rgba(191,155,84,.15); }

/* ---------- 11. Programm / Kapitel-Cards ---------- */
.chapters { display: grid; gap: 1.1rem; }
.chapter {
  background: var(--white); border: 1px solid var(--line);
  border-radius: var(--radius); overflow: hidden;
  transition: box-shadow .45s var(--ease), border-color .45s var(--ease);
}
.chapter:hover { box-shadow: var(--shadow); border-color: var(--line-gold); }
.chapter-head {
  display: grid; grid-template-columns: auto 1fr auto; gap: 1.4rem; align-items: center;
  width: 100%; text-align: left; padding: clamp(1.4rem,3vw,2rem);
}
.chapter-num {
  font-family: var(--font-display); font-style: italic; font-size: 2.4rem;
  color: var(--gold); line-height: 1; font-weight: 340; min-width: 1.6em;
}
.chapter-title h3 { font-size: clamp(1.3rem,2.4vw,1.9rem); }
.chapter-title .essence { color: var(--ink-soft); font-size: .96rem; margin-top: .3rem; }
.chapter-toggle {
  width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--line-gold);
  display: grid; place-items: center; flex: none; transition: .45s var(--ease); color: var(--gold-deep);
}
.chapter-toggle::before { content:"+"; font-size: 1.4rem; font-family: var(--font-body); line-height: 1; }
.chapter[open] .chapter-toggle { background: var(--gold); color: var(--navy-deep); transform: rotate(180deg); border-color: var(--gold); }
.chapter[open] .chapter-toggle::before { content:"–"; }
.chapter-body { padding: 0 clamp(1.4rem,3vw,2rem) clamp(1.6rem,3vw,2.2rem); }
.chapter-body .steps { list-style:none; display:grid; gap:.85rem; border-top: 1px solid var(--line); padding-top: 1.4rem; }
.chapter-body .steps li { display:grid; grid-template-columns: auto 1fr; gap:.9rem; align-items:baseline; }
.chapter-body .steps b { font-family: var(--font-display); font-style: italic; font-weight:380; color: var(--navy); font-size:1.08rem; }
.chapter-body .steps span { color: var(--ink-soft); font-size:.97rem; }
.chapter-body .steps li::before { content:""; }
.chapter-body .steps .step-dot { width:6px; height:6px; border-radius:50%; background: var(--gold); margin-top:.55em; }
details > summary { list-style: none; cursor: pointer; }
details > summary::-webkit-details-marker { display: none; }

/* ---------- 12. Angebot / Preis-Block ("stilles Verkaufen") ---------- */
.offer {
  background: var(--navy);
  border-radius: var(--radius-lg);
  padding: clamp(2.2rem, 5vw, 4rem);
  color: var(--cream);
  position: relative; overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.offer::before {
  content:""; position:absolute; top:-30%; right:-10%; width: 60%; height: 160%;
  background: radial-gradient(circle, rgba(191,155,84,.22), transparent 60%);
  pointer-events:none;
}
.offer-grid { display:grid; grid-template-columns: 1.2fr .8fr; gap: clamp(2rem,4vw,3.5rem); align-items:center; position:relative; z-index:1; }
.offer .tag {
  display:inline-flex; align-items:center; gap:.6em; font-size:.78rem; letter-spacing:.2em;
  text-transform:uppercase; color: var(--gold-soft); border:1px solid rgba(215,189,134,.4);
  padding:.5em 1.1em; border-radius:999px; margin-bottom:1.4rem;
}
.offer h2 { color: var(--white); }
.offer .incl { list-style:none; display:grid; gap:.8rem; margin-top:1.6rem; }
.offer .incl li { position:relative; padding-left:1.8rem; color: rgba(250,245,236,.85); }
.offer .incl li::before { content:""; position:absolute; left:0; top:.55em; width:11px; height:7px; border-left:2px solid var(--gold-soft); border-bottom:2px solid var(--gold-soft); transform: rotate(-45deg); }
.price-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(215,189,134,.3);
  border-radius: var(--radius); padding: clamp(1.8rem,3vw,2.4rem); text-align:center;
  backdrop-filter: blur(6px);
}
.price-card .plaetze { font-family: var(--font-script); font-size:1.6rem; color: var(--gold-soft); }
.price-card .price { font-family: var(--font-display); font-size: clamp(3rem,6vw,4rem); color: var(--white); line-height:1; margin:.3rem 0 .2rem; font-weight:340; }
.price-card .price small { font-size:1.1rem; vertical-align:.8em; color: var(--gold-soft); }
.price-card .note { font-size:.86rem; color: rgba(250,245,236,.65); margin-bottom:1.6rem; }
.price-card .btn { width:100%; justify-content:center; }
.beta-frame { font-size:.95rem; color: rgba(250,245,236,.78); border-top:1px solid rgba(215,189,134,.25); margin-top:1.5rem; padding-top:1.3rem; }

/* ---------- 13. FAQ Akkordeon ---------- */
.faq-group { margin-top: 2.6rem; }
.faq-group h3 {
  font-family: var(--font-display); font-style: italic; font-size: clamp(1.4rem,2.6vw,2rem);
  color: var(--navy); margin-bottom:1.1rem;
}
.faq {
  border-bottom: 1px solid var(--line);
}
.faq summary {
  display:flex; align-items:center; justify-content:space-between; gap:1.2rem;
  padding: 1.25rem 0; font-weight: 600; font-size: clamp(1.02rem,1.4vw,1.12rem); color: var(--navy);
}
.faq summary .q-ic { flex:none; width:28px; height:28px; border-radius:50%; border:1px solid var(--line-gold); display:grid; place-items:center; color: var(--gold-deep); transition:.4s var(--ease); }
.faq summary .q-ic::before { content:"+"; font-size:1.1rem; line-height:1; }
.faq[open] summary .q-ic { background: var(--gold); color: var(--navy-deep); transform: rotate(135deg); border-color: var(--gold); }
.faq .a { padding: 0 0 1.4rem; color: var(--ink-soft); max-width: 62ch; }

/* ---------- 14. Footer ---------- */
.footer { background: var(--navy-deep); color: rgba(250,245,236,.7); padding-block: clamp(3.5rem,7vw,5.5rem) 2.5rem; }
.footer-cta { text-align:center; max-width: 36ch; margin: 0 auto clamp(3rem,6vw,4.5rem); }
.footer-cta .script { color: var(--gold-soft); font-size: clamp(2.2rem,5vw,3.2rem); display:block; margin-bottom:.4rem; }
.footer-cta h2 { color: var(--white); }
.footer-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2.5rem; border-top:1px solid rgba(255,255,255,.1); padding-top: 3rem; }
.footer .brand { color: var(--cream); }
.footer h4 { font-family: var(--font-body); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color: var(--gold-soft); margin-bottom:1.1rem; }
.footer ul { list-style:none; display:grid; gap:.7rem; }
.footer a:hover { color: var(--gold-soft); }
.footer .contact-line { margin-top:1rem; font-size:.92rem; line-height:1.9; }
.footer-bottom { display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; align-items:center; margin-top:3rem; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,.08); font-size:.82rem; color: rgba(250,245,236,.45); }
.footer-bottom a { text-decoration: underline; text-underline-offset: 3px; }

/* ---------- 15. Rechtstext-Seiten (Impressum/Datenschutz) ---------- */
.legal { padding-top: clamp(8rem, 12vw, 11rem); }
.legal h1 { margin-bottom: .5rem; }
.legal .updated { color: var(--ink-soft); font-size:.9rem; margin-bottom: 2.5rem; }
.legal h2 { font-size: clamp(1.3rem,2.4vw,1.7rem); margin: 2.4rem 0 .8rem; }
.legal h3 { font-size: 1.1rem; margin: 1.6rem 0 .5rem; font-family: var(--font-body); font-weight:700; color: var(--navy); }
.legal p, .legal li { color: var(--ink-soft); }
.legal ul { margin: .6rem 0 .6rem 1.2rem; }
.legal .ph-note {
  background: var(--cream-2); border-left: 3px solid var(--gold);
  padding: 1rem 1.3rem; border-radius: 0 var(--radius) var(--radius) 0;
  font-size:.9rem; color: var(--ink); margin: 1rem 0;
}
.legal .ph-note strong { color: var(--gold-deep); }
mark.fill {
  background: rgba(191,155,84,.18); color: var(--gold-deep); font-weight:600;
  padding: 0 .25em; border-radius: 4px; border-bottom: 1px dashed var(--gold);
}

/* ---------- 16. Scroll-Reveal (dezent, mobile-sicher) ---------- */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; }
.reveal.d2 { transition-delay: .16s; }
.reveal.d3 { transition-delay: .24s; }
.reveal.d4 { transition-delay: .32s; }

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

/* ---------- 17. Responsive ---------- */
@media (max-width: 880px) {
  .nav-links {
    position: fixed; inset: 0 0 0 auto; width: min(78vw, 340px);
    background: var(--cream); flex-direction: column; align-items: flex-start;
    justify-content: center; gap: 1.8rem; padding: 3rem 2.2rem;
    transform: translateX(110%); transition: transform .5s var(--ease);
    box-shadow: var(--shadow-lg); z-index: 105;
  }
  .nav-open .nav-links { transform: translateX(0); }
  .nav-links a { font-size: 1.25rem; font-family: var(--font-display); color: var(--navy); }
  .nav-links .nav-cta { font-family: var(--font-body); }
  .nav-toggle { display: block; }
  .nav-backdrop { position: fixed; inset:0; background: rgba(16,37,48,.4); opacity:0; visibility:hidden; transition:.4s; z-index:104; backdrop-filter: blur(2px); }
  .nav-open .nav-backdrop { opacity:1; visibility:visible; }

  .split, .offer-grid, .cards-3, .footer-grid { grid-template-columns: 1fr; }
  .split.media-left { direction: ltr; }
  .split.narrow-media { grid-template-columns: 1fr; }
  .offer-grid { gap: 2rem; }
  .chapter-head { grid-template-columns: auto 1fr auto; gap: 1rem; }
  .chapter-num { font-size: 1.8rem; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 520px) {
  .hero-actions .btn { width: 100%; justify-content:center; }
  .chapter-num { display:none; }
  .chapter-head { grid-template-columns: 1fr auto; }
}
