/* ============================================================
   MARK FROHMÜLLER — Vom Überleben zurück ins Leben
   High-End Redesign · Design System
   ============================================================ */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500;1,600&family=Poppins:wght@300;400;500;600&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500&family=Hanken+Grotesk:wght@300;400;500;600&display=swap');

/* ---------- Tokens ---------- */
:root{
  --paper:      #F7F2EA;
  --paper-2:    #F1E9DC;
  --sand:       #E8DDCA;
  --sand-deep:  #DCCDB3;
  --ink:        #201D19;
  --ink-2:      #4B453C;
  --ink-3:      #6E665A;
  --gold:       #B0884A;
  --gold-2:     #D2B377;
  --gold-deep:  #8C6A36;
  --gold-soft:  rgba(176,136,74,.12);
  --line:       rgba(32,29,25,.12);
  --line-soft:  rgba(32,29,25,.07);
  --night:      #1A1714;
  --night-2:    #221E1A;

  --maxw: 1240px;
  --gutter: clamp(1.25rem, 5vw, 4rem);
  --radius: 22px;
  --radius-lg: 34px;
  --bar-h: 46px;

  --serif: 'Playfair Display', Georgia, serif;
  --sans:  'Poppins', system-ui, -apple-system, sans-serif;

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

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
html.gsap{ scroll-behavior:auto; } /* Lenis owns smoothing */
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.7;
  font-weight:300;
  font-size:clamp(1rem,.96rem + .2vw,1.075rem);
  letter-spacing:.005em;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--gold); color:#fff; }

/* Grain overlay */
body::before{
  content:""; position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.035; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.wrap--narrow{ max-width:880px; }
.wrap--wide{ max-width:1400px; }
section{ position:relative; }
.section{ padding-block:clamp(4.5rem,10vw,9rem); }
.section--tight{ padding-block:clamp(3rem,7vw,6rem); }

/* ---------- Typographic primitives ---------- */
.eyebrow{
  font-family:var(--sans);
  font-weight:500;
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex; align-items:center; gap:.85rem;
}
.eyebrow::before{
  content:""; width:34px; height:1px; background:var(--gold);
  display:inline-block; opacity:.7;
}
.eyebrow--center::after{
  content:""; width:34px; height:1px; background:var(--gold);
  display:inline-block; opacity:.7;
}
h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; line-height:1.08; letter-spacing:-.01em; color:var(--ink); }
.display{
  font-size:clamp(2.6rem,1.6rem + 4.6vw,5.4rem);
  font-weight:600; line-height:1.02; letter-spacing:-.022em;
}
.h2{ font-size:clamp(2rem,1.4rem + 2.6vw,3.4rem); line-height:1.07; }
.h3{ font-size:clamp(1.45rem,1.2rem + 1.1vw,2.1rem); }
.lead{
  font-size:clamp(1.12rem,1.02rem + .5vw,1.4rem);
  line-height:1.6; color:var(--ink-2); font-weight:300;
}
.serif-it{ font-family:var(--serif); font-style:italic; font-weight:500; }
em.gold,.gold-text{ color:var(--gold-deep); font-style:normal; }
.muted{ color:var(--ink-3); }
.maxch{ max-width:62ch; }
.center{ text-align:center; }
.mx-auto{ margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink); --fg:var(--paper);
  position:relative; display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--sans); font-weight:500; font-size:.78rem;
  letter-spacing:.18em; text-transform:uppercase;
  padding:1.15em 2.2em; border-radius:100px; isolation:isolate;
  color:var(--fg); background:var(--bg); border:1px solid var(--bg);
  overflow:hidden; transition:color .5s var(--ease), border-color .5s var(--ease), transform .4s var(--ease);
}
.btn::after{
  content:""; position:absolute; inset:0; z-index:-1; border-radius:inherit;
  background:linear-gradient(120deg,var(--gold),var(--gold-deep));
  transform:translateY(102%); transition:transform .55s var(--ease-out);
}
.btn:hover{ color:#fff; transform:translateY(-2px); }
.btn:hover::after{ transform:translateY(0); }
.btn .ar{ transition:transform .45s var(--ease); }
.btn:hover .ar{ transform:translateX(4px); }
.btn--ghost{ --bg:transparent; --fg:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ border-color:transparent; }
.btn--gold{ --bg:var(--gold-deep); --fg:#fff; border-color:var(--gold-deep); }
.btn--gold::after{ background:linear-gradient(120deg,var(--ink),#000); }
.btn--lg{ padding:1.3em 2.6em; font-size:.82rem; }
.btn--light{ --bg:transparent; --fg:var(--paper); border-color:rgba(247,242,234,.3); }
.btn--light:hover{ color:var(--night); border-color:transparent; }
.btn--light::after{ background:var(--paper); }

/* Text link */
.tlink{
  position:relative; font-weight:500; font-size:.78rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--gold-deep); display:inline-flex; gap:.6em; align-items:center;
}
.tlink::after{ content:""; position:absolute; left:0; bottom:-6px; height:1px; width:100%;
  background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.tlink:hover::after{ transform:scaleX(1); }
.tlink .ar{ transition:transform .4s var(--ease); }
.tlink:hover .ar{ transform:translateX(4px); }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:fixed; top:var(--bar-h, 0); left:0; right:0; z-index:1000;
  padding-block:1.1rem; transition:all .5s var(--ease);
}
.site-header::before{
  content:""; position:absolute; inset:0; z-index:-1; opacity:0;
  background:rgba(247,242,234,.82); backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line-soft); transition:opacity .5s var(--ease);
}
.site-header.scrolled{ padding-block:.7rem; }
.site-header.scrolled::before{ opacity:1; }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand .enso{ width:38px; height:38px; flex:none; transition:transform .6s var(--ease); }
.brand:hover .enso{ transform:rotate(-12deg); }
.brand-name{ display:flex; flex-direction:column; line-height:1; }
.brand-name strong{ font-family:var(--serif); font-weight:600; font-size:1.18rem; letter-spacing:.01em; }
.brand-name span{ font-size:.54rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold-deep); margin-top:.35em; }

.nav-links{ display:flex; align-items:center; gap:2.4rem; list-style:none; }
.nav-links a{
  font-size:.82rem; font-weight:400; letter-spacing:.04em; color:var(--ink-2);
  position:relative; padding-block:.3rem; transition:color .3s var(--ease);
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; width:100%; height:1px; background:var(--gold);
  transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease);
}
.nav-links a:hover,.nav-links a.active{ color:var(--ink); }
.nav-links a:hover::after,.nav-links a.active::after{ transform:scaleX(1); }
.nav-cta{ display:flex; align-items:center; gap:1.2rem; }

.burger{ display:none; width:42px; height:42px; border:1px solid var(--line); border-radius:50%;
  background:transparent; position:relative; z-index:1101; }
.burger span{ position:absolute; left:50%; top:50%; width:16px; height:1.5px; background:var(--ink);
  translate:-50% -50%; transition:.4s var(--ease); }
.burger span:nth-child(1){ translate:-50% calc(-50% - 4px); }
.burger span:nth-child(2){ translate:-50% calc(-50% + 4px); }
.burger.open span:nth-child(1){ translate:-50% -50%; rotate:45deg; }
.burger.open span:nth-child(2){ translate:-50% -50%; rotate:-45deg; }

/* Mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:1100; background:var(--night); color:var(--paper);
  display:flex; flex-direction:column; justify-content:center; padding:var(--gutter);
  clip-path:circle(0% at calc(100% - 42px) 42px); transition:clip-path .7s var(--ease-out);
  pointer-events:none;
}
.mobile-menu.open{ clip-path:circle(150% at calc(100% - 42px) 42px); pointer-events:auto; }
.mobile-menu ul{ list-style:none; display:flex; flex-direction:column; gap:.2rem; }
.mobile-menu a{ font-family:var(--serif); font-size:clamp(2rem,9vw,3.4rem); font-weight:500;
  color:var(--paper); display:inline-block; padding-block:.25rem; opacity:.5; transition:.4s var(--ease); }
.mobile-menu a:hover{ opacity:1; color:var(--gold-2); padding-left:.4rem; }
.mobile-menu .mm-foot{ margin-top:3rem; font-size:.8rem; letter-spacing:.1em; color:rgba(247,242,234,.5); }
.mobile-menu .mm-foot a{ font-family:var(--sans); font-size:.8rem; opacity:.8; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  padding-bottom:clamp(3rem,7vw,6rem); padding-top:9rem; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:-2; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; object-position:70% 30%;
  filter:grayscale(1) contrast(1.02); }
.hero-bg::after{ content:""; position:absolute; inset:0;
  background:
    linear-gradient(to top, var(--paper) 4%, rgba(247,242,234,.7) 24%, rgba(247,242,234,.18) 48%, rgba(247,242,234,0) 70%),
    linear-gradient(105deg, rgba(247,242,234,.96) 0%, rgba(247,242,234,.82) 26%, rgba(247,242,234,.32) 48%, rgba(247,242,234,0) 64%);
}
.hero-enso{ position:absolute; right:-6vw; top:8vh; width:min(54vw,720px); z-index:-1;
  opacity:.10; pointer-events:none; }
.hero-inner{ position:relative; }
.hero .eyebrow{ margin-bottom:1.6rem; }
.hero h1{ margin-bottom:1.7rem; max-width:16ch; }
.hero h1 .ln{ display:block; overflow:hidden; }
.hero h1 .ln > span{ display:block; }
.hero-quote{ font-family:var(--serif); font-style:italic; font-weight:500;
  font-size:clamp(1.15rem,1rem + .8vw,1.65rem); color:var(--ink-2); max-width:30ch;
  padding-left:1.4rem; border-left:2px solid var(--gold); margin-bottom:2.2rem; line-height:1.5; }
.hero-sub{ max-width:48ch; margin-bottom:2.6rem; }
.hero-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:1.2rem 1.8rem; }
.scroll-cue{ position:absolute; left:var(--gutter); bottom:2rem; display:flex; align-items:center; gap:.8rem;
  font-size:.66rem; letter-spacing:.25em; text-transform:uppercase; color:var(--ink-3); }
.scroll-cue .bar{ width:1px; height:46px; background:var(--line); position:relative; overflow:hidden; }
.scroll-cue .bar::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%;
  background:var(--gold); animation:scrolldown 2.2s var(--ease) infinite; }
@keyframes scrolldown{ 0%{ top:-50% } 60%,100%{ top:100% } }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--ease-out), transform 1s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.1s } .reveal[data-d="2"]{ transition-delay:.2s }
.reveal[data-d="3"]{ transition-delay:.3s } .reveal[data-d="4"]{ transition-delay:.4s }
.reveal[data-d="5"]{ transition-delay:.5s } .reveal[data-d="6"]{ transition-delay:.6s }
.line-reveal .ln{ display:block; overflow:hidden; }
.line-reveal .ln > span{ display:block; transform:translateY(110%); transition:transform 1.1s var(--ease-out); }
.line-reveal.in .ln > span{ transform:none; }
.line-reveal .ln:nth-child(2) > span{ transition-delay:.09s }
.line-reveal .ln:nth-child(3) > span{ transition-delay:.18s }
.line-reveal .ln:nth-child(4) > span{ transition-delay:.27s }
@media (prefers-reduced-motion: reduce){
  .reveal,.line-reveal .ln > span{ opacity:1 !important; transform:none !important; }
}

/* ============================================================
   INTRO / EMPATHY LIST
   ============================================================ */
.empathy{ background:var(--paper-2); }
.empathy-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,6vw,6rem); align-items:center; }
.empathy-head h2{ margin-bottom:1.4rem; }
.check-list{ list-style:none; display:grid; gap:.2rem; }
.check-list li{ display:flex; gap:1.1rem; align-items:flex-start; padding:1.05rem 0;
  border-bottom:1px solid var(--line-soft); color:var(--ink-2); font-size:1.02rem; line-height:1.55; }
.check-list li:last-child{ border-bottom:0; }
.check-list .dot{ flex:none; width:8px; height:8px; border-radius:50%; margin-top:.62rem;
  background:var(--gold); box-shadow:0 0 0 4px var(--gold-soft); }
.empathy-foot{ margin-top:2.4rem; }
.empathy-foot p{ font-family:var(--serif); font-style:italic; font-size:clamp(1.2rem,1rem + 1vw,1.7rem);
  color:var(--ink); line-height:1.4; }

/* ============================================================
   STATEMENT — "Vielleicht ist mit dir nichts falsch"
   ============================================================ */
.statement{ position:relative; overflow:hidden; }
.statement .enso-bg{ position:absolute; left:50%; top:50%; translate:-50% -50%;
  width:min(80vw,820px); opacity:.06; z-index:0; pointer-events:none; }
.statement-inner{ position:relative; z-index:1; text-align:center; }
.statement .h2{ margin:1.4rem auto 2.5rem; max-width:18ch; }
.statement-words{ display:flex; flex-wrap:wrap; justify-content:center; gap:.6rem 1.1rem; margin-bottom:2.8rem; }
.statement-words span{ font-family:var(--serif); font-style:italic; font-size:clamp(1.3rem,1rem + 1.6vw,2.1rem);
  color:var(--ink-3); }
.statement-words span.x{ position:relative; color:var(--ink); }
.statement-words span.x::after{ content:""; position:absolute; left:-4%; right:-4%; top:54%; height:2px;
  background:var(--gold); transform:scaleX(0); transform-origin:left; }
.statement-words.in span.x::after{ transform:scaleX(1); transition:transform .8s var(--ease) calc(var(--i,0)*.12s + .4s); }
.statement-body{ max-width:60ch; margin-inline:auto; }
.statement-body p{ margin-bottom:1.2rem; color:var(--ink-2); }
.statement-body .accent{ font-family:var(--serif); font-style:italic; font-size:1.4rem; color:var(--ink);
  margin-top:1.8rem; }

/* shift couplets */
.couplets{ display:grid; gap:1.4rem; max-width:640px; margin:0 auto 2.6rem; }
.couplet{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:1rem;
  padding-bottom:1.4rem; border-bottom:1px solid var(--line-soft); text-align:left; }
.couplet .was{ color:var(--ink-3); }
.couplet .now{ font-family:var(--serif); font-style:italic; color:var(--ink); text-align:right; }
.couplet .arrow{ color:var(--gold); font-size:1.1rem; }

/* ============================================================
   APPROACH — split editorial
   ============================================================ */
.approach-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2.5rem,6vw,6rem); align-items:center; }
.approach-media{ position:relative; }
.approach-media .ph{ border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/5;
  box-shadow:0 40px 80px -40px rgba(32,29,25,.4); }
.approach-media .ph img{ width:100%; height:100%; object-fit:cover; }
.approach-media .badge{ position:absolute; bottom:-26px; left:-26px; background:var(--ink); color:var(--paper);
  border-radius:18px; padding:1.4rem 1.6rem; max-width:230px; box-shadow:0 30px 60px -30px rgba(0,0,0,.5); }
.approach-media .badge .q{ font-family:var(--serif); font-style:italic; font-size:1.05rem; line-height:1.4; }
.approach-text h2{ margin:1.2rem 0 1.8rem; }
.approach-text p{ margin-bottom:1.15rem; color:var(--ink-2); }
.approach-text .pull{ font-family:var(--serif); font-style:italic; font-size:clamp(1.3rem,1.1rem + 1vw,1.75rem);
  color:var(--ink); line-height:1.4; margin:2rem 0; padding-left:1.4rem; border-left:2px solid var(--gold); }

/* ============================================================
   QUOTE BAND (dark)
   ============================================================ */
.band{ background:var(--night); color:var(--paper); overflow:hidden; position:relative; }
.band .enso-bg{ position:absolute; right:-8%; bottom:-30%; width:min(60vw,560px); opacity:.10; }
.band-inner{ position:relative; z-index:1; text-align:center; max-width:640px; margin-inline:auto; }
.band-inner::before{ content:"\201C"; display:block; font-family:var(--serif); font-weight:600; font-style:italic;
  font-size:clamp(2.6rem,2rem + 2vw,3.8rem); line-height:.7; color:var(--gold-2); opacity:.38;
  margin-bottom:.9rem; }
.band-q{ font-family:var(--serif); font-weight:500; font-size:clamp(1.5rem,1.15rem + 1.5vw,2.35rem);
  line-height:1.4; letter-spacing:-.003em; text-wrap:balance; }
.band-q em{ color:var(--gold-2); font-style:italic; }
.band-cite{ margin-top:2.2rem; font-size:.72rem; letter-spacing:.28em; text-transform:uppercase;
  color:rgba(247,242,234,.5); }

/* ============================================================
   MENTORING TEASER / FEATURE CARD
   ============================================================ */
.offer{ background:var(--paper-2); }
.offer-card{ display:grid; grid-template-columns:1.1fr 1fr; background:var(--paper); border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:0 50px 90px -50px rgba(32,29,25,.35); border:1px solid var(--line-soft); }
.offer-card .media{ position:relative; min-height:420px; }
.offer-card .media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.offer-card .media .tag{ position:absolute; top:1.4rem; left:1.4rem; background:rgba(26,23,20,.72);
  color:var(--paper); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; padding:.6em 1.1em; border-radius:100px;
  backdrop-filter:blur(6px); }
.offer-card .body{ padding:clamp(2.2rem,4vw,3.6rem); display:flex; flex-direction:column; justify-content:center; }
.offer-card .body h2{ margin:1rem 0 1.2rem; }
.offer-card .body p{ color:var(--ink-2); margin-bottom:2rem; }
.offer-meta{ display:flex; gap:1.8rem; margin-bottom:2rem; flex-wrap:wrap; }
.offer-meta div{ }
.offer-meta .n{ font-family:var(--serif); font-size:1.9rem; color:var(--gold-deep); line-height:1; }
.offer-meta .l{ font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-top:.4rem; }

/* ============================================================
   VOICE / QUOTES (replaces fake testimonials)
   ============================================================ */
.voices{ }
.voices-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.voice{ background:var(--paper-2); border:1px solid var(--line-soft); border-radius:var(--radius);
  padding:2.2rem 2rem; display:flex; flex-direction:column; gap:1.4rem; transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.voice:hover{ transform:translateY(-6px); box-shadow:0 30px 60px -36px rgba(32,29,25,.32); }
.voice .mark{ font-family:var(--serif); font-size:3rem; line-height:.6; color:var(--gold); height:1.4rem; }
.voice p{ font-family:var(--serif); font-style:italic; font-size:1.18rem; line-height:1.45; color:var(--ink); }
.voice .src{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3); margin-top:auto; }

/* ============================================================
   FINAL CTA
   ============================================================ */
.cta{ position:relative; overflow:hidden; background:var(--night); color:var(--paper); }
.cta .enso-bg{ position:absolute; left:50%; top:50%; translate:-50% -50%; width:min(70vw,640px); opacity:.09; }
.cta-inner{ position:relative; z-index:1; text-align:center; max-width:720px; margin-inline:auto; }
.cta h2{ color:var(--paper); margin:1.4rem 0 1.4rem; font-size:clamp(2.2rem,1.5rem + 3vw,4rem); }
.cta p{ color:rgba(247,242,234,.7); max-width:46ch; margin:0 auto 2.6rem; }
.cta .eyebrow{ color:var(--gold-2); }
.cta .eyebrow::before{ background:var(--gold-2); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--paper-2); padding-top:clamp(3.5rem,7vw,6rem); border-top:1px solid var(--line-soft); }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:3rem; padding-bottom:3.5rem; border-bottom:1px solid var(--line); }
.footer-brand .enso{ width:54px; height:54px; margin-bottom:1.2rem; }
.footer-brand .fb-name{ font-family:var(--serif); font-size:1.5rem; font-weight:600; }
.footer-brand .fb-tag{ font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold-deep); margin:.4rem 0 1.4rem; }
.footer-brand p{ color:var(--ink-3); max-width:34ch; font-size:.95rem; }
.footer-col h4{ font-family:var(--sans); font-size:.72rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-3); margin-bottom:1.3rem; }
.footer-col ul{ list-style:none; display:grid; gap:.85rem; }
.footer-col a{ color:var(--ink-2); font-size:.96rem; transition:color .3s var(--ease); position:relative; }
.footer-col a:hover{ color:var(--gold-deep); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem;
  padding-block:2rem; font-size:.78rem; color:var(--ink-3); }
.footer-bottom .legal{ display:flex; gap:1.6rem; }
.footer-bottom a:hover{ color:var(--ink); }
.disclaimer{ background:var(--sand); }
.disclaimer p{ text-align:center; font-size:.82rem; color:var(--ink-3); max-width:70ch; margin-inline:auto; }

/* ============================================================
   SUBPAGE HERO (smaller)
   ============================================================ */
.page-hero{ padding-top:clamp(8rem,16vh,12rem); padding-bottom:clamp(2.5rem,5vw,4.5rem); position:relative; overflow:hidden; }
.page-hero .enso-bg{ position:absolute; right:-4vw; top:20%; width:min(40vw,440px); opacity:.07; }
.page-hero .eyebrow{ margin-bottom:1.5rem; }
.page-hero h1{ max-width:18ch; }
.page-hero .lead{ max-width:54ch; margin-top:1.6rem; }

/* ============================================================
   STORY (Über mich)
   ============================================================ */
.story-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2.5rem,6vw,5.5rem); align-items:start; }
.story-media{ position:sticky; top:7rem; }
.story-media .ph{ border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:3/4;
  box-shadow:0 40px 80px -44px rgba(32,29,25,.45); }
.story-media .ph img{ width:100%; height:100%; object-fit:cover; }
.story-media .sig{ margin-top:1.6rem; text-align:center; }
.story-media .sig .nm{ font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--ink); }
.story-media .sig .rl{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-3); margin-top:.3rem; }
.story-prose p{ margin-bottom:1.35rem; color:var(--ink-2); }
.story-prose .big{ font-family:var(--serif); font-size:clamp(1.5rem,1.2rem + 1.4vw,2.2rem); color:var(--ink);
  line-height:1.3; margin:.5rem 0 2rem; font-weight:500; }
.story-prose .q-list{ list-style:none; display:grid; gap:.9rem; margin:1.6rem 0 2rem; }
.story-prose .q-list li{ font-family:var(--serif); font-style:italic; font-size:1.2rem; color:var(--ink);
  padding-left:1.3rem; border-left:2px solid var(--gold); }
.story-prose .reveal-line{ font-family:var(--serif); font-style:italic; font-size:clamp(1.4rem,1.1rem + 1.4vw,2rem);
  color:var(--gold-deep); margin:2rem 0; line-height:1.35; }
.story-prose .feelings{ display:flex; flex-wrap:wrap; gap:.7rem; margin:1.5rem 0 2rem; }
.story-prose .feelings span{ font-family:var(--serif); font-style:italic; font-size:1.1rem; color:var(--ink);
  padding:.5em 1.2em; border:1px solid var(--line); border-radius:100px; background:var(--paper); }

/* ============================================================
   MENTORING PAGE
   ============================================================ */
.forwhom{ background:var(--paper-2); }
.forwhom-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2.5rem,6vw,5rem); align-items:center; }
.forwhom-list{ list-style:none; display:grid; gap:.1rem; }
.forwhom-list li{ display:flex; gap:1.1rem; align-items:flex-start; padding:1rem 0; border-bottom:1px solid var(--line-soft);
  color:var(--ink-2); }
.forwhom-list li:last-child{ border-bottom:0; }
.forwhom-list .ic{ flex:none; width:26px; height:26px; border-radius:50%; border:1px solid var(--gold);
  display:grid; place-items:center; color:var(--gold-deep); font-size:.8rem; margin-top:.15rem; }

.phases{ }
.phases-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.phase{ background:var(--paper); border:1px solid var(--line-soft); border-radius:var(--radius); padding:2rem 1.7rem;
  position:relative; overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.phase:hover{ transform:translateY(-6px); box-shadow:0 30px 60px -40px rgba(32,29,25,.32); }
.phase .num{ font-family:var(--serif); font-size:3.4rem; color:var(--sand-deep); line-height:.8; margin-bottom:1.2rem;
  transition:color .5s var(--ease); }
.phase:hover .num{ color:var(--gold); }
.phase h3{ font-size:1.3rem; margin-bottom:.7rem; }
.phase p{ font-size:.95rem; color:var(--ink-3); line-height:1.55; }

.includes{ background:var(--night); color:var(--paper); }
.includes-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2.5rem,6vw,5rem); align-items:center; }
.includes h2{ color:var(--paper); }
.includes .lead{ color:rgba(247,242,234,.7); }
.includes-list{ list-style:none; display:grid; gap:.1rem; }
.includes-list li{ display:flex; gap:1.1rem; align-items:center; padding:1.15rem 0;
  border-bottom:1px solid rgba(247,242,234,.1); font-size:1.05rem; }
.includes-list li:last-child{ border-bottom:0; }
.includes-list .ic{ flex:none; color:var(--gold-2); }
.notincl{ }
.notincl-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.notincl-list{ list-style:none; display:grid; gap:1rem; }
.notincl-list li{ display:flex; gap:1rem; color:var(--ink-2); padding-bottom:1rem; border-bottom:1px solid var(--line-soft); }
.notincl-list li:last-child{ border-bottom:0; }
.notincl-list .ic{ flex:none; color:var(--ink-3); }

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,6vw,5rem); align-items:start; }
.contact-info h2{ margin-bottom:1.4rem; }
.contact-info .lead{ margin-bottom:2.4rem; }
.contact-channels{ display:grid; gap:1.2rem; margin-bottom:2.4rem; }
.channel{ display:flex; gap:1.2rem; align-items:center; padding:1.3rem 1.5rem; background:var(--paper-2);
  border:1px solid var(--line-soft); border-radius:var(--radius); transition:.4s var(--ease); }
.channel:hover{ border-color:var(--gold); transform:translateX(4px); }
.channel .ic{ flex:none; width:46px; height:46px; border-radius:50%; background:var(--paper); display:grid; place-items:center;
  color:var(--gold-deep); border:1px solid var(--line); }
.channel .k{ font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); }
.channel .v{ font-size:1.05rem; color:var(--ink); }

.contact-form{ background:var(--paper); border:1px solid var(--line-soft); border-radius:var(--radius-lg);
  padding:clamp(1.8rem,4vw,3rem); box-shadow:0 40px 80px -50px rgba(32,29,25,.3); }
.field{ position:relative; margin-bottom:1.6rem; }
.field label{ display:block; font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-bottom:.6rem; }
.field input,.field textarea{ width:100%; background:var(--paper-2); border:1px solid var(--line); border-radius:14px;
  padding:1rem 1.1rem; font-family:var(--sans); font-size:1rem; color:var(--ink); transition:.3s var(--ease); font-weight:300; }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--gold); background:#fff;
  box-shadow:0 0 0 4px var(--gold-soft); }
.field textarea{ min-height:140px; resize:vertical; }
.consent{ display:flex; gap:.8rem; align-items:flex-start; font-size:.82rem; color:var(--ink-3); margin-bottom:1.6rem; line-height:1.5; }
.consent input{ margin-top:.25rem; accent-color:var(--gold-deep); }
.form-note{ font-size:.78rem; color:var(--ink-3); margin-top:1rem; text-align:center; }

/* ============================================================
   PROSE (Legal-/Textseiten) + Kennenlern-Bausteine
   ============================================================ */
.prose{ max-width:760px; }
.prose h2{ font-size:clamp(1.4rem,1.2rem + .8vw,1.9rem); margin:2.6rem 0 1rem; }
.prose h3{ font-size:1.1rem; margin:1.8rem 0 .5rem; font-family:var(--sans); font-weight:600; }
.prose p{ margin-bottom:1rem; color:var(--ink-2); }
.prose ul{ margin:0 0 1.1rem 1.25rem; color:var(--ink-2); }
.prose li{ margin-bottom:.45rem; }
.prose a{ color:var(--gold-deep); text-decoration:underline; text-underline-offset:3px; }
.prose .lead{ margin-bottom:1.6rem; }
.ph-tag{ background:var(--gold-soft); color:var(--gold-deep); padding:.08em .55em; border-radius:6px;
  font-size:.92em; font-style:normal; }
.prose .note{ margin-top:2.4rem; padding:1.2rem 1.4rem; background:var(--paper-2); border:1px solid var(--line-soft);
  border-radius:var(--radius); font-size:.9rem; color:var(--ink-3); }

.expect{ background:var(--paper-2); }
.expect-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.2rem; }
.expect-card{ display:flex; gap:1.1rem; align-items:flex-start; padding:1.6rem 1.7rem; background:var(--paper);
  border:1px solid var(--line-soft); border-radius:var(--radius); }
.expect-card .ic{ flex:none; width:42px; height:42px; border-radius:50%; border:1px solid var(--gold);
  display:grid; place-items:center; color:var(--gold-deep); font-size:1.1rem; }
.expect-card h3{ font-size:1.15rem; margin-bottom:.35rem; }
.expect-card p{ font-size:.95rem; color:var(--ink-3); line-height:1.55; }
@media (max-width:680px){ .expect-grid{ grid-template-columns:1fr; } }

/* ============================================================
   THEME: SALBEI  (Fraunces + Hanken Grotesk · Salbei-Grün · Organisch)
   Default (kein .theme-salbei) = Original: Playfair + Poppins · Gold · Sanft
   Klasse sitzt auf <html> (früh per Inline-Script gesetzt → kein Flash)
   ============================================================ */
html.theme-salbei{
  --serif:'Fraunces', Georgia, serif;
  --sans:'Hanken Grotesk', system-ui, sans-serif;
  --gold:#7C8A69; --gold-2:#9DAA88; --gold-deep:#59694A; --gold-soft:rgba(124,138,105,.14);
  --radius:30px; --radius-lg:48px;
}
html.theme-salbei .display{ font-weight:500; }
html.theme-salbei h1, html.theme-salbei h2, html.theme-salbei h3{ letter-spacing:-.015em; }
/* organische Formen */
html.theme-salbei .pkg{ border-radius:40px; }
html.theme-salbei .offer-card{ border-radius:46px; }
html.theme-salbei .approach-media .ph{ border-radius:48% 48% 46% 46% / 15% 15% 12% 12%; }
html.theme-salbei .story-media .ph{ border-radius:40px; }
html.theme-salbei .flow-step .step-n{ box-shadow:0 0 0 6px var(--gold-soft); }
/* organische Animation: federndes Scale + leichter Blur */
html.theme-salbei .reveal{ transform:scale(.94); filter:blur(4px);
  transition:opacity 1s var(--ease-out), transform 1s cubic-bezier(.34,1.4,.5,1), filter .9s var(--ease-out); }
html.theme-salbei .reveal.in{ transform:none; filter:none; }

/* Theme-Umschalter — schlanke Leiste GANZ OBEN (Finalisten Original ⇄ Salbei) */
.theme-bar{ position:fixed; top:0; left:0; right:0; height:var(--bar-h); z-index:2000;
  display:flex; align-items:center; gap:.7rem; padding:0 clamp(.9rem,4vw,2.2rem);
  background:rgba(22,19,16,.96); backdrop-filter:blur(12px); color:var(--paper);
  border-bottom:1px solid rgba(247,242,234,.12); font-family:'Poppins', system-ui, sans-serif; }
.theme-bar .tb-label{ font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(247,242,234,.5); }
.theme-bar .tb-opts{ display:flex; gap:.4rem; }
.theme-bar button{ font-family:inherit; font-size:.72rem; font-weight:500; color:rgba(247,242,234,.72);
  background:transparent; border:1px solid rgba(247,242,234,.22); padding:.4em 1em; border-radius:100px;
  cursor:pointer; transition:.25s ease; white-space:nowrap; }
.theme-bar button:hover{ color:#fff; border-color:rgba(247,242,234,.5); }
.theme-bar button.active{ background:var(--paper); color:#161310; border-color:var(--paper); }
.theme-bar .tb-hint{ margin-left:auto; font-size:.64rem; color:rgba(247,242,234,.38); white-space:nowrap; }
@media (max-width:760px){ .theme-bar .tb-hint{ display:none; } }
@media (max-width:430px){ .theme-bar .tb-label{ display:none; } .theme-bar button{ padding:.4em .8em; font-size:.68rem; } }

/* ============================================================
   FUNNEL — flow steps + packages
   ============================================================ */
.flow{ background:var(--paper-2); }
.flow-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-top:3rem; position:relative; }
.flow-step{ position:relative; padding:2.2rem 1.9rem; background:var(--paper); border:1px solid var(--line-soft);
  border-radius:var(--radius); }
.flow-step .step-n{ display:inline-grid; place-items:center; width:48px; height:48px; border-radius:50%;
  border:1px solid var(--gold); color:var(--gold-deep); font-family:var(--serif); font-size:1.3rem; margin-bottom:1.3rem; }
.flow-step h3{ font-size:1.35rem; margin-bottom:.6rem; }
.flow-step p{ color:var(--ink-3); font-size:.97rem; line-height:1.6; }
.flow-step .conn{ position:absolute; top:46px; right:-0.85rem; width:1.7rem; height:1px; background:var(--line); z-index:2; }
.flow-step:last-child .conn{ display:none; }

.packages{ }
.pkg-head{ text-align:center; margin-bottom:3.2rem; }
.pkg-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.6rem; align-items:stretch; }
.pkg{ position:relative; display:flex; flex-direction:column; background:var(--paper);
  border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(2rem,3.5vw,3rem);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease); overflow:hidden; }
.pkg:hover{ transform:translateY(-6px); box-shadow:0 40px 80px -46px rgba(32,29,25,.34); }
.pkg--featured{ background:var(--night); color:var(--paper); border-color:transparent; }
.pkg--featured h3,.pkg--featured .pkg-price .amt{ color:var(--paper); }
.pkg-badge{ position:absolute; top:1.5rem; right:1.5rem; font-size:.6rem; letter-spacing:.2em; text-transform:uppercase;
  padding:.5em 1em; border-radius:100px; background:linear-gradient(120deg,var(--gold-2),var(--gold-deep)); color:#fff; }
.pkg .pkg-k{ font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:1rem; }
.pkg--featured .pkg-k{ color:var(--gold-2); }
.pkg h3{ font-family:var(--serif); font-size:clamp(1.6rem,1.3rem + 1vw,2.2rem); line-height:1.1; margin-bottom:.7rem; }
.pkg .pkg-pos{ color:var(--ink-2); margin-bottom:1.8rem; min-height:3em; }
.pkg--featured .pkg-pos{ color:rgba(247,242,234,.72); }
.pkg-price{ display:flex; align-items:baseline; gap:.5rem; padding-bottom:1.6rem; margin-bottom:1.6rem;
  border-bottom:1px solid var(--line); }
.pkg--featured .pkg-price{ border-color:rgba(247,242,234,.16); }
.pkg-price .pre{ font-size:.8rem; color:var(--ink-3); }
.pkg--featured .pkg-price .pre{ color:rgba(247,242,234,.6); }
.pkg-price .amt{ font-family:var(--serif); font-size:clamp(1.8rem,1.4rem + 1.4vw,2.6rem); color:var(--ink); line-height:1; }
.pkg-price .per{ font-size:.85rem; color:var(--ink-3); }
.pkg--featured .pkg-price .per{ color:rgba(247,242,234,.6); }
.pkg-features{ list-style:none; display:grid; gap:.95rem; margin-bottom:2.2rem; }
.pkg-features li{ display:flex; gap:.8rem; align-items:flex-start; font-size:.98rem; color:var(--ink-2); line-height:1.5; }
.pkg--featured .pkg-features li{ color:rgba(247,242,234,.82); }
.pkg-features .ic{ flex:none; width:20px; height:20px; border-radius:50%; background:var(--gold-soft);
  color:var(--gold-deep); display:grid; place-items:center; font-size:.65rem; margin-top:.15rem; }
.pkg--featured .pkg-features .ic{ background:rgba(210,179,119,.18); color:var(--gold-2); }
.pkg-features li.ph{ font-style:italic; color:var(--ink-3); }
.pkg--featured .pkg-features li.ph{ color:rgba(247,242,234,.55); }
.pkg .btn{ width:100%; justify-content:center; margin-top:auto; }
.pkg-note{ text-align:center; margin-top:2rem; font-size:.85rem; color:var(--ink-3); }

/* ============================================================
   DYNAMIC LAYER — cursor · progress · marquee · img reveal
   ============================================================ */

/* Scroll progress bar */
.scroll-prog{ position:fixed; top:var(--bar-h,0); left:0; height:2px; width:100%; z-index:1200;
  transform:scaleX(0); transform-origin:0 50%;
  background:linear-gradient(90deg,var(--gold-2),var(--gold-deep)); }

/* Custom cursor (desktop pointer only) */
.cursor,.cursor-dot{ display:none; }
@media (hover:hover) and (pointer:fine){
  html.gsap, html.gsap *{ cursor:none; }
  html.gsap input, html.gsap textarea{ cursor:text; }
  .cursor{ display:block; position:fixed; top:0; left:0; width:44px; height:44px;
    border:1px solid var(--gold-deep); border-radius:50%; pointer-events:none; z-index:1300;
    transform:translate(-50%,-50%); transition:width .3s var(--ease), height .3s var(--ease),
    background .3s var(--ease), opacity .3s var(--ease); }
  .cursor.is-hover{ width:72px; height:72px; background:var(--gold-soft); border-color:transparent; }
  .cursor.is-down{ width:34px; height:34px; }
  .cursor-dot{ display:block; position:fixed; top:0; left:0; width:6px; height:6px; border-radius:50%;
    background:var(--gold-deep); pointer-events:none; z-index:1301; transform:translate(-50%,-50%); }
  .cursor.is-hover + .cursor-dot{ opacity:0; }
}

/* Image clip reveal (IntersectionObserver-driven, independent of GSAP) */
.img-reveal{ clip-path:inset(0 0 102% 0); transition:clip-path 1.15s var(--ease-out); }
.img-reveal.shown{ clip-path:inset(0 0 0% 0); }
@media (prefers-reduced-motion: reduce){ .img-reveal{ clip-path:none; transition:none; } }

/* Marquee band */
.marquee{ background:var(--ink); color:var(--paper); padding-block:clamp(1.1rem,2.4vw,1.8rem);
  overflow:hidden; white-space:nowrap; position:relative; }
.marquee::before,.marquee::after{ content:""; position:absolute; top:0; bottom:0; width:14%; z-index:2; pointer-events:none; }
.marquee::before{ left:0; background:linear-gradient(90deg,var(--ink),transparent); }
.marquee::after{ right:0; background:linear-gradient(270deg,var(--ink),transparent); }
.marquee-track{ display:inline-flex; align-items:center; gap:2.6rem; will-change:transform;
  animation:marq 32s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--serif); font-style:italic; font-size:clamp(1.3rem,1rem + 1.5vw,2.3rem);
  color:var(--paper); }
.marquee-track .sep{ color:var(--gold-2); font-style:normal; font-size:1em; }
@keyframes marq{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .marquee-track{ animation:none; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .approach-grid,.empathy-grid,.story-grid,.forwhom-grid,.includes-grid,.notincl-grid,.contact-grid,.offer-card{ grid-template-columns:1fr; }
  .voices-grid{ grid-template-columns:1fr; }
  .phases-grid{ grid-template-columns:1fr 1fr; }
  .story-media{ position:static; max-width:420px; }
  .offer-card .media{ min-height:320px; }
  .approach-media{ max-width:480px; }
  .flow-grid{ grid-template-columns:1fr; }
  .flow-step .conn{ display:none; }
  .pkg-grid{ grid-template-columns:1fr; max-width:520px; margin-inline:auto; }
}
@media (max-width:1080px){
  .nav-links{ display:none; }
  .nav-cta .btn{ display:none; }
  .burger{ display:block; }
}
@media (max-width:680px){
  .nav-links,.nav-cta .btn{ display:none; }
  .burger{ display:block; }
  .phases-grid{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; gap:2.4rem; }
  .couplet{ grid-template-columns:1fr; text-align:center; gap:.3rem; }
  .couplet .now,.couplet .was{ text-align:center; }
  .couplet .arrow{ display:none; }
  .approach-media .badge{ left:50%; translate:-50% 50%; bottom:0; }
  .hero{ min-height:92svh; }
}
