/* =========================================================
   TELLER & TALENTE — Design System
   Apple × Porsche × Premium Gastronomie
   Strikt Schwarz / Weiß · Montserrat · viel Weißraum
   ========================================================= */

:root{
  /* Graustufen-Skala (ausschließlich Schwarz/Weiß-Welt) */
  --ink:        #0A0A0A;   /* Schrift / Schwarzflächen */
  --ink-2:      #1A1A1A;
  --paper:      #FFFFFF;
  --paper-2:    #FAFAF9;   /* dezentes Off-White zur Flächentrennung */
  --line:       #E6E4E0;   /* Haarlinien */
  --line-2:     #D6D4CF;
  --muted:      #6E6E6E;   /* Sekundärtext */
  --muted-2:    #9A9A9A;
  --inverse-muted:#B5B5B5;

  /* Typo */
  --f: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* Maße */
  --maxw: 1180px;
  --gutter: clamp(20px, 5vw, 48px);
  --radius: 2px;

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

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--f);
  color:var(--ink);
  background:var(--paper);
  font-weight:400;
  line-height:1.62;
  font-size:17px;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }

::selection{ background:var(--ink); color:var(--paper); }

/* ---------- Layout-Helfer ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px,11vw,148px); }
.section--tight{ padding-block:clamp(56px,8vw,96px); }
.dark{ background:var(--ink); color:var(--paper); }
.dark .muted{ color:var(--inverse-muted); }
.soft{ background:var(--paper-2); }
.center{ text-align:center; }
.rule{ height:1px; background:var(--line); border:0; margin:0; }
.dark .rule{ background:rgba(255,255,255,.14); }

/* ---------- Typo-Skala ---------- */
.eyebrow{
  font-size:12px; font-weight:600; letter-spacing:.28em; text-transform:uppercase;
  color:var(--muted); margin:0 0 22px;
}
.dark .eyebrow{ color:var(--inverse-muted); }
.eyebrow::before{
  content:""; display:inline-block; width:26px; height:1px; background:currentColor;
  vertical-align:middle; margin-right:14px; opacity:.6;
}

h1,h2,h3{ font-weight:800; letter-spacing:-.022em; line-height:1.04; margin:0; }
.h-hero{ font-size:clamp(2.6rem,7.2vw,5.6rem); line-height:.98; }
.h-sec{ font-size:clamp(2rem,4.6vw,3.4rem); }
.h-sub{ font-size:clamp(1.3rem,2.4vw,1.85rem); font-weight:700; letter-spacing:-.015em; }
.lede{
  font-size:clamp(1.05rem,1.7vw,1.32rem); font-weight:400; line-height:1.55;
  color:var(--muted); max-width:46ch;
}
.dark .lede{ color:var(--inverse-muted); }
.measure{ max-width:62ch; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink); --fg:var(--paper);
  position:relative; display:inline-flex; align-items:center; gap:.7em;
  padding:1.02em 1.7em; background:var(--bg); color:var(--fg);
  font-weight:600; font-size:.96rem; letter-spacing:.01em; border:1px solid var(--bg);
  border-radius:var(--radius); cursor:pointer; overflow:hidden; isolation:isolate;
  transition:transform .5s var(--ease-out), box-shadow .5s var(--ease-out);
}
.btn .arw{ transition:transform .45s var(--ease-out); }
.btn::after{
  content:""; position:absolute; inset:0; z-index:-1; background:var(--fg);
  transform:translateY(101%); transition:transform .5s var(--ease-out);
}
.btn:hover{ color:var(--bg); transform:translateY(-2px); box-shadow:0 18px 40px -22px rgba(0,0,0,.55); }
.btn:hover::after{ transform:translateY(0); }
.btn:hover .arw{ transform:translateX(5px); }
.btn--ghost{ --bg:transparent; --fg:var(--ink); border-color:var(--line-2); }
.btn--ghost::after{ background:var(--ink); }
.btn--ghost:hover{ color:var(--paper); }
.dark .btn{ --bg:var(--paper); --fg:var(--ink); }
.dark .btn--ghost{ --bg:transparent; --fg:var(--paper); border-color:rgba(255,255,255,.3); }
.dark .btn--ghost::after{ background:var(--paper); }
.dark .btn--ghost:hover{ color:var(--ink); }

.txtlink{
  display:inline-flex; align-items:center; gap:.5em; font-weight:600; font-size:.95rem;
  border-bottom:1px solid currentColor; padding-bottom:2px; transition:gap .35s var(--ease-out);
}
.txtlink:hover{ gap:.9em; }

:focus-visible{ outline:2px solid var(--ink); outline-offset:3px; border-radius:2px; }
.dark :focus-visible{ outline-color:#fff; }

/* ---------- Navbar ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter); transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(255,255,255,.82); backdrop-filter:saturate(180%) blur(14px);
  border-bottom-color:var(--line); padding-block:13px;
}
.nav__logo img{ height:21px; width:auto; }
.nav__right{ display:flex; align-items:center; gap:22px; }
.nav__back{ font-size:.9rem; font-weight:500; color:var(--muted); transition:color .3s; }
.nav__back:hover{ color:var(--ink); }
.nav .btn{ padding:.7em 1.25em; font-size:.86rem; }
@media (max-width:620px){
  .nav__back{ display:none; }
  .nav__logo img{ height:18px; }
}

/* ---------- Reveal-Animationen ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.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; }

/* =========================================================
   STARTSEITE — Split-Hero, kein Scroll
   ========================================================= */
.home{ min-height:100svh; min-height:100vh; display:flex; flex-direction:column; }
.home__top{
  display:flex; align-items:center; justify-content:space-between;
  padding:26px var(--gutter); flex:0 0 auto;
}
.home__top img{ height:22px; }
.home__top .meta{ font-size:.78rem; letter-spacing:.22em; text-transform:uppercase; color:var(--inverse-muted); }
.home__intro{ text-align:center; padding:clamp(28px,6vh,70px) var(--gutter) clamp(18px,3vh,34px); flex:0 0 auto; }
.home__intro .lede{ margin:18px auto 0; color:var(--inverse-muted); text-align:center; }
.home__tiles{ flex:1 1 auto; display:grid; grid-template-columns:1fr 1fr; min-height:0; border-top:1px solid rgba(255,255,255,.12); }

.tile{
  position:relative; display:flex; flex-direction:column; justify-content:flex-end;
  padding:clamp(32px,4.5vw,64px); min-height:clamp(340px,46vh,560px);
  color:var(--paper); overflow:hidden; isolation:isolate; cursor:pointer;
  transition:flex-grow .6s var(--ease);
}
.tile + .tile{ border-left:1px solid rgba(255,255,255,.12); }
.tile__bg{ position:absolute; inset:0; z-index:-2; background:var(--ink); }
.tile__fill{ position:absolute; inset:0; z-index:-1; background:var(--paper); transform:translateY(100%); transition:transform .7s var(--ease-out); }
.tile:hover .tile__fill{ transform:translateY(0); }
.tile, .tile *{ transition:color .5s var(--ease-out); }
.tile:hover{ color:var(--ink); }
.tile__icon{ font-size:1.7rem; margin-bottom:auto; opacity:.92; filter:grayscale(1); }
.tile__num{ position:absolute; top:clamp(26px,3.5vw,52px); right:clamp(26px,3.5vw,52px); font-size:.8rem; letter-spacing:.2em; color:var(--inverse-muted); }
.tile:hover .tile__num{ color:var(--muted); }
.tile h2{ font-size:clamp(1.9rem,3.4vw,2.9rem); letter-spacing:-.02em; margin:0 0 10px; }
.tile p{ margin:0 0 26px; color:var(--inverse-muted); max-width:30ch; font-size:1.02rem; }
.tile:hover p{ color:var(--muted); }
.tile__cta{ display:inline-flex; align-items:center; gap:.6em; font-weight:600; font-size:.98rem; }
.tile__cta .arw{ transition:transform .45s var(--ease-out); }
.tile:hover .tile__cta .arw{ transform:translateX(6px); }
.home__foot{ flex:0 0 auto; padding:16px var(--gutter); display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:.76rem; color:var(--inverse-muted); border-top:1px solid rgba(255,255,255,.12); }
.home__foot a:hover{ color:#fff; }

@media (max-width:780px){
  .home__tiles{ grid-template-columns:1fr; }
  .tile + .tile{ border-left:0; border-top:1px solid rgba(255,255,255,.12); }
  .tile{ min-height:clamp(280px,38vh,420px); }
}

/* =========================================================
   LANDINGPAGES
   ========================================================= */
.lp-hero{
  position:relative; padding-top:clamp(150px,20vh,220px); padding-bottom:clamp(70px,10vw,120px);
  overflow:hidden;
}
.lp-hero .eyebrow{ color:var(--inverse-muted); }
.lp-hero__grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(34px,5vw,72px); align-items:end; }
.lp-hero h1{ font-size:clamp(2.5rem,6.2vw,5rem); }
.lp-hero .lede{ color:var(--inverse-muted); margin-top:26px; }
.lp-hero__actions{ margin-top:38px; display:flex; gap:14px; flex-wrap:wrap; }
.lp-hero__aside{ padding-bottom:8px; }
.statline{ display:flex; flex-direction:column; gap:22px; }
.statline .stat{ border-top:1px solid rgba(255,255,255,.16); padding-top:16px; }
.statline .stat b{ display:block; font-size:clamp(2rem,3.4vw,2.7rem); font-weight:800; letter-spacing:-.02em; line-height:1; }
.statline .stat span{ font-size:.86rem; color:var(--inverse-muted); }
@media (max-width:860px){ .lp-hero__grid{ grid-template-columns:1fr; align-items:start; gap:40px; } }

/* Section-Kopf */
.sec-head{ display:grid; grid-template-columns:1fr 1fr; gap:30px; align-items:end; margin-bottom:clamp(40px,5vw,64px); }
.sec-head .lede{ margin:0; }
@media (max-width:760px){ .sec-head{ grid-template-columns:1fr; gap:16px; } }

/* Problem-Liste */
.pains{ display:grid; grid-template-columns:repeat(2,1fr); gap:0; border-top:1px solid var(--line); }
.dark .pains{ border-top-color:rgba(255,255,255,.14); }
.pain{ padding:30px 26px 30px 0; border-bottom:1px solid var(--line); display:flex; gap:18px; align-items:flex-start; }
.dark .pain{ border-bottom-color:rgba(255,255,255,.14); }
.pain:nth-child(odd){ padding-right:40px; }
.pain__no{ font-size:.78rem; font-weight:600; color:var(--muted-2); letter-spacing:.12em; padding-top:4px; min-width:30px; }
.pain h3{ font-size:1.12rem; font-weight:700; letter-spacing:-.01em; margin:0 0 6px; }
.pain p{ margin:0; font-size:.96rem; color:var(--muted); }
.dark .pain p{ color:var(--inverse-muted); }
@media (max-width:680px){ .pains{ grid-template-columns:1fr; } .pain:nth-child(odd){ padding-right:0; } }

/* Kostenrechner */
.calc{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(34px,5vw,76px); align-items:center; }
@media (max-width:880px){ .calc{ grid-template-columns:1fr; gap:46px; } }
.calc__controls{ display:flex; flex-direction:column; gap:34px; }
.ctrl label{ display:flex; justify-content:space-between; align-items:baseline; font-weight:600; font-size:.98rem; margin-bottom:14px; }
.ctrl label .val{ font-size:1.45rem; font-weight:800; letter-spacing:-.02em; }
.ctrl input[type=range]{ -webkit-appearance:none; appearance:none; width:100%; height:2px; background:var(--line-2); border-radius:2px; outline-offset:6px; }
.dark .ctrl input[type=range]{ background:rgba(255,255,255,.22); }
.ctrl input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:22px; height:22px; border-radius:50%; background:var(--ink); border:3px solid var(--paper); box-shadow:0 2px 10px rgba(0,0,0,.25); cursor:pointer; transition:transform .25s var(--ease-out); }
.dark .ctrl input[type=range]::-webkit-slider-thumb{ background:var(--paper); border-color:var(--ink); }
.ctrl input[type=range]::-webkit-slider-thumb:hover{ transform:scale(1.12); }
.ctrl input[type=range]::-moz-range-thumb{ width:22px; height:22px; border-radius:50%; background:var(--ink); border:3px solid var(--paper); cursor:pointer; }
.ctrl .hint{ font-size:.8rem; color:var(--muted-2); margin-top:10px; }
.dark .ctrl .hint{ color:var(--inverse-muted); }

.calc__out{ border:1px solid rgba(255,255,255,.16); padding:clamp(30px,4vw,52px); border-radius:var(--radius); }
.calc__out .k{ font-size:.78rem; letter-spacing:.22em; text-transform:uppercase; color:var(--inverse-muted); margin:0 0 12px; }
.calc__big{ font-size:clamp(2.8rem,7vw,4.6rem); font-weight:800; letter-spacing:-.03em; line-height:1; font-variant-numeric:tabular-nums; }
.calc__sub{ margin:18px 0 0; color:var(--inverse-muted); font-size:.95rem; }
.calc__row{ display:flex; justify-content:space-between; padding:14px 0; border-top:1px solid rgba(255,255,255,.14); font-size:.95rem; }
.calc__row:first-of-type{ margin-top:26px; }
.calc__row span:last-child{ font-weight:700; font-variant-numeric:tabular-nums; }

/* Case Studies */
.cases{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.dark .cases{ background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.14); }
.case{ background:var(--paper); padding:clamp(28px,3vw,40px); display:flex; flex-direction:column; gap:14px; transition:background .4s var(--ease); }
.dark .case{ background:var(--ink); }
.case:hover{ background:var(--paper-2); }
.dark .case:hover{ background:var(--ink-2); }
.case__tag{ font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted-2); }
.case__big{ font-size:clamp(2.1rem,3vw,2.7rem); font-weight:800; letter-spacing:-.025em; line-height:1; }
.case__name{ font-weight:700; font-size:1.05rem; }
.case p{ margin:0; color:var(--muted); font-size:.95rem; }
.dark .case p{ color:var(--inverse-muted); }
@media (max-width:840px){ .cases{ grid-template-columns:1fr; } }

/* System / Prozess */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.step{ padding:34px 26px 38px 0; border-top:2px solid var(--ink); position:relative; }
.dark .step{ border-top-color:var(--paper); }
.step + .step{ padding-left:26px; }
.step__no{ font-size:.8rem; font-weight:700; letter-spacing:.14em; color:var(--muted); margin-bottom:18px; }
.dark .step__no{ color:var(--inverse-muted); }
.step h3{ font-size:1.25rem; font-weight:700; letter-spacing:-.01em; margin:0 0 10px; }
.step p{ margin:0; font-size:.94rem; color:var(--muted); }
.dark .step p{ color:var(--inverse-muted); }
@media (max-width:860px){ .steps{ grid-template-columns:1fr 1fr; } .step + .step{ padding-left:0; } .step:nth-child(even){ padding-left:26px; } }
@media (max-width:520px){ .steps{ grid-template-columns:1fr; } .step:nth-child(even){ padding-left:0; } }

/* Bild-Platzhalter (echte Fotos später einsetzen) */
.imgslot{
  position:relative; background:
    repeating-linear-gradient(135deg, var(--paper-2) 0 18px, #F1F0EE 18px 36px);
  border:1px solid var(--line); border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center; aspect-ratio:16/10; overflow:hidden;
}
.imgslot__label{ text-align:center; color:var(--muted); padding:24px; }
.imgslot__label .ic{ font-size:1.4rem; display:block; margin-bottom:10px; opacity:.5; }
.imgslot__label b{ display:block; font-weight:700; color:var(--ink); font-size:.98rem; letter-spacing:-.01em; }
.imgslot__label span{ font-size:.82rem; }

/* FAQ */
.faq{ border-top:1px solid var(--line); max-width:880px; margin-inline:auto; }
.dark .faq{ border-top-color:rgba(255,255,255,.14); }
.faq__item{ border-bottom:1px solid var(--line); }
.dark .faq__item{ border-bottom-color:rgba(255,255,255,.14); }
.faq__q{
  width:100%; background:none; border:0; cursor:pointer; text-align:left;
  display:flex; gap:20px; align-items:center; justify-content:space-between;
  padding:26px 4px; font-size:1.08rem; font-weight:600; letter-spacing:-.01em; color:inherit;
}
.faq__q:hover{ opacity:.7; }
.faq__sign{ position:relative; width:16px; height:16px; flex:0 0 auto; }
.faq__sign::before,.faq__sign::after{ content:""; position:absolute; background:currentColor; transition:transform .4s var(--ease-out), opacity .3s; }
.faq__sign::before{ top:7px; left:0; width:16px; height:2px; }
.faq__sign::after{ left:7px; top:0; width:2px; height:16px; }
.faq__item.open .faq__sign::after{ transform:scaleY(0); opacity:0; }
.faq__a{ overflow:hidden; height:0; transition:height .45s var(--ease-out); }
.faq__a .inner{ padding:0 4px 28px; color:var(--muted); max-width:70ch; font-size:1rem; }
.dark .faq__a .inner{ color:var(--inverse-muted); }

/* Großer CTA */
.cta-final{ text-align:center; }
.cta-final h2{ margin:0 auto 22px; max-width:18ch; }
.cta-final .lede{ margin:0 auto 38px; text-align:center; }
.cta-meta{ margin-top:28px; display:flex; gap:30px; justify-content:center; flex-wrap:wrap; font-size:.88rem; color:var(--inverse-muted); }
.cta-meta span{ display:inline-flex; align-items:center; gap:.5em; }

/* Footer */
.foot{ padding-block:clamp(54px,6vw,80px); }
.foot__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; align-items:start; }
.foot__logo img{ height:24px; margin-bottom:18px; }
.foot__claim{ color:var(--inverse-muted); font-size:.92rem; max-width:34ch; }
.foot h4{ font-size:.76rem; letter-spacing:.2em; text-transform:uppercase; color:var(--inverse-muted); margin:0 0 18px; font-weight:600; }
.foot ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px; }
.foot a{ color:#D9D9D9; font-size:.95rem; }
.foot a:hover{ color:#fff; }
.foot__bar{ margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.14); display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:.82rem; color:var(--inverse-muted); }
.flag{ background:rgba(255,255,255,.07); border:1px dashed rgba(255,255,255,.25); padding:2px 8px; border-radius:3px; font-size:.78rem; }
@media (max-width:760px){ .foot__grid{ grid-template-columns:1fr; gap:34px; } }

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

/* Navbar Logo-Swap (über dunklem Hero weiß, nach Scroll dunkel) */
.nav__logo{ position:relative; display:block; line-height:0; }
.nav__logo img{ display:block; transition:opacity .35s var(--ease); }
.nav__logo .ld{ position:absolute; inset:0; opacity:0; }
.nav.scrolled .nav__logo .lw{ opacity:0; }
.nav.scrolled .nav__logo .ld{ opacity:1; }
.nav.scrolled .nav__back{ color:var(--muted); }
.nav.scrolled .btn{ --bg:var(--ink); --fg:var(--paper); }

/* Mobile-Feinschliff Startseite */
@media (max-width:640px){
  .home__top .meta{ display:none; }
  .home__top{ padding-block:20px; }
}

/* ---------- Kundenlogos in Case-Karten (Gäste) ---------- */
.case__logo{
  width:80px; height:80px; border-radius:50%; overflow:hidden; margin-bottom:4px;
  display:flex; align-items:center; justify-content:center;
  background:var(--paper); border:1px solid var(--line);
}
.case__logo img{
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(1) contrast(1.02); transition:filter .55s var(--ease);
}
.case:hover .case__logo img{ filter:none; }

/* ---------- Echte Testimonial-Fotos (Mitarbeiter) ---------- */
.testi{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.testi figure{
  margin:0; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; background:var(--paper); transition:transform .6s var(--ease-out), box-shadow .6s var(--ease-out);
}
.testi img{
  width:100%; height:auto; display:block;
  filter:grayscale(1) contrast(1.03); transition:filter .6s var(--ease);
}
.testi figure:hover{ transform:translateY(-4px); box-shadow:0 26px 50px -30px rgba(0,0,0,.5); }
.testi figure:hover img{ filter:none; }
.testi figcaption{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }
@media (max-width:840px){ .testi{ grid-template-columns:1fr; max-width:430px; margin-inline:auto; } }

/* =========================================================
   CRO-OPTIMIERUNGEN
   ========================================================= */

/* Ergebnis-Leiste direkt unter dem Hero */
.proofbar{ border-top:1px solid rgba(255,255,255,.16); margin-top:clamp(34px,5vw,56px); }
.proofbar__grid{ display:grid; grid-template-columns:repeat(3,1fr); }
.proofbar .pf{ padding:clamp(24px,3vw,32px) 0; padding-right:26px; border-left:1px solid rgba(255,255,255,.16); padding-left:clamp(20px,2.4vw,32px); }
.proofbar .pf:first-child{ border-left:0; padding-left:0; }
.proofbar .pf b{ display:block; font-size:clamp(1.9rem,3.4vw,2.7rem); font-weight:800; letter-spacing:-.025em; line-height:1; }
.proofbar .pf .lbl{ display:block; font-size:.92rem; margin-top:10px; color:#EDEDED; line-height:1.4; }
.proofbar .pf .src{ display:block; font-size:.78rem; margin-top:8px; color:var(--inverse-muted); letter-spacing:.02em; }
@media (max-width:720px){
  .proofbar__grid{ grid-template-columns:1fr; }
  .proofbar .pf{ border-left:0; padding-left:0; padding-right:0; border-top:1px solid rgba(255,255,255,.14); }
  .proofbar .pf:first-child{ border-top:0; }
}

/* Inline-CTA-Band (Mitte der Seite) */
.cta-band{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.dark .cta-band{ border-color:rgba(255,255,255,.14); }
.cta-band .wrap{ display:flex; align-items:center; justify-content:space-between; gap:26px; padding-block:clamp(30px,4vw,44px); flex-wrap:wrap; }
.cta-band h3{ font-size:clamp(1.3rem,2.4vw,1.9rem); font-weight:800; letter-spacing:-.02em; margin:0; max-width:24ch; }
.cta-band .sub{ margin:8px 0 0; color:var(--muted); font-size:.95rem; }
.cta-band__act{ display:flex; flex-direction:column; gap:8px; align-items:flex-start; }
.cta-band__meta{ font-size:.8rem; color:var(--muted-2); }

/* Risiko-Umkehr / Vertrauenszusicherungen */
.assure{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:30px; }
.assure .a{ display:inline-flex; align-items:center; gap:9px; font-size:.9rem; color:var(--inverse-muted); border:1px solid rgba(255,255,255,.18); border-radius:999px; padding:9px 16px; }
.assure .a .ti{ font-size:16px; }
.risk{ max-width:60ch; margin:26px auto 0; text-align:center; color:var(--inverse-muted); font-size:.96rem; line-height:1.6; }

/* Vertrauensband (hell) */
.trustband{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--paper-2); }
.trustband .wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; }
.trustband .tb{ padding:26px 22px; display:flex; gap:12px; align-items:flex-start; }
.trustband .tb .ti{ font-size:20px; margin-top:2px; }
.trustband .tb b{ display:block; font-size:.98rem; font-weight:700; letter-spacing:-.01em; }
.trustband .tb span{ font-size:.86rem; color:var(--muted); }
@media (max-width:760px){ .trustband .wrap{ grid-template-columns:1fr 1fr; } }
@media (max-width:440px){ .trustband .wrap{ grid-template-columns:1fr; } }

/* Mobile Sticky-CTA unten */
.mobile-cta{ display:none; }
@media (max-width:768px){
  .mobile-cta{
    display:flex; position:fixed; left:0; right:0; bottom:0; z-index:75; gap:12px; align-items:center;
    padding:11px 14px calc(11px + env(safe-area-inset-bottom,0px));
    background:rgba(10,10,10,.94); backdrop-filter:saturate(180%) blur(12px);
    border-top:1px solid rgba(255,255,255,.16);
  }
  .mobile-cta .mc-meta{ flex:0 0 auto; font-size:.72rem; line-height:1.2; color:var(--inverse-muted); }
  .mobile-cta .btn{ flex:1 1 auto; justify-content:center; padding:.9em 1em; }
  body.has-mcta{ padding-bottom:74px; }
}

/* Hero: Sub-Zeile unter CTAs (Mikro-Vertrauen) */
.hero-microtrust{ margin-top:18px; font-size:.86rem; color:var(--inverse-muted); display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.hero-microtrust .ti{ font-size:15px; }
.btn .btn-sub{ font-weight:500; opacity:.8; font-size:.8em; margin-left:.1em; }

/* Startseite: dezente Vertrauenszeile */
.home__trust{ text-align:center; font-size:.8rem; letter-spacing:.04em; color:var(--inverse-muted); padding:0 var(--gutter) 8px; }
.home__trust b{ color:#fff; font-weight:600; }

/* Hero Single-Column-Variante */
.lp-hero__grid--solo{ display:block; }
.lp-hero__grid--solo > div{ max-width:30ch; }
.lp-hero__grid--solo h1{ max-width:18ch; }
.lp-hero__grid--solo .lede{ max-width:54ch; }
.lp-hero__grid--solo > div{ max-width:none; }

/* Mobil: oberer Navi-CTA entfällt (Sticky-Bar unten übernimmt) */
@media (max-width:620px){
  .nav .btn{ display:none; }
  .nav__right{ gap:0; }
}

/* =========================================================
   BUTTON-BEWEGUNG (dezent, dauerhaft)
   ========================================================= */
@keyframes ttSheen{
  0%   { transform:translateX(-140%) skewX(-18deg); }
  18%  { transform:translateX(240%)  skewX(-18deg); }
  100% { transform:translateX(240%)  skewX(-18deg); }
}
@keyframes ttArrow{
  0%,100% { transform:translateX(0); }
  50%     { transform:translateX(4px); }
}

/* Lichtschimmer über jeden Button */
.btn::before{
  content:""; position:absolute; top:0; bottom:0; left:0; width:34%; z-index:-1;
  background:linear-gradient(90deg, transparent, rgba(150,150,150,.45), transparent);
  transform:translateX(-140%) skewX(-18deg);
  animation:ttSheen 5s ease-in-out infinite;
  pointer-events:none;
}
.btn:hover::before{ animation-play-state:paused; opacity:0; }

/* Sanft nickender Pfeil bei allen CTAs mit Pfeil */
.btn .arw{ animation:ttArrow 1.8s ease-in-out infinite; }
.btn:hover .arw{ animation:none; }
.tile__cta .arw{ animation:ttArrow 1.8s ease-in-out infinite; }
.tile:hover .tile__cta .arw{ animation:none; }

/* Sticky-Mobile-CTA: gleicher Schimmer (erbt über .btn) */

@media (prefers-reduced-motion:reduce){
  .btn::before{ animation:none; }
  .btn .arw, .tile__cta .arw{ animation:none; }
}

/* Vertrauensleiste unter dem Hero (helle Logos + Ergebnis) */
.proofstrip{ background:var(--paper); border-bottom:1px solid var(--line); }
.proofstrip .wrap{ padding-block:clamp(26px,3.2vw,40px); }
.proofstrip__intro{ font-size:.76rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--muted-2); margin:0 0 22px; }
.proofstrip__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; }
.proofstrip .ps{ display:flex; gap:16px; align-items:center; padding:6px 28px 6px 0; border-left:1px solid var(--line); padding-left:30px; }
.proofstrip .ps:first-child{ border-left:0; padding-left:0; }
.proofstrip .ps__logo{ width:56px; height:56px; border-radius:50%; flex:0 0 auto; overflow:hidden; border:1px solid var(--line); background:#fff; }
.proofstrip .ps__logo img{ width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.02); transition:filter .55s var(--ease); }
.proofstrip .ps:hover .ps__logo img{ filter:none; }
.proofstrip .ps b{ display:block; font-size:1.04rem; font-weight:700; letter-spacing:-.012em; line-height:1.2; }
.proofstrip .ps span{ display:block; font-size:.82rem; color:var(--muted); margin-top:5px; }
@media (max-width:820px){
  .proofstrip__grid{ grid-template-columns:1fr; gap:0; }
  .proofstrip .ps{ border-left:0; padding-left:0; padding-block:16px; border-top:1px solid var(--line); }
  .proofstrip .ps:first-child{ border-top:0; padding-top:0; }
}

/* Logo-Laufband auf der Startseite */
.logobar{ overflow:hidden; padding:4px 0 14px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); }
.logobar__track{ display:flex; gap:14px; width:max-content; animation:logoscroll 34s linear infinite; }
.logobar:hover .logobar__track{ animation-play-state:paused; }
.logobar__item{ flex:0 0 auto; width:148px; height:72px; background:#fff; border-radius:7px;
  display:flex; align-items:center; justify-content:center; padding:13px 16px; }
.logobar__item img{ max-width:100%; max-height:100%; object-fit:contain;
  filter:grayscale(1) contrast(1.03); opacity:.9; }
@keyframes logoscroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .logobar__track{ animation:none; } }
@media (max-width:640px){ .logobar__item{ width:124px; height:62px; padding:11px 13px; } }

/* =========================================================
   ÜBER FUUF (Gründer-Abschnitt)
   ========================================================= */
.founder{ display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(34px,5vw,72px); align-items:start; }
.founder__media{ position:sticky; top:100px; }
.founder__media .imgslot{ aspect-ratio:3/4; }
.founder__text .eyebrow{ margin-bottom:18px; }
.founder__text h2{ margin-bottom:30px; }
.prose p{ margin:0 0 18px; color:var(--muted); font-size:1.04rem; line-height:1.72; }
.prose strong{ color:var(--ink); font-weight:600; }
.prose ul{ margin:6px 0 20px; padding:0; list-style:none; display:flex; flex-direction:column; gap:11px; }
.prose ul li{ position:relative; padding-left:28px; color:var(--ink); font-weight:600; }
.prose ul li::before{ content:""; position:absolute; left:0; top:.72em; width:14px; height:1px; background:var(--ink); }
.founder__sign{ font-weight:800; color:var(--ink); font-size:1.25rem; letter-spacing:-.015em; margin:28px 0 0; }
@media (max-width:840px){
  .founder{ grid-template-columns:1fr; gap:34px; }
  .founder__media{ position:static; max-width:340px; }
}

/* =========================================================
   RECHTSSEITEN (Impressum / Datenschutz)
   ========================================================= */
.legal-hero{ padding-top:clamp(130px,18vh,180px); padding-bottom:24px; }
.legal{ padding-bottom:clamp(60px,8vw,110px); }
.legal .wrap{ max-width:840px; }
.legal h2{ font-size:clamp(1.2rem,2vw,1.5rem); font-weight:800; letter-spacing:-.02em; margin:40px 0 14px; }
.legal h3{ font-size:1.04rem; font-weight:700; margin:26px 0 8px; }
.legal p, .legal address{ color:var(--muted); font-size:1rem; line-height:1.72; font-style:normal; margin:0 0 14px; }
.legal address b, .legal p b{ color:var(--ink); }
.legal a{ border-bottom:1px solid var(--line-2); }
.legal a:hover{ border-bottom-color:var(--ink); }
.legal ul{ margin:0 0 16px; padding-left:20px; color:var(--muted); line-height:1.7; }
.legal ul li{ margin-bottom:7px; }
.legal .note{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius); padding:15px 18px; font-size:.9rem; color:var(--muted); margin:8px 0 18px; }

/* Startseiten-Footer: Rechtslinks */
.home__foot-legal a{ color:var(--inverse-muted); }
.home__foot-legal a:hover{ color:#fff; }
@media (max-width:640px){ .home__foot-legal{ order:3; width:100%; } }

/* Solide Navigation für Rechtsseiten (heller Hintergrund von oben) */
.nav--solid{ background:rgba(255,255,255,.92); backdrop-filter:saturate(180%) blur(14px); border-bottom:1px solid var(--line); }
.nav--solid .nav__logo .lw{ opacity:0; }
.nav--solid .nav__logo .ld{ opacity:1; }
.nav--solid .nav__back{ color:var(--muted); }
.nav--solid .btn{ --bg:var(--ink); --fg:var(--paper); }

/* Gründer-Portrait */
.founder__photo{ margin:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--paper-2); aspect-ratio:1/1; }
.founder__photo img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; display:block; filter:grayscale(1) contrast(1.02); transition:filter .6s var(--ease); }
.founder__photo:hover img{ filter:none; }

/* Über-Fuuf: Porträtfoto */
.founder__photo{ margin:0; aspect-ratio:1/1; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--line); background:var(--paper-2); }
.founder__photo img{ width:100%; height:100%; object-fit:cover; display:block;
  filter:grayscale(1) contrast(1.02); transition:filter .6s var(--ease); }
.founder__photo:hover img{ filter:none; }

/* =========================================================
   OPT-IN LANDINGPAGES (Lead-Magnet)
   ========================================================= */
.optin-hero{ padding-top:clamp(120px,16vh,168px); padding-bottom:clamp(50px,7vw,88px); }
.optin__grid{ display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(30px,5vw,60px); align-items:center; }
.optin__visual{ display:flex; justify-content:center; }
.optin__visual img{ width:100%; max-width:430px; height:auto; }
.optin h1{ font-size:clamp(2rem,3.8vw,3rem); line-height:1.04; letter-spacing:-.03em; margin:12px 0 16px; }
.optin__sub{ color:var(--muted); font-size:1.1rem; line-height:1.55; margin-bottom:22px; max-width:46ch; }
.checks{ list-style:none; margin:0 0 6px; padding:0; display:flex; flex-direction:column; gap:11px; }
.checks li{ position:relative; padding-left:30px; color:#2a2a2a; line-height:1.45; }
.checks li::before{ content:"✓"; position:absolute; left:0; top:0; font-weight:800; }

.form-card{ background:var(--paper); border:1px solid var(--line); border-radius:14px;
  padding:26px 24px; box-shadow:0 22px 60px -30px rgba(0,0,0,.30); }
.form-card h3{ font-size:1.3rem; margin:0 0 4px; letter-spacing:-.01em; }
.form-card .fc-sub{ color:var(--muted); font-size:.95rem; margin:0 0 18px; }
.field{ margin-bottom:13px; }
.field label{ display:block; font-size:.78rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; margin-bottom:6px; color:#3a3a3a; }
.field input{ width:100%; padding:13px 15px; border:1px solid var(--line2); border-radius:8px; font:inherit; font-size:1rem; background:var(--paper-2); transition:border-color .2s, background .2s; }
.field input:focus{ outline:none; border-color:var(--ink); background:#fff; }
.consent{ display:flex; gap:10px; align-items:flex-start; margin:8px 0 18px; }
.consent input{ margin-top:3px; flex:0 0 auto; }
.consent label{ font-size:.8rem; color:var(--muted); line-height:1.5; }
.consent a{ text-decoration:underline; }
.form-card .btn{ width:100%; justify-content:center; }
.fc-trust{ text-align:center; font-size:.8rem; color:var(--muted2); margin-top:13px; }
/* Brevo-Embed-Slot: Hinweis nur als Platzhalter sichtbar */
.brevo-slot{ }

@media (max-width:820px){
  .optin__grid{ grid-template-columns:1fr; gap:30px; }
  .optin__visual{ order:-1; }
  .optin__visual img{ max-width:300px; }
}

/* =========================================================
   DANKE / DOWNLOAD-SEITEN
   ========================================================= */
.danke-hero{ padding-top:clamp(128px,17vh,176px); padding-bottom:clamp(60px,9vw,120px); text-align:center; }
.danke__wrap{ max-width:620px; margin:0 auto; }
.danke__cover{ width:150px; height:auto; margin:0 auto 24px; display:block;
  box-shadow:0 18px 44px -22px rgba(0,0,0,.4); border:1px solid var(--line); border-radius:4px; }
.danke h1{ font-size:clamp(2rem,4vw,2.9rem); letter-spacing:-.03em; line-height:1.05; margin:6px 0 16px; }
.danke p{ color:var(--muted); font-size:1.1rem; line-height:1.6; margin:0 auto 10px; max-width:48ch; }
.danke .dl{ margin:28px 0 6px; }
.danke .btn--xl{ font-size:1.05rem; padding:17px 32px; }
.danke__second{ margin-top:34px; padding-top:26px; border-top:1px solid var(--line); }
.danke__second p{ font-size:1rem; margin-bottom:16px; }

/* Zweizeiliger Button (Haupttext + kleiner Zusatz) */
.btn--stack{ flex-direction:column; gap:3px; align-items:center; line-height:1.12; text-align:center; }
.btn--stack .btn__sub{ font-size:.74rem; font-weight:500; opacity:.62; letter-spacing:.02em; }
