/* =====================================================================
   BellaFit · pages.css — Split-Screen, Heroes, Sektionen, Funnel
   ===================================================================== */

/* ============ OPENING SPLIT-SCREEN ============ */
.opener{height:100svh;min-height:620px;display:flex;position:relative;overflow:hidden;background:var(--ink)}
.opener__side{
  position:relative;flex:1 1 50%;min-width:0;overflow:hidden;
  display:flex;align-items:flex-end;
  transition:flex-grow .65s var(--ease-out),flex-basis .65s var(--ease-out);
  cursor:pointer;color:#fff;text-decoration:none;
}
/* Bild als <img> mit object-fit + Focal-Point — kein Überlaufen, Person bleibt sichtbar */
.opener__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transform:scale(1.04);transition:transform 1.2s var(--ease-out);will-change:transform}
.opener__side--fl .opener__img{object-position:62% 32%}
.opener__side--pm .opener__img{object-position:58% 30%}
/* Overlay: ruhiger Marken-Verlauf + Vignette für Lesbarkeit */
.opener__side::after{content:"";position:absolute;inset:0;z-index:1;transition:opacity .6s}
.opener__side--fl::after{background:
  linear-gradient(0deg,rgba(74,0,9,.92) 0%,rgba(96,0,12,.42) 42%,rgba(120,4,18,.30) 100%),
  radial-gradient(120% 80% at 50% 0%,rgba(226,0,26,.18),transparent 60%)}
.opener__side--pm::after{background:
  linear-gradient(0deg,rgba(0,18,42,.92) 0%,rgba(0,26,56,.44) 42%,rgba(0,34,72,.30) 100%),
  radial-gradient(120% 80% at 50% 0%,rgba(0,97,176,.20),transparent 60%)}
.opener__content{position:relative;z-index:2;padding:clamp(32px,5vw,84px);max-width:540px;width:100%;
  transition:transform .6s var(--ease-out),opacity .6s}
.opener__eyebrow{font-weight:600;font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.7em;margin-bottom:20px;color:rgba(255,255,255,.92)}
.opener__eyebrow .dot{width:8px;height:8px;border-radius:50%;background:currentColor;box-shadow:0 0 0 4px rgba(255,255,255,.18)}
.opener__side--fl .opener__eyebrow .dot{color:#ff5e6e}
.opener__side--pm .opener__eyebrow .dot{color:#5aa6e8}
.opener__title{font-family:var(--font-display);font-weight:600;color:#fff;
  font-size:clamp(2rem,3.7vw,3.3rem);line-height:1.06;letter-spacing:-.03em;margin-bottom:16px;
  text-shadow:0 2px 30px rgba(0,0,0,.28);text-wrap:balance}
.opener__sub{font-size:clamp(1rem,1.2vw,1.15rem);line-height:1.55;color:rgba(255,255,255,.9);max-width:40ch;margin-bottom:28px}
.opener__go{display:inline-flex;align-items:center;gap:.7em;font-weight:600;font-size:1rem;
  padding:.95rem 1.7rem;border-radius:var(--r-pill);background:rgba(255,255,255,.12);color:#fff;
  border:1.5px solid rgba(255,255,255,.6);backdrop-filter:blur(6px);
  transition:background .3s,color .3s,gap .3s,transform .3s,box-shadow .3s}
.opener__go svg{width:1.15em;height:1.15em;transition:transform .3s}
.opener__side:hover .opener__go,.opener__side:focus-visible .opener__go{background:#fff;gap:1em;transform:translateY(-2px);box-shadow:var(--sh-lg)}
.opener__side--fl:hover .opener__go{color:var(--fl)}
.opener__side--pm:hover .opener__go{color:var(--pm)}

/* Hover: aktive Seite wächst, andere zieht sich zurück */
@media (hover:hover) and (min-width:861px){
  .opener:hover .opener__side{flex-grow:.78}
  .opener:hover .opener__side:hover{flex-grow:1.5}
  .opener__side:hover .opener__img{transform:scale(1.1)}
  .opener:hover .opener__side:not(:hover)::after{opacity:.96}
  .opener:hover .opener__side:not(:hover) .opener__content{transform:scale(.97);opacity:.62}
}
.opener.is-ready .opener__img{transform:scale(1)}
@media (prefers-reduced-motion:reduce){.opener__img{transition:none}}

/* Mittlere Marke / Divider mit feiner Linie */
.opener__divider{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);z-index:3;
  display:grid;place-items:center;pointer-events:none}
.opener__divider::before{content:"";position:absolute;top:0;bottom:0;width:1px;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.28),transparent)}
/* Center-Mark OHNE Box */
.opener__badge{display:grid;place-items:center}
.opener__badge img{width:clamp(52px,5.5vw,74px);filter:drop-shadow(0 6px 18px rgba(0,0,0,.45))}
@media (max-width:860px){
  .opener{flex-direction:column;height:auto;min-height:100svh}
  .opener__side{min-height:48svh;flex:1 1 50%;align-items:center;text-align:center}
  .opener__side--fl .opener__img{object-position:62% 28%}
  .opener__side--pm .opener__img{object-position:58% 26%}
  .opener__content{display:flex;flex-direction:column;align-items:center;padding:clamp(40px,7vw,56px) 24px}
  /* Ausreichend Abstand zur Logo-Bar (Headlines nicht mehr dahinter) */
  .opener__side--fl .opener__content{padding-top:96px}
  .opener__sub{margin-inline:auto}
  .opener__divider{display:none}
}

/* Marken-Bar (Logo in sauberem Container, klar abgesetzt) */
.opener__head{position:absolute;top:clamp(18px,3vw,28px);left:0;right:0;z-index:5;display:flex;justify-content:center}
.opener__brandbar{display:inline-flex;align-items:center;padding:11px 22px;border-radius:var(--r-pill);
  background:rgba(22,24,29,.42);backdrop-filter:blur(12px) saturate(160%);
  border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 30px rgba(0,0,0,.28)}
.opener__brandbar img{height:30px;width:auto;display:block}

/* Opener-Wrapper + Footer */
.opener-wrap{min-height:100svh;display:flex;flex-direction:column}
.opener-wrap .opener{flex:1 1 auto}
.opener-foot{background:var(--ink);color:rgba(255,255,255,.6);display:flex;justify-content:space-between;align-items:center;
  gap:14px;flex-wrap:wrap;padding:18px clamp(20px,5vw,44px);font-size:.82rem}
.opener-foot nav{display:flex;gap:20px;flex-wrap:wrap}
.opener-foot a{color:rgba(255,255,255,.72);transition:color .2s}
.opener-foot a:hover{color:#fff}
@media (max-width:560px){.opener-foot{flex-direction:column;gap:8px;text-align:center;padding-bottom:18px}}

/* ============ HERO (Landingpages) ============ */
.hero{position:relative;min-height:92svh;display:flex;align-items:center;overflow:hidden;padding-top:var(--nav-h)}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.hero__bg::after{content:"";position:absolute;inset:0}
.hero--fl .hero__bg::after{background:
  linear-gradient(95deg,rgba(52,0,7,.92) 0%,rgba(70,0,10,.62) 40%,rgba(74,0,10,.26) 74%,rgba(74,0,10,.34) 100%),
  linear-gradient(0deg,rgba(36,0,5,.6) 0%,transparent 44%)}
.hero--pm .hero__bg::after{background:
  linear-gradient(95deg,rgba(0,15,36,.92) 0%,rgba(0,24,52,.62) 40%,rgba(0,24,52,.26) 74%,rgba(0,28,60,.36) 100%),
  linear-gradient(0deg,rgba(0,12,30,.62) 0%,transparent 44%)}
.hero__inner{position:relative;z-index:2;max-width:var(--container);margin-inline:auto;width:100%;
  padding-inline:clamp(20px,5vw,48px);padding-block:clamp(40px,6vw,80px)}
.hero__content{max-width:680px;color:#fff}
.hero .eyebrow{color:#fff;opacity:.95}
.hero .eyebrow::before{background:#fff}
.hero__title{font-family:var(--font-display);color:#fff;font-size:clamp(2.5rem,5.6vw,4.6rem);line-height:1.02;letter-spacing:-.03em;margin:18px 0 20px}
.hero__title em{font-style:italic;color:#fff}
.hero--fl .hero__title .mark{color:#ff8a96}
.hero--pm .hero__title .mark{color:#7ab8ee}
.hero__sub{font-size:clamp(1.1rem,1.5vw,1.35rem);line-height:1.6;color:rgba(255,255,255,.92);max-width:54ch;margin-bottom:30px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero__trust{margin-top:34px;display:flex;flex-wrap:wrap;gap:10px 22px;align-items:center;color:rgba(255,255,255,.85);font-size:.88rem;font-weight:500}
.hero__trust .dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.5)}
.hero__scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.7);
  display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase}
.hero__scroll svg{width:22px;height:22px;animation:bob 1.8s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@media (prefers-reduced-motion:reduce){.hero__scroll svg{animation:none}}

/* ============ PAIN POINTS ============ */
.pain{background:var(--paper-2)}
.pain__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media (max-width:720px){.pain__grid{grid-template-columns:1fr}}
.pain__item{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);padding:20px 22px;transition:transform .3s var(--ease),box-shadow .3s}
.pain__item:hover{transform:translateY(-3px);box-shadow:var(--sh-sm)}
/* Negatives Symbol (X) für Schmerzpunkte – niemals ein Haken */
.pain__mark{flex:0 0 auto;width:30px;height:30px;border-radius:9px;background:rgba(22,24,29,.06);color:var(--muted);
  display:grid;place-items:center;margin-top:2px}
.pain__mark svg{width:15px;height:15px}
.pain__item p{font-size:1rem;color:var(--ink-soft);font-weight:500;margin:0}

/* ============ SOLUTION / STEPS ============ */
.steps{counter-reset:step}
.steps__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,30px)}
@media (max-width:900px){.steps__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.steps__grid{grid-template-columns:1fr}}
.step{position:relative;padding-top:14px}
.step__num{font-family:var(--font-display);font-size:2.4rem;font-weight:700;color:var(--fl);opacity:.9;line-height:1;letter-spacing:-.04em}
[data-accent="pm"] .step__num{color:var(--pm)}
.step h3{font-size:1.15rem;margin:12px 0 8px}
.step p{font-size:.95rem;color:var(--muted);margin:0}
.step::before{content:"";position:absolute;top:0;left:0;width:40px;height:3px;background:var(--fl);border-radius:3px}
[data-accent="pm"] .step::before{background:var(--pm)}

/* ============ MEDIA / IMAGE BLOCKS ============ */
.media-card{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg)}
.media-card img{width:100%;height:100%;object-fit:cover}
.media-card--tall{aspect-ratio:4/5}
.media-card--wide{aspect-ratio:16/11}
.media-badge{position:absolute;left:18px;bottom:18px;z-index:2}
.feature-list{display:flex;flex-direction:column;gap:18px;margin-top:8px}
.feature-list li{display:flex;gap:14px;align-items:flex-start}
.feature-list .fi{flex:0 0 auto;width:40px;height:40px;border-radius:11px;background:var(--fl-soft);color:var(--fl);display:grid;place-items:center}
[data-accent="pm"] .feature-list .fi{background:var(--pm-soft);color:var(--pm)}
.feature-list .fi svg{width:20px;height:20px}
.feature-list h3{font-size:1.1rem;margin-bottom:3px}
.feature-list p{font-size:.95rem;color:var(--muted);margin:0}

/* ============ PRODUCTS STRIP ============ */
.products{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px)}
@media (max-width:820px){.products{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.products{grid-template-columns:1fr}}
.product{border-radius:var(--r-lg);overflow:hidden;position:relative;aspect-ratio:4/5;box-shadow:var(--sh-sm);
  transition:transform .4s var(--ease),box-shadow .4s}
.product:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.product img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.product:hover img{transform:scale(1.06)}
.product__cap{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px;color:#fff;background:linear-gradient(180deg,transparent 45%,rgba(20,10,5,.78) 100%);z-index:1}
.product__cap h3{color:#fff;font-size:1.15rem;margin-bottom:2px}
.product__cap span{font-size:.84rem;opacity:.85}

/* ============ TOP REASONS (Karriere) ============ */
.reasons{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media (max-width:760px){.reasons{grid-template-columns:1fr}}
.reason{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:24px;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.reason:hover{transform:translateY(-3px);box-shadow:var(--sh);border-color:transparent}
.reason__n{flex:0 0 auto;width:44px;height:44px;border-radius:12px;background:var(--pm);color:#fff;
  display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:1.2rem}
.reason h3{font-size:1.08rem;margin-bottom:6px}
.reason p{font-size:.95rem;color:var(--muted);margin:0}

/* ============ SOCIAL PROOF / QUOTE ============ */
.quote{max-width:880px;margin-inline:auto;text-align:center}
.quote__mark{font-family:var(--font-display);font-size:4rem;line-height:.5;color:var(--fl);opacity:.4}
[data-accent="pm"] .quote__mark{color:var(--pm)}
.quote__text{font-family:var(--font-display);font-size:clamp(1.4rem,2.6vw,2.1rem);line-height:1.35;color:var(--ink);margin:16px 0 22px;font-style:italic}
.quote__by{font-weight:600;color:var(--ink-soft)}
.quote__by span{display:block;color:var(--muted);font-weight:400;font-size:.92rem}

/* ============ CROSS-LINK (Querverweis) ============ */
.crosslink{position:relative;overflow:hidden;border-radius:var(--r-xl);color:#fff;
  display:grid;grid-template-columns:1.2fr 1fr;align-items:center;min-height:300px}
@media (max-width:720px){.crosslink{grid-template-columns:1fr}}
.crosslink__bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.crosslink--pm .crosslink__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(0,20,46,.92),rgba(0,40,80,.62))}
.crosslink--fl .crosslink__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(70,0,10,.92),rgba(120,0,16,.6))}
.crosslink__body{position:relative;z-index:1;padding:clamp(32px,5vw,60px)}
.crosslink .eyebrow{color:#fff}.crosslink .eyebrow::before{background:#fff}
.crosslink h2{color:#fff;margin:14px 0 12px;font-size:clamp(1.6rem,3vw,2.4rem)}
.crosslink p{color:rgba(255,255,255,.9);margin-bottom:24px;max-width:46ch}

/* ============ FORM SECTION / FUNNEL ============ */
.formsec{background:var(--paper-2);position:relative}
.form-shell{max-width:680px;margin-inline:auto;background:#fff;border-radius:var(--r-xl);
  box-shadow:var(--sh-lg);padding:clamp(26px,4vw,48px);position:relative;overflow:hidden}
.form-shell__head{text-align:center;margin-bottom:26px}
.form-shell__head h2{font-size:clamp(1.6rem,2.8vw,2.2rem);margin-bottom:10px}
.form-shell__head p{color:var(--muted);margin-inline:auto}

/* Progress */
.funnel__progress{display:flex;align-items:center;gap:8px;margin-bottom:28px}
.funnel__bar{flex:1;height:6px;background:var(--paper-3);border-radius:6px;overflow:hidden}
.funnel__bar span{display:block;height:100%;width:25%;background:var(--fl);border-radius:6px;transition:width .4s var(--ease)}
[data-accent="pm"] .funnel__bar span{background:var(--pm)}
.funnel__count{font-size:.82rem;font-weight:600;color:var(--muted);white-space:nowrap}

/* Steps */
.funnel__step{display:none;animation:stepIn .45s var(--ease-out)}
.funnel__step.is-active{display:block}
@keyframes stepIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}
.funnel__step h3{font-size:1.3rem;margin-bottom:6px}
.funnel__step .step-hint{color:var(--muted);font-size:.94rem;margin-bottom:22px}

/* Choice chips (Ja/Nein & Multi) */
.choices{display:grid;gap:12px}
.choices--2{grid-template-columns:1fr 1fr}
.choice{position:relative;display:flex;align-items:center;gap:12px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  padding:16px 18px;cursor:pointer;transition:border-color .2s,background .2s,transform .15s}
.choice:hover{border-color:var(--fl);transform:translateY(-1px)}
[data-accent="pm"] .choice:hover{border-color:var(--pm)}
.choice input{position:absolute;opacity:0;pointer-events:none}
.choice__box{width:24px;height:24px;border-radius:7px;border:2px solid var(--line);flex:0 0 auto;display:grid;place-items:center;transition:.2s}
.choice__box svg{width:14px;height:14px;color:#fff;opacity:0;transition:opacity .15s}
.choice__txt{font-weight:600;font-size:.98rem;color:var(--ink-soft)}
.choice:has(input:checked){border-color:var(--fl);background:var(--fl-soft)}
.choice:has(input:checked) .choice__box{background:var(--fl);border-color:var(--fl)}
.choice:has(input:checked) .choice__box svg{opacity:1}
[data-accent="pm"] .choice:has(input:checked){border-color:var(--pm);background:var(--pm-soft)}
[data-accent="pm"] .choice:has(input:checked) .choice__box{background:var(--pm);border-color:var(--pm)}

.funnel__nav{display:flex;justify-content:space-between;gap:12px;margin-top:28px}
.funnel__nav .btn--back{background:transparent;color:var(--muted);box-shadow:none;padding-inline:.4rem}
.funnel__nav .btn--back:hover{color:var(--ink);transform:none}
.funnel__nav .btn--back[hidden]{visibility:hidden}
/* .btn{display:inline-flex} würde [hidden] überschreiben -> explizit ausblenden */
.funnel__nav .btn[data-next][hidden],.funnel__nav .btn[data-submit][hidden]{display:none}

/* ============ LEGAL PAGES ============ */
.legal{padding-top:calc(var(--nav-h) + 40px);padding-bottom:80px;background:var(--paper)}
.legal__inner{max-width:820px;margin-inline:auto;padding-inline:clamp(20px,5vw,48px)}
.legal h1{margin-bottom:10px}
.legal .updated{color:var(--muted);font-size:.9rem;margin-bottom:36px}
.legal h2{font-size:1.4rem;margin:36px 0 12px}
.legal h3{font-size:1.1rem;margin:24px 0 8px}
.legal p,.legal li{color:var(--ink-soft);font-size:1rem;line-height:1.75;max-width:none}
.legal ul{list-style:disc;padding-left:22px;margin:10px 0}
.legal li{margin-bottom:6px}
.legal a{color:var(--fl);text-decoration:underline}
.legal .placeholder{background:var(--fl-soft);border:1px dashed var(--fl);border-radius:var(--r-sm);
  padding:14px 18px;color:var(--fl-deep);font-size:.92rem;font-weight:500;margin:8px 0}
.legal .ph-field{background:var(--paper-2);border-radius:6px;padding:1px 8px;font-weight:600;color:var(--muted)}

/* =====================================================================
   REDESIGN-REFINEMENTS — Bild-Focal-Points, Konsistenz, Mobile-Buttons
   ===================================================================== */
/* Hero-Hintergrund: Person bleibt sichtbar, kein Auslaufen */
.hero__bg{background-position:74% 24%}

/* Scroll-Cue entfernt (kein „MEHR ↓" – unnötiges Element) */
.hero__scroll{display:none}

/* Mobil: Hero-Text unten verankert über starkem Scrim → immer lesbar */
@media (max-width:760px){
  .hero{align-items:flex-end;min-height:90svh}
  .hero__bg{background-position:72% 16%}
  .hero__inner{padding-block:0 clamp(28px,7vw,44px)}
  .hero--fl .hero__bg::after{background:linear-gradient(0deg,rgba(38,0,5,.94) 6%,rgba(54,0,8,.6) 40%,rgba(60,4,10,.12) 78%)}
  .hero--pm .hero__bg::after{background:linear-gradient(0deg,rgba(0,12,30,.94) 6%,rgba(0,20,46,.6) 40%,rgba(0,22,50,.12) 78%)}
  .hero__title{font-size:clamp(2.1rem,8.5vw,2.9rem)}
  .hero__sub{font-size:1.02rem}
}

/* Einheitlicher Bild-Look: gleicher Focal-Point über alle Media-Bilder */
.media-card img{object-position:center 30%}
.crosslink__bg{background-position:center 28%}

/* Konsistente Card-Höhen: Grid-Items strecken, Inhalt oben ausgerichtet */
.pain__item,.reason{height:100%}
.products,.reasons,.pain__grid,.steps__grid{align-items:stretch}

/* Mobile: primäre CTAs volle Breite, gleiche Höhe & Abstände */
@media (max-width:600px){
  .hero__cta{flex-direction:column;align-items:stretch;width:100%;gap:12px}
  .hero__cta .btn,.crosslink .btn,.section .btn--lg{width:100%;justify-content:center}
  .hero__trust{justify-content:flex-start}
  .funnel__nav{gap:10px}
  .funnel__nav .btn--fl,.funnel__nav .btn--pm{flex:1 1 auto;justify-content:center}
  .split{gap:32px}
}

/* Tablet-Bereich: Schnellkontakt-FAB kollidiert nicht mit Inhalt (Corner) */
@media (max-width:1100px){
  .container{padding-inline:clamp(18px,4vw,40px)}
}

/* =====================================================================
   ÜBERARBEITUNG 2 — Parallax, Trust-Proof, Prozessstrahl, Funnel-Wide
   ===================================================================== */

/* ---- Parallax-CTA-Band ---- */
.parallax-band{position:relative;overflow:hidden;color:#fff;isolation:isolate}
.parallax-band__bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;
  transform:scale(1.12);will-change:transform}
.parallax-band::after{content:"";position:absolute;inset:0;z-index:-1}
.parallax-band--fl::after{background:linear-gradient(180deg,rgba(60,0,8,.78),rgba(90,0,12,.86))}
.parallax-band--pm::after{background:linear-gradient(180deg,rgba(0,18,42,.8),rgba(0,28,60,.88))}
.parallax-band--ink::after{background:linear-gradient(180deg,rgba(18,20,25,.78),rgba(18,20,25,.9))}
.parallax-band__inner{position:relative;z-index:1;max-width:760px;margin-inline:auto;text-align:center;
  padding-block:clamp(64px,11vw,150px);padding-inline:clamp(22px,5vw,40px)}
.parallax-band .eyebrow{color:#fff}.parallax-band .eyebrow::before{background:#fff}
.parallax-band h2{color:#fff;font-size:clamp(1.9rem,3.6vw,3rem);margin:14px 0 16px}
.parallax-band p{color:rgba(255,255,255,.92);margin:0 auto 30px;max-width:48ch}
.parallax-band__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---- Trust-Proof (Avatare + Text) ---- */
.trust-proof{display:inline-flex;align-items:center;gap:15px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-pill);padding:9px 22px 9px 13px;box-shadow:var(--sh)}
.trust-proof__faces{display:flex;flex:0 0 auto}
.trust-proof__faces img{width:42px;height:42px;border-radius:50%;border:2.5px solid #fff;object-fit:cover;
  margin-left:-13px;box-shadow:0 2px 6px rgba(0,0,0,.14)}
.trust-proof__faces img:first-child{margin-left:0}
.trust-proof__txt{text-align:left;line-height:1.25}
.trust-proof__stars{color:#F5A623;font-size:.82rem;letter-spacing:1px}
.trust-proof__txt strong{display:block;font-size:.95rem;color:var(--ink);font-weight:700}
.trust-proof__txt span{font-size:.82rem;color:var(--muted)}
/* Glas-Variante über dunklem Hero/Band */
.trust-proof--glass{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.28);backdrop-filter:blur(8px);box-shadow:none}
.trust-proof--glass .trust-proof__txt strong{color:#fff}
.trust-proof--glass .trust-proof__txt span{color:rgba(255,255,255,.8)}
.trust-proof--glass .trust-proof__faces img{border-color:rgba(255,255,255,.85)}
.hero .trust-proof{margin-top:30px}
@media (max-width:480px){
  .trust-proof{padding:9px 18px 9px 11px;gap:12px}
  .trust-proof__faces img{width:36px;height:36px}
}

/* ---- Prozessstrahl („So funktioniert's") ---- */
.process{position:relative}
.process__track{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,28px);position:relative}
.process__track::before{content:"";position:absolute;top:36px;left:11%;right:11%;height:2px;z-index:0;
  background:repeating-linear-gradient(90deg,var(--fl) 0 8px,transparent 8px 16px);opacity:.4}
[data-accent="pm"] .process__track::before{background:repeating-linear-gradient(90deg,var(--pm) 0 8px,transparent 8px 16px)}
.process__step{position:relative;z-index:1;text-align:center}
.process__icon{width:74px;height:74px;border-radius:50%;background:#fff;border:2px solid var(--fl);color:var(--fl);
  display:grid;place-items:center;margin:0 auto 18px;box-shadow:var(--sh-sm);position:relative;transition:transform .35s var(--ease),box-shadow .35s}
[data-accent="pm"] .process__icon{border-color:var(--pm);color:var(--pm)}
.process__step:hover .process__icon{transform:translateY(-5px);box-shadow:var(--sh)}
.process__icon svg{width:30px;height:30px}
.process__icon::after{content:attr(data-n);position:absolute;top:-6px;right:-6px;width:24px;height:24px;border-radius:50%;
  background:var(--fl);color:#fff;font-family:var(--font-sans);font-weight:700;font-size:.78rem;display:grid;place-items:center;box-shadow:0 2px 6px rgba(0,0,0,.2)}
[data-accent="pm"] .process__icon::after{background:var(--pm)}
.process__step h3{font-size:1.12rem;margin-bottom:7px}
.process__step p{font-size:.94rem;color:var(--muted);margin:0 auto;max-width:24ch}
@media (max-width:760px){
  .process__track{grid-template-columns:1fr;gap:0;max-width:440px;margin-inline:auto;text-align:left}
  .process__track::before{top:0;bottom:0;left:36px;right:auto;width:2px;height:auto;
    background:repeating-linear-gradient(180deg,var(--fl) 0 8px,transparent 8px 16px);opacity:.4}
  [data-accent="pm"] .process__track::before{background:repeating-linear-gradient(180deg,var(--pm) 0 8px,transparent 8px 16px)}
  .process__step{display:grid;grid-template-columns:74px 1fr;column-gap:18px;row-gap:4px;align-items:start;text-align:left;padding-bottom:34px}
  .process__icon{margin:0;grid-column:1;grid-row:1 / span 2}
  .process__step h3{grid-column:2;grid-row:1;align-self:center;margin:0}
  .process__step p{grid-column:2;grid-row:2;max-width:none}
}

/* ---- Funnel volle Containerbreite ---- */
.form-shell--wide{max-width:none}
.form-shell--wide .funnel__step .choices--grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:620px){.form-shell--wide .funnel__step .choices--grid{grid-template-columns:1fr}}
.form-shell--wide .form-shell__pad{max-width:920px;margin-inline:auto}

/* Choice mit Icon */
.choice__ico{flex:0 0 auto;width:30px;height:30px;border-radius:8px;background:var(--fl-soft);color:var(--fl);display:grid;place-items:center;margin-right:2px}
[data-accent="pm"] .choice__ico{background:var(--pm-soft);color:var(--pm)}
.choice__ico svg{width:17px;height:17px}

/* „Warum FitLine" – sauberer Abstand Headline -> Inhalt */
.feature-list{margin-top:26px}
.media-split-text .lead{margin-top:16px}

/* zentrierter Pain-CTA-Button (bereits text-center, hier abgesichert) */
.pain__cta{display:flex;justify-content:center;margin-top:clamp(28px,4vw,44px)}

/* rotes ✗ für Schmerzpunkte */
.pain__mark{background:var(--fl-soft);color:var(--fl)}

/* ---- Choice mit Icon (Box rechts) ---- */
.choice{gap:13px}
.choice__txt{flex:1}
.choice__box{margin-left:auto}
.choice__box--radio{border-radius:50%}

/* ---- Zitat: Avatar + Sterne ---- */
.quote__avatar{width:66px;height:66px;border-radius:50%;overflow:hidden;margin:0 auto 16px;border:3px solid rgba(255,255,255,.22);box-shadow:var(--sh)}
.quote__avatar img{width:100%;height:100%;object-fit:cover}
.quote__stars{color:#F5A623;letter-spacing:3px;font-size:1.05rem;margin-bottom:12px}
.quote__by span{display:block;font-weight:400;font-size:.9rem;margin-top:2px}

/* ---- Media-Badge Icon-Größe ---- */
.media-badge.pill svg{width:1.05em;height:1.05em}
