/* ============================================================
   A.M.Ö. GmbH — Karriere & Bewerbung
   Maßgeschneidertes Stylesheet · Markenrot #CD1417
   Kein Framework. Handgebaut.
   ============================================================ */

:root {
  /* Marke */
  --rot:           #CD1417;   /* exakte Logo-Farbe */
  --rot-tief:      #A20F12;
  --rot-dunkel:    #7E0C0E;
  --rot-zart:      #FBEAEA;
  --rot-linie:     #F0CFCF;

  /* Tinte / Neutral (warm, nicht blaustichig) */
  --tinte:         #17140F;
  --tinte-2:       #2A251E;
  --grau:          #5B554C;
  --grau-hell:     #8A8378;
  --linie:         #E7E0D6;
  --papier:        #FBF8F4;   /* warmes Off-White */
  --papier-2:      #F4EFE8;
  --weiss:         #FFFFFF;

  --gold:          #C8A24B;   /* dezenter, einziger Sekundärakzent */

  /* Typo */
  --serif:   'Fraunces', Georgia, serif;
  --display: 'Plus Jakarta Sans', system-ui, sans-serif;
  --sans:    'Inter', system-ui, sans-serif;

  /* Maße */
  --rhythm: clamp(4.5rem, 9vw, 8rem);
  --pad:    clamp(1.15rem, 4vw, 2.25rem);
  --maxw:   1180px;

  /* Effekte */
  --schatten-s: 0 1px 2px rgba(23,20,15,.05);
  --schatten-m: 0 10px 30px -12px rgba(23,20,15,.18);
  --schatten-l: 0 30px 60px -20px rgba(23,20,15,.28);
  --schatten-rot: 0 14px 30px -10px rgba(205,20,23,.45);

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

/* ===== Reset ===== */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  color:var(--tinte);
  background:var(--papier);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
button{ font-family:inherit; cursor:pointer; border:0; background:none; color:inherit; }
input,select,textarea{ font-family:inherit; font-size:inherit; }
a{ color:inherit; text-decoration:none; transition:color .2s var(--ease); }
ul{ list-style:none; margin:0; padding:0; }
h1,h2,h3,h4{ margin:0; font-family:var(--display); font-weight:800; line-height:1.08; letter-spacing:-.025em; }
p{ margin:0 0 1em; }

/* ===== Layout ===== */
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
.container--narrow{ max-width:860px; }
.section{ padding-block:var(--rhythm); }
.section--paper{ background:var(--papier-2); }
.section--ink{ background:var(--tinte); color:var(--papier); }

/* Eyebrow / Kicker mit Linie — editorialer Detailgrad */
.eyebrow{
  display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--display); font-weight:700;
  font-size:.72rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--rot);
}
.eyebrow::before{ content:''; width:28px; height:2px; background:var(--rot); display:inline-block; }
.eyebrow--light{ color:var(--rot); }
.eyebrow--ink::before{ background:var(--gold); }
.eyebrow--ink{ color:var(--gold); }

.h-sec{ font-size:clamp(2rem,4.2vw,3.1rem); letter-spacing:-.03em; margin:1.1rem 0 0; }
.lead{ font-size:clamp(1.05rem,1.4vw,1.2rem); color:var(--grau); line-height:1.7; }
.ink .lead, .section--ink .lead{ color:rgba(251,248,244,.72); }

.sec-head{ max-width:720px; }
.sec-head--center{ margin-inline:auto; text-align:center; }

.measure{ max-width:62ch; }

/* ===== Buttons ===== */
.btn{
  --bg:var(--rot); --fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  padding:.95rem 1.6rem;
  font-family:var(--display); font-weight:700; font-size:1rem;
  background:var(--bg); color:var(--fg);
  border:1.5px solid var(--bg);
  border-radius:2px;
  transition:transform .2s var(--ease), background .2s var(--ease), box-shadow .25s var(--ease), border-color .2s var(--ease);
}
.btn svg{ transition:transform .25s var(--ease); }
.btn:hover{ transform:translateY(-2px); }
.btn:hover svg{ transform:translateX(3px); }
.btn--primary{ box-shadow:var(--schatten-rot); }
.btn--primary:hover{ background:var(--rot-tief); border-color:var(--rot-tief); }
.btn--lg{ padding:1.15rem 2rem; font-size:1.06rem; }
.btn--sm{ padding:.6rem 1.1rem; font-size:.9rem; }
.btn--ghost{ --bg:transparent; --fg:var(--tinte); border-color:var(--linie); }
.btn--ghost:hover{ border-color:var(--tinte); background:transparent; }
.btn--ink{ --bg:var(--tinte); --fg:#fff; box-shadow:none; }
.btn--ink:hover{ background:#000; border-color:#000; }
.btn--on-ink{ --bg:var(--rot); --fg:#fff; }
.btn--ghost-ink{ --bg:transparent; --fg:#fff; border-color:rgba(255,255,255,.28); }
.btn--ghost-ink:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.5); }

/* ===== Logo (echtes Markenlogo) ===== */
.brand{ display:inline-flex; align-items:center; }
.brand img{ height:38px; width:auto; }
.brand--footer img{ height:42px; filter:brightness(0) invert(1); opacity:.95; }

/* ============================================================
   TOP-BAR (Vertrauen + Kontakt) — sofortiger Seriositätssignal
   ============================================================ */
.topbar{
  background:var(--tinte); color:rgba(251,248,244,.82);
  font-size:.8rem; letter-spacing:.01em;
}
.topbar__inner{ display:flex; justify-content:space-between; align-items:center; gap:1rem; padding-block:.5rem; }
.topbar__left{ display:flex; gap:1.4rem; }
.topbar__left span{ display:inline-flex; align-items:center; gap:.45rem; }
.topbar__left b{ color:var(--gold); font-weight:600; }
.topbar__right{ display:flex; gap:1.4rem; }
.topbar a:hover{ color:#fff; }
@media (max-width:760px){ .topbar__left span:not(:first-child), .topbar__right a:last-child{ display:none; } }

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:sticky; top:0; z-index:100;
  background:rgba(251,248,244,.88);
  backdrop-filter:blur(14px) saturate(1.4);
  -webkit-backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid var(--linie);
}
.header__inner{ display:flex; align-items:center; justify-content:space-between; gap:2rem; height:74px; }
.nav{ display:flex; align-items:center; gap:2.1rem; margin-left:auto; }
.nav a{ font-family:var(--display); font-weight:600; font-size:.96rem; color:var(--tinte-2); position:relative; padding-block:.4rem; }
.nav a::after{ content:''; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--rot); transition:width .25s var(--ease); }
.nav a:hover{ color:var(--rot); }
.nav a:hover::after{ width:100%; }
.header__actions{ display:flex; align-items:center; gap:1rem; }
.header__phone{ font-family:var(--display); font-weight:700; font-size:.95rem; color:var(--tinte); white-space:nowrap; }
.header__phone:hover{ color:var(--rot); }
.nav__toggle{ display:none; flex-direction:column; gap:5px; padding:8px; }
.nav__toggle span{ display:block; width:24px; height:2px; background:var(--tinte); transition:.2s var(--ease); }

@media (max-width:920px){
  .header__phone{ display:none; }
  .nav{
    position:fixed; inset:74px 0 auto 0;
    flex-direction:column; align-items:stretch; gap:0;
    background:var(--papier); padding:.5rem var(--pad) 1.5rem;
    border-bottom:1px solid var(--linie); box-shadow:var(--schatten-m);
    transform:translateY(-130%); transition:transform .3s var(--ease);
  }
  .nav.is-open{ transform:translateY(0); }
  .nav a{ padding:1rem 0; border-bottom:1px solid var(--linie); font-size:1.05rem; }
  .nav a::after{ display:none; }
  .nav__toggle{ display:flex; }
}

/* ============================================================
   HERO — asymmetrisch, redaktionell
   ============================================================ */
.hero{ position:relative; padding-block:clamp(3rem,6vw,5.5rem) clamp(4rem,8vw,7rem); overflow:hidden; }
.hero::before{ /* großes, blasses Marken-Ö als Wasserzeichen */
  content:'ö'; position:absolute; right:-2vw; top:-6vw;
  font-family:var(--display); font-weight:800; font-size:46vw; line-height:1;
  color:var(--rot); opacity:.04; pointer-events:none; z-index:0;
}
.hero__inner{ position:relative; z-index:1; display:grid; grid-template-columns:1.08fr .92fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
@media (max-width:940px){ .hero__inner{ grid-template-columns:1fr; } }

.hero__flag{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.45rem .9rem .45rem .55rem; border:1px solid var(--rot-linie); background:var(--weiss);
  border-radius:2px; font-size:.82rem; font-weight:600; color:var(--rot-tief); margin-bottom:1.6rem;
}
.hero__flag .dot{ width:9px; height:9px; border-radius:50%; background:#1f9d55; box-shadow:0 0 0 0 rgba(31,157,85,.5); animation:pulse 2.2s infinite; }
@keyframes pulse{ 70%{ box-shadow:0 0 0 7px rgba(31,157,85,0);} 100%{ box-shadow:0 0 0 0 rgba(31,157,85,0);} }

.hero__title{ font-size:clamp(2.6rem,6.2vw,4.6rem); line-height:1.02; letter-spacing:-.035em; }
.hero__title em{ font-family:var(--serif); font-style:italic; font-weight:500; color:var(--rot); letter-spacing:-.01em; }
.hero__lead{ font-size:clamp(1.08rem,1.5vw,1.24rem); color:var(--grau); margin:1.6rem 0 2.2rem; max-width:33em; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:.9rem; }
.hero__sub{ margin-top:1rem; font-size:.92rem; color:var(--grau-hell); }
.hero__sub b{ color:var(--tinte); font-weight:600; }

/* Hero-Visual: EIN art-direktiertes Bild, kein Karten-Stapel */
.hero__media{ position:relative; }
.hero__frame{
  position:relative; aspect-ratio:4/5; border-radius:3px; overflow:hidden;
  box-shadow:var(--schatten-l); background:var(--tinte);
}
.hero__frame::after{ content:''; position:absolute; inset:0; background:linear-gradient(to top, rgba(23,20,15,.42), transparent 42%); }
.hero__photo{
  width:100%; height:100%; object-fit:cover;
  filter:none;
}
.hero__corner{ position:absolute; width:34px; height:34px; border:2px solid var(--rot); z-index:2; }
.hero__corner--tl{ top:14px; left:14px; border-right:0; border-bottom:0; }
.hero__corner--br{ bottom:14px; right:14px; border-left:0; border-top:0; }
.hero__tag{
  position:absolute; left:-18px; bottom:34px; z-index:3;
  background:var(--weiss); border-left:4px solid var(--rot);
  padding:1rem 1.25rem; box-shadow:var(--schatten-m); max-width:230px;
}
.hero__tag b{ display:block; font-family:var(--display); font-size:1.7rem; font-weight:800; color:var(--tinte); letter-spacing:-.03em; line-height:1; }
.hero__tag span{ font-size:.78rem; color:var(--grau); display:block; margin-top:.35rem; line-height:1.4; }
.hero__cap{ position:absolute; right:14px; top:14px; z-index:3; font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.8); background:rgba(23,20,15,.5); padding:.25rem .55rem; border-radius:2px; backdrop-filter:blur(4px); }
@media (max-width:940px){ .hero__media{ max-width:440px; margin:1.5rem auto 0; } .hero__tag{ left:0; } }

/* ============================================================
   PARTNER / MISSION STRIP
   ============================================================ */
.strip{ border-block:1px solid var(--linie); background:var(--weiss); }
.strip__inner{ display:flex; align-items:center; gap:clamp(1.2rem,4vw,3rem); padding-block:1.4rem; flex-wrap:wrap; }
.strip__label{ font-family:var(--display); font-weight:700; font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--grau-hell); white-space:nowrap; }
.strip__items{ display:flex; flex-wrap:wrap; gap:.7rem 1.6rem; align-items:center; }
.strip__items span{ font-family:var(--display); font-weight:700; color:var(--tinte-2); font-size:1.02rem; display:inline-flex; align-items:center; gap:.5rem; }
.strip__items span::before{ content:''; width:7px; height:7px; background:var(--rot); border-radius:50%; }

/* ============================================================
   STATS BAND
   ============================================================ */
.stats{ background:var(--tinte); color:var(--papier); }
.stats__inner{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:clamp(2.2rem,4vw,3rem) 1.5rem; border-right:1px solid rgba(255,255,255,.08); }
.stat:last-child{ border-right:0; }
.stat b{ display:block; font-family:var(--display); font-weight:800; font-size:clamp(2.1rem,3.6vw,2.9rem); letter-spacing:-.03em; color:#fff; }
.stat b em{ font-style:normal; color:var(--rot); }
.stat span{ display:block; margin-top:.4rem; font-size:.88rem; color:rgba(251,248,244,.6); }
@media (max-width:720px){ .stats__inner{ grid-template-columns:1fr 1fr; } .stat:nth-child(2){ border-right:0; } .stat:nth-child(1),.stat:nth-child(2){ border-bottom:1px solid rgba(255,255,255,.08); } }

/* ============================================================
   STORY / DER JOB
   ============================================================ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,5rem); align-items:center; }
@media (max-width:880px){ .split{ grid-template-columns:1fr; } }
.story__media{ position:relative; }
.story__img{ aspect-ratio:5/6; border-radius:3px; overflow:hidden; box-shadow:var(--schatten-l); background:var(--tinte); position:relative; }
.story__img img{ width:100%; height:100%; object-fit:cover; filter:none; }
.story__badge{
  position:absolute; right:-16px; bottom:28px; background:var(--rot); color:#fff;
  padding:1.1rem 1.3rem; max-width:240px; box-shadow:var(--schatten-m);
}
.story__badge b{ display:block; font-family:var(--display); font-size:1.05rem; }
.story__badge span{ font-size:.82rem; opacity:.9; }
@media (max-width:880px){ .story__media{ max-width:460px; } .story__badge{ right:0; } }

.checks{ margin:1.6rem 0 2rem; display:grid; gap:.2rem; }
.checks li{ display:flex; gap:.85rem; padding:.7rem 0; border-bottom:1px solid var(--linie); align-items:flex-start; }
.checks li:last-child{ border-bottom:0; }
.checks svg{ flex-shrink:0; margin-top:3px; }

/* ============================================================
   BENEFITS — editoriale Liste (kein Karten-Raster!)
   ============================================================ */
.bnf{ display:grid; grid-template-columns:1fr 1fr; gap:0 clamp(2rem,5vw,4.5rem); margin-top:3rem; }
@media (max-width:760px){ .bnf{ grid-template-columns:1fr; } }
.benefit{
  display:grid; grid-template-columns:auto 1fr; gap:1.2rem;
  padding:1.8rem 0; border-top:1px solid var(--linie);
  transition:padding-left .25s var(--ease);
}
.benefit:hover{ padding-left:.5rem; }
.benefit__no{ font-family:var(--display); font-weight:800; font-size:1rem; color:var(--rot); padding-top:.35rem; letter-spacing:.02em; }
.benefit__ic{ display:none; }
.benefit h3{ font-size:1.3rem; letter-spacing:-.02em; display:flex; align-items:center; gap:.6rem; }
.benefit h3 svg{ color:var(--rot); flex-shrink:0; }
.benefit p{ margin:.5rem 0 0; color:var(--grau); font-size:.97rem; }

/* ============================================================
   LEADMAGNET
   ============================================================ */
.lm{ background:var(--tinte); color:var(--papier); position:relative; overflow:hidden; }
.lm::before{ content:''; position:absolute; right:-8%; top:-30%; width:46%; height:200%; background:radial-gradient(circle, rgba(205,20,23,.30), transparent 62%); }
.lm__inner{ position:relative; display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2rem,6vw,4.5rem); align-items:center; }
@media (max-width:880px){ .lm__inner{ grid-template-columns:1fr; } }
.lm__doc{
  position:relative; width:min(260px,72%); aspect-ratio:3/4; background:#fff; color:var(--tinte);
  padding:1.6rem 1.5rem; box-shadow:0 30px 60px rgba(0,0,0,.45); transform:rotate(-3deg);
  border-top:5px solid var(--rot);
}
.lm__doc-k{ font-family:var(--display); font-weight:800; font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--rot); }
.lm__doc-h{ font-family:var(--display); font-weight:800; font-size:1.15rem; line-height:1.15; margin:.6rem 0 1.1rem; letter-spacing:-.02em; }
.lm__doc-line{ height:7px; background:var(--papier-2); border-radius:2px; margin-bottom:.6rem; }
.lm__doc-foot{ position:absolute; left:1.5rem; bottom:1.3rem; font-family:var(--display); font-weight:700; font-size:.72rem; color:var(--grau); }
.lm__form{ display:grid; grid-template-columns:1fr 1fr auto; gap:.7rem; margin:1.8rem 0 1rem; }
@media (max-width:680px){ .lm__form{ grid-template-columns:1fr; } }
.lm__form input{ padding:1rem 1.1rem; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.06); color:#fff; border-radius:2px; outline:none; transition:.2s var(--ease); }
.lm__form input::placeholder{ color:rgba(255,255,255,.5); }
.lm__form input:focus{ border-color:var(--rot); background:rgba(255,255,255,.1); }
.lm__note{ font-size:.84rem; color:rgba(251,248,244,.55); display:flex; align-items:center; gap:.5rem; margin:0; }

/* ============================================================
   STANDORTE — Roster
   ============================================================ */
.roster{ border-top:1px solid var(--linie); margin-top:2.5rem; }
.loc{
  display:grid; grid-template-columns:auto 1fr auto auto; gap:1.4rem; align-items:center;
  padding:1.15rem .4rem; border-bottom:1px solid var(--linie);
  transition:background .2s var(--ease), padding-left .2s var(--ease);
}
.loc:hover{ background:var(--weiss); padding-left:1rem; }
.loc__dot{ width:11px; height:11px; border-radius:50%; }
.loc--on .loc__dot{ background:#1f9d55; box-shadow:0 0 0 4px rgba(31,157,85,.14); }
.loc--soon .loc__dot{ background:var(--gold); box-shadow:0 0 0 4px rgba(200,162,75,.16); }
.loc__city{ font-family:var(--display); font-weight:700; font-size:1.25rem; letter-spacing:-.02em; }
.loc__meta{ font-size:.86rem; color:var(--grau); }
.loc__tag{ font-family:var(--display); font-weight:700; font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; padding:.32rem .7rem; border-radius:2px; white-space:nowrap; }
.loc--on .loc__tag{ background:var(--rot-zart); color:var(--rot-tief); }
.loc--soon .loc__tag{ background:var(--papier-2); color:var(--grau); }
@media (max-width:680px){ .loc{ grid-template-columns:auto 1fr auto; } .loc__meta{ display:none; } }

/* ============================================================
   PROCESS — vertikal nummeriert mit Linie
   ============================================================ */
.steps{ position:relative; margin-top:3rem; display:grid; gap:0; }
.step{ display:grid; grid-template-columns:auto 1fr; gap:1.6rem; padding-bottom:2.4rem; position:relative; }
.step:last-child{ padding-bottom:0; }
.step__no{ position:relative; z-index:1; width:54px; height:54px; flex-shrink:0; border-radius:50%; background:var(--weiss); border:2px solid var(--rot); color:var(--rot); font-family:var(--display); font-weight:800; font-size:1.3rem; display:flex; align-items:center; justify-content:center; }
.step:not(:last-child)::before{ content:''; position:absolute; left:26px; top:54px; bottom:0; width:2px; background:linear-gradient(var(--rot-linie), transparent); }
.step__body{ padding-top:.5rem; }
.step__body h3{ font-size:1.3rem; }
.step__body p{ margin:.4rem 0 0; color:var(--grau); }
@media (min-width:760px){
  .steps{ grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,4vw,3rem); }
  .step{ padding-bottom:0; }
  .step:not(:last-child)::before{ left:54px; top:26px; right:0; bottom:auto; width:auto; height:2px; background:linear-gradient(90deg,var(--rot-linie),transparent); }
  .step{ display:block; }
  .step__no{ margin-bottom:1.2rem; }
}

/* ============================================================
   KARRIEREPFAD — dunkel, Markenrot
   ============================================================ */
.path{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.08); margin-top:3rem; }
@media (max-width:900px){ .path{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .path{ grid-template-columns:1fr; } }
.rung{ background:var(--tinte); padding:1.8rem 1.5rem; transition:background .25s var(--ease); }
.rung:hover{ background:#211c15; }
.rung--hot{ background:var(--rot); }
.rung--hot:hover{ background:var(--rot); }
.rung__m{ font-family:var(--display); font-weight:700; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); }
.rung--hot .rung__m{ color:rgba(255,255,255,.85); }
.rung h3{ color:#fff; font-size:1.2rem; margin:.6rem 0 .5rem; }
.rung p{ color:rgba(251,248,244,.7); font-size:.9rem; margin:0 0 1rem; }
.rung--hot p{ color:rgba(255,255,255,.9); }
.rung__pay{ font-family:var(--display); font-weight:800; color:var(--gold); font-size:1.02rem; padding-top:.9rem; border-top:1px solid rgba(255,255,255,.12); display:block; }
.rung--hot .rung__pay{ color:#fff; border-color:rgba(255,255,255,.25); }

/* ============================================================
   TESTIMONIALS — Feature-Quote + zwei kleine
   ============================================================ */
.voices{ display:grid; grid-template-columns:1.3fr 1fr; gap:clamp(1.5rem,4vw,3rem); align-items:stretch; margin-top:2.5rem; }
@media (max-width:880px){ .voices{ grid-template-columns:1fr; } }
.voice-feat{ background:var(--weiss); border:1px solid var(--linie); border-top:3px solid var(--rot); padding:clamp(2rem,4vw,3rem); display:flex; flex-direction:column; }
.voice-feat__mark{ font-family:var(--serif); font-style:italic; font-size:4rem; line-height:.6; color:var(--rot); height:2.2rem; }
.voice-feat__q{ font-family:var(--serif); font-style:italic; font-weight:400; font-size:clamp(1.3rem,2.4vw,1.85rem); line-height:1.4; letter-spacing:-.01em; color:var(--tinte); margin:1rem 0 1.6rem; }
.voice-feat__by{ margin-top:auto; display:flex; align-items:center; gap:.9rem; }
.voice-feat__by .ini{ width:48px; height:48px; border-radius:50%; background:var(--rot); color:#fff; font-family:var(--display); font-weight:800; display:flex; align-items:center; justify-content:center; }
.voice-feat__by b{ font-family:var(--display); display:block; }
.voice-feat__by span{ font-size:.86rem; color:var(--grau); }
.voice-col{ display:grid; gap:clamp(1.5rem,4vw,3rem); }
.voice{ background:var(--weiss); border:1px solid var(--linie); padding:1.6rem; }
.voice__q{ font-size:.98rem; color:var(--tinte-2); margin:0 0 1rem; line-height:1.55; }
.voice__by{ display:flex; align-items:center; gap:.7rem; padding-top:.9rem; border-top:1px solid var(--linie); }
.voice__by b{ font-family:var(--display); font-size:.95rem; }
.voice__by span{ font-size:.8rem; color:var(--grau); display:block; }
.stars{ color:var(--gold); letter-spacing:2px; font-size:.95rem; margin-bottom:.7rem; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ margin-top:2.5rem; border-top:1px solid var(--linie); }
.faq__item{ border-bottom:1px solid var(--linie); }
.faq__item summary{
  list-style:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:1.5rem;
  padding:1.4rem .3rem; font-family:var(--display); font-weight:700; font-size:1.1rem; color:var(--tinte);
  transition:color .2s var(--ease);
}
.faq__item summary:hover{ color:var(--rot); }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{ content:''; width:14px; height:14px; flex-shrink:0; background:var(--rot); -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 5v14M5 12h14' stroke='black' stroke-width='2.5' stroke-linecap='round'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 5v14M5 12h14' stroke='black' stroke-width='2.5' stroke-linecap='round'/></svg>") center/contain no-repeat; transition:transform .25s var(--ease); }
.faq__item[open] summary::after{ transform:rotate(135deg); }
.faq__item p{ margin:0 .3rem 1.5rem; color:var(--grau); max-width:70ch; }

/* ============================================================
   APPLY
   ============================================================ */
.apply-sec{ background:var(--tinte); color:var(--papier); position:relative; overflow:hidden; }
.apply-sec::before{ content:''; position:absolute; left:-6%; top:-20%; width:46%; height:150%; background:radial-gradient(circle, rgba(205,20,23,.26), transparent 62%); }
.apply{ position:relative; display:grid; grid-template-columns:1fr 1.18fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
@media (max-width:880px){ .apply{ grid-template-columns:1fr; } }
.apply__benefits{ margin-top:1.8rem; display:grid; gap:.1rem; }
.apply__benefits li{ display:flex; align-items:center; gap:.8rem; padding:.6rem 0; color:rgba(251,248,244,.9); border-bottom:1px solid rgba(255,255,255,.08); }
.apply__benefits li:last-child{ border-bottom:0; }
.apply__benefits svg{ color:#1fb564; flex-shrink:0; }
.apply__form{ background:var(--weiss); color:var(--tinte); padding:clamp(1.6rem,3vw,2.5rem); box-shadow:var(--schatten-l); border-top:4px solid var(--rot); }
.apply__step h3{ font-size:1.35rem; margin-bottom:1.4rem; }
.field{ margin-bottom:1.1rem; }
.field label{ display:block; font-family:var(--display); font-size:.85rem; font-weight:600; margin-bottom:.4rem; color:var(--tinte-2); }
.field input[type=text],.field input[type=email],.field input[type=tel],.field input[type=number]{
  width:100%; padding:.9rem 1rem; border:1.5px solid var(--linie); border-radius:2px; outline:none; transition:.2s var(--ease); background:var(--papier);
}
.field input:focus{ border-color:var(--rot); background:#fff; box-shadow:0 0 0 3px var(--rot-zart); }
.field--radio{ display:grid; gap:.5rem; }
.field--radio > label:first-child{ font-family:var(--display); font-weight:600; font-size:.85rem; color:var(--tinte-2); margin-bottom:.3rem; }
.radio,.check{ display:flex; align-items:center; gap:.7rem; padding:.75rem 1rem; border:1.5px solid var(--linie); border-radius:2px; cursor:pointer; transition:.2s var(--ease); background:var(--papier); font-size:.96rem; }
.radio:hover,.check:hover{ border-color:var(--rot-linie); }
.radio input,.check input{ accent-color:var(--rot); width:18px; height:18px; }
.radio:has(input:checked){ border-color:var(--rot); background:var(--rot-zart); }
.check{ align-items:flex-start; font-size:.86rem; color:var(--grau); margin-top:1.4rem; line-height:1.5; }
.apply__buttons{ display:flex; gap:.7rem; margin-top:1.4rem; }
.apply__buttons .btn{ flex:1; }
.apply__next{ width:100%; margin-top:.8rem; }
.apply__progress{ margin-top:1.8rem; }
.apply__progress-bar{ height:3px; background:var(--linie); border-radius:2px; overflow:hidden; margin-bottom:.5rem; }
.apply__progress-bar::after{ content:''; display:block; height:100%; width:var(--progress,33%); background:var(--rot); transition:width .3s var(--ease); }
#progressText{ font-size:.8rem; color:var(--grau); }
.apply__success{ text-align:center; padding:2rem 1rem; }
.apply__success svg{ margin:0 auto 1rem; }
.apply__success h3{ font-size:1.4rem; margin-bottom:.5rem; }
.apply__success p{ color:var(--grau); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--tinte); color:rgba(251,248,244,.66); padding-top:4.5rem; }
.footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:2.5rem; padding-bottom:3rem; }
@media (max-width:880px){ .footer__grid{ grid-template-columns:1fr 1fr; gap:2rem; } }
@media (max-width:520px){ .footer__grid{ grid-template-columns:1fr; } }
.footer p{ font-size:.92rem; line-height:1.65; }
.footer h4{ font-family:var(--display); color:#fff; font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:1.1rem; }
.footer__nav a{ display:block; padding:.3rem 0; font-size:.94rem; color:rgba(251,248,244,.66); }
.footer__nav a:hover{ color:var(--rot); }
.footer address{ font-style:normal; font-size:.92rem; line-height:1.8; }
.footer address b{ color:#fff; font-weight:600; }
.footer__bottom{ border-top:1px solid rgba(255,255,255,.1); padding-block:1.5rem; }
.footer__bottom .container{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.84rem; color:rgba(251,248,244,.5); }
.footer__bottom a{ color:var(--gold); }

/* ============================================================
   STICKY CTA
   ============================================================ */
.sticky-cta{
  position:fixed; right:1.5rem; bottom:1.5rem; z-index:90;
  display:inline-flex; align-items:center; gap:.5rem;
  padding:1rem 1.4rem; background:var(--rot); color:#fff;
  font-family:var(--display); font-weight:700; border-radius:2px;
  box-shadow:var(--schatten-rot);
  opacity:0; transform:translateY(16px); pointer-events:none; transition:.3s var(--ease);
}
.sticky-cta.is-visible{ opacity:1; transform:translateY(0); pointer-events:auto; }
.sticky-cta:hover{ background:var(--rot-tief); transform:translateY(-2px); }
@media (max-width:560px){ .sticky-cta{ right:1rem; bottom:1rem; padding:.85rem 1.1rem; font-size:.9rem; } }

/* ============================================================
   MODAL
   ============================================================ */
.modal{ position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center; padding:1rem; }
.modal[hidden]{ display:none; }
.modal__overlay{ position:absolute; inset:0; background:rgba(23,20,15,.72); backdrop-filter:blur(5px); animation:fade .25s var(--ease); }
.modal__box{ position:relative; background:var(--papier); width:100%; max-width:460px; padding:2.4rem 2rem 2rem; box-shadow:var(--schatten-l); border-top:4px solid var(--rot); animation:pop .3s var(--ease); }
.modal__close{ position:absolute; top:.6rem; right:.9rem; font-size:1.8rem; line-height:1; color:var(--grau); }
.modal__close:hover{ color:var(--tinte); }
.modal__k{ font-family:var(--display); font-weight:800; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--rot); }
.modal__box h3{ font-size:1.5rem; margin:.5rem 0; }
.modal__box p{ color:var(--grau); margin-bottom:1.4rem; }
.modal__box form{ display:grid; gap:.7rem; }
.modal__box input{ width:100%; padding:.9rem 1rem; border:1.5px solid var(--linie); border-radius:2px; outline:none; background:#fff; transition:.2s var(--ease); }
.modal__box input:focus{ border-color:var(--rot); box-shadow:0 0 0 3px var(--rot-zart); }
.modal__note{ font-size:.8rem; color:var(--grau); margin:1rem 0 0; }
@keyframes fade{ from{opacity:0} to{opacity:1} }
@keyframes pop{ from{opacity:0; transform:translateY(12px) scale(.98)} to{opacity:1; transform:none} }

/* ============================================================
   OFFENE STELLEN — Akkordeon mit vollständigen Anzeigen
   ============================================================ */
.jobs{ margin-top:2.5rem; display:grid; gap:1rem; }
.job{ background:var(--weiss); border:1px solid var(--linie); transition:border-color .2s var(--ease), box-shadow .25s var(--ease); }
.job[open]{ border-color:var(--rot-linie); box-shadow:var(--schatten-m); }
.job > summary{ list-style:none; cursor:pointer; display:grid; grid-template-columns:auto 1fr auto auto; gap:1.3rem; align-items:center; padding:1.35rem 1.6rem; }
.job > summary::-webkit-details-marker{ display:none; }
.job__no{ font-family:var(--display); font-weight:800; color:var(--rot); font-size:1.05rem; }
.job__role b{ display:block; font-family:var(--display); font-weight:700; font-size:1.22rem; letter-spacing:-.02em; line-height:1.2; }
.job__role span{ font-size:.84rem; color:var(--grau); }
.job__pay{ font-family:var(--display); font-weight:700; color:var(--tinte); font-size:.95rem; white-space:nowrap; }
.job__plus{ width:15px; height:15px; flex-shrink:0; background:var(--rot); -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 5v14M5 12h14' stroke='black' stroke-width='2.5' stroke-linecap='round'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 5v14M5 12h14' stroke='black' stroke-width='2.5' stroke-linecap='round'/></svg>") center/contain no-repeat; transition:transform .25s var(--ease); }
.job[open] .job__plus{ transform:rotate(135deg); }
.job__body{ padding:0 1.6rem 1.7rem; }
.job__divider{ height:1px; background:var(--linie); margin:0 0 1.4rem; }
.job__lead{ color:var(--grau); margin:0 0 1.5rem; max-width:78ch; }
.job__lead b{ color:var(--tinte); font-weight:600; }
.job__cols{ display:grid; grid-template-columns:1fr 1fr; gap:1.6rem 2.5rem; }
@media (max-width:680px){
  .job > summary{ grid-template-columns:auto 1fr auto; }
  .job__pay{ grid-column:2; font-size:.86rem; color:var(--rot-tief); }
  .job__cols{ grid-template-columns:1fr; }
}
.job__col h5{ font-family:var(--display); font-size:.74rem; letter-spacing:.13em; text-transform:uppercase; color:var(--rot); margin:0 0 .7rem; }
.job__col ul li{ position:relative; padding-left:18px; margin-bottom:.55rem; font-size:.95rem; color:var(--tinte-2); line-height:1.5; }
.job__col ul li::before{ content:''; position:absolute; left:0; top:9px; width:6px; height:6px; background:var(--rot); border-radius:50%; }
.job__offer{ margin-top:1.5rem; background:var(--papier-2); border-left:3px solid var(--rot); padding:1.1rem 1.3rem; }
.job__offer h5{ font-family:var(--display); font-size:.74rem; letter-spacing:.13em; text-transform:uppercase; color:var(--rot); margin:0 0 .6rem; }
.job__offer ul{ display:grid; grid-template-columns:1fr 1fr; gap:.4rem 1.5rem; }
@media (max-width:560px){ .job__offer ul{ grid-template-columns:1fr; } }
.job__offer li{ position:relative; padding-left:22px; font-size:.92rem; color:var(--tinte-2); }
.job__offer li::before{ content:''; position:absolute; left:0; top:3px; width:14px; height:14px; background:var(--rot); -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 12.5l4 4 10-10' stroke='black' stroke-width='2.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 12.5l4 4 10-10' stroke='black' stroke-width='2.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat; }
.job__foot{ margin-top:1.6rem; display:flex; align-items:center; gap:1rem 1.4rem; flex-wrap:wrap; }
.job__meta{ font-size:.86rem; color:var(--grau); display:inline-flex; align-items:center; gap:.45rem; }
.job__meta svg{ color:var(--rot); }

/* ============================================================
   MULTI-PAGE KOMPONENTEN
   ============================================================ */

/* Aktiver Nav-Link */
.nav a.is-active{ color:var(--rot); }
.nav a.is-active::after{ width:100%; }

/* WhatsApp-Pill im Header */
.header__wa{ display:inline-flex; align-items:center; gap:.45rem; font-family:var(--display); font-weight:700; font-size:.9rem; color:#0e7a44; padding:.5rem .8rem; border:1.5px solid #cde7d8; border-radius:2px; background:#f1faf4; white-space:nowrap; }
.header__wa:hover{ background:#e6f6ec; color:#0a5e34; }
.header__wa svg{ flex-shrink:0; }
@media (max-width:1040px){ .header__wa span{ display:none; } }

/* Subpage-Hero */
.subhero{ background:var(--tinte); color:var(--papier); position:relative; overflow:hidden; padding-block:clamp(2.5rem,6vw,4.5rem) clamp(2.5rem,6vw,4rem); }
.subhero::before{ content:''; position:absolute; right:-6%; top:-40%; width:46%; height:200%; background:radial-gradient(circle, rgba(205,20,23,.32), transparent 62%); }
.subhero__inner{ position:relative; max-width:760px; }
.subhero h1{ font-size:clamp(2.1rem,5vw,3.4rem); letter-spacing:-.03em; margin-top:.8rem; }
.subhero h1 em{ font-family:var(--serif); font-style:italic; font-weight:500; color:#ff5a5d; }
.subhero p{ font-size:clamp(1.05rem,1.5vw,1.2rem); color:rgba(251,248,244,.75); margin-top:1rem; max-width:60ch; }

/* Breadcrumb */
.crumb{ display:flex; gap:.5rem; align-items:center; font-size:.82rem; color:rgba(251,248,244,.55); }
.crumb a{ color:rgba(251,248,244,.7); }
.crumb a:hover{ color:#fff; }
.crumb span{ color:rgba(251,248,244,.4); }

/* Teaser-Karten (Startseite-Hub) */
.teasers{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; margin-top:3rem; }
@media (max-width:860px){ .teasers{ grid-template-columns:1fr; } }
.teaser{ display:flex; flex-direction:column; background:var(--weiss); border:1px solid var(--linie); padding:2rem 1.8rem; transition:border-color .2s var(--ease), transform .2s var(--ease), box-shadow .25s var(--ease); }
.teaser:hover{ transform:translateY(-4px); box-shadow:var(--schatten-m); border-color:var(--rot-linie); }
.teaser__ic{ width:48px; height:48px; display:flex; align-items:center; justify-content:center; background:var(--rot-zart); color:var(--rot); border-radius:3px; margin-bottom:1.2rem; }
.teaser h3{ font-size:1.3rem; letter-spacing:-.02em; }
.teaser p{ color:var(--grau); font-size:.96rem; margin:.5rem 0 1.3rem; flex-grow:1; }
.teaser__link{ font-family:var(--display); font-weight:700; color:var(--rot); display:inline-flex; align-items:center; gap:.4rem; }
.teaser:hover .teaser__link svg{ transform:translateX(4px); }
.teaser__link svg{ transition:transform .2s var(--ease); }

/* Faktengrid (ASB) */
.facts{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--linie); border:1px solid var(--linie); margin-top:2.5rem; }
@media (max-width:780px){ .facts{ grid-template-columns:1fr 1fr; } }
.fact{ background:var(--weiss); padding:1.6rem 1.4rem; }
.fact b{ display:block; font-family:var(--display); font-weight:800; font-size:1.8rem; color:var(--rot); letter-spacing:-.02em; }
.fact span{ font-size:.88rem; color:var(--grau); margin-top:.3rem; display:block; }

/* Leistungs-Liste (ASB) */
.services{ display:grid; grid-template-columns:1fr 1fr; gap:0 3rem; margin-top:2rem; }
@media (max-width:760px){ .services{ grid-template-columns:1fr; } }
.service{ display:grid; grid-template-columns:auto 1fr; gap:1rem; padding:1.3rem 0; border-top:1px solid var(--linie); }
.service svg{ color:var(--rot); flex-shrink:0; margin-top:2px; }
.service b{ font-family:var(--display); font-size:1.05rem; display:block; }
.service span{ font-size:.92rem; color:var(--grau); }

/* Quellenangaben */
.sources{ margin-top:2rem; background:var(--papier-2); border-left:3px solid var(--rot); padding:1.4rem 1.6rem; }
.sources h4{ font-family:var(--display); font-size:.78rem; letter-spacing:.13em; text-transform:uppercase; color:var(--rot); margin-bottom:.8rem; }
.sources ol{ margin:0; padding-left:1.2rem; }
.sources li{ font-size:.88rem; color:var(--grau); margin-bottom:.5rem; }
.sources a{ color:var(--rot-tief); text-decoration:underline; text-underline-offset:2px; word-break:break-word; }

/* Ausbildungs-Timeline */
.tline{ margin-top:2.5rem; position:relative; }
.tline__row{ display:grid; grid-template-columns:auto 1fr; gap:1.5rem; padding-bottom:2rem; position:relative; }
.tline__row:last-child{ padding-bottom:0; }
.tline__dot{ position:relative; z-index:1; width:46px; height:46px; flex-shrink:0; border-radius:50%; background:var(--rot); color:#fff; font-family:var(--display); font-weight:800; display:flex; align-items:center; justify-content:center; }
.tline__row:not(:last-child)::before{ content:''; position:absolute; left:22px; top:46px; bottom:0; width:2px; background:var(--rot-linie); }
.tline__body h3{ font-size:1.25rem; }
.tline__body p{ color:var(--grau); margin:.4rem 0 0; }
.tline__tag{ display:inline-block; font-family:var(--display); font-weight:700; font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--rot-tief); background:var(--rot-zart); padding:.25rem .6rem; border-radius:2px; margin-bottom:.5rem; }

/* Events / Team-Leben */
.events{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; margin-top:2.5rem; }
@media (max-width:860px){ .events{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .events{ grid-template-columns:1fr; } }
.event{ background:var(--weiss); border:1px solid var(--linie); padding:1.6rem; }
.event__ic{ width:44px; height:44px; display:flex; align-items:center; justify-content:center; background:var(--rot-zart); color:var(--rot); border-radius:3px; margin-bottom:1rem; }
.event h4{ font-size:1.1rem; }
.event p{ color:var(--grau); font-size:.92rem; margin:.4rem 0 0; }

/* Kontakt-Karten (WhatsApp / Anruf) */
.contact-cards{ display:grid; grid-template-columns:1fr 1fr; gap:1.3rem; margin-top:1.8rem; }
@media (max-width:640px){ .contact-cards{ grid-template-columns:1fr; } }
.ccard{ display:flex; gap:1.1rem; align-items:flex-start; padding:1.6rem; border:1.5px solid var(--linie); background:var(--weiss); transition:border-color .2s var(--ease), transform .2s var(--ease); }
.ccard:hover{ transform:translateY(-3px); }
.ccard--wa{ border-color:#bfe6cd; background:#f4fbf6; }
.ccard--wa:hover{ border-color:#7fcf9e; }
.ccard--call{ border-color:var(--rot-linie); background:var(--rot-zart); }
.ccard__ic{ width:46px; height:46px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; color:#fff; }
.ccard--wa .ccard__ic{ background:#25D366; }
.ccard--call .ccard__ic{ background:var(--rot); }
.ccard b{ display:block; font-family:var(--display); font-size:1.1rem; }
.ccard span{ font-size:.9rem; color:var(--grau); display:block; margin:.2rem 0 .2rem; }
.ccard strong{ font-family:var(--display); font-size:1.05rem; color:var(--tinte); }

/* Floating WhatsApp-Button */
.wa-fab{ position:fixed; left:1.5rem; bottom:1.5rem; z-index:90; display:inline-flex; align-items:center; gap:.55rem; padding:.85rem 1.15rem; background:#25D366; color:#fff; font-family:var(--display); font-weight:700; font-size:.92rem; border-radius:999px; box-shadow:0 12px 28px -8px rgba(37,211,102,.6); transition:transform .2s var(--ease), box-shadow .25s var(--ease); }
.wa-fab:hover{ transform:translateY(-2px); color:#fff; box-shadow:0 16px 34px -8px rgba(37,211,102,.7); }
@media (max-width:560px){ .wa-fab{ left:1rem; bottom:1rem; padding:.75rem; } .wa-fab span{ display:none; } }

/* Prose (Legal / Artikel) */
.prose{ max-width:760px; }
.prose h2{ font-family:var(--display); font-size:1.5rem; letter-spacing:-.02em; margin:2.2rem 0 .8rem; }
.prose h3{ font-family:var(--display); font-size:1.15rem; margin:1.6rem 0 .5rem; }
.prose p, .prose li{ color:var(--grau); line-height:1.7; }
.prose p{ margin:0 0 1rem; }
.prose ul{ margin:0 0 1rem; padding-left:1.2rem; list-style:disc; }
.prose li{ margin-bottom:.4rem; }
.prose a{ color:var(--rot-tief); text-decoration:underline; text-underline-offset:2px; }
.prose strong{ color:var(--tinte); }
.prose__updated{ font-size:.85rem; color:var(--grau-hell); margin-bottom:1.5rem; }

/* Dev-Credit (Footer/Impressum) – inline, damit langer Text sauber umbricht */
.dev-credit{ display:inline; }
.dev-credit .heart{ color:var(--rot); margin:0 .15em; }
.dev-credit a{ color:var(--gold); font-weight:600; }

/* CTA-Band */
.ctaband{ background:var(--rot); color:#fff; }
.ctaband__inner{ display:flex; justify-content:space-between; align-items:center; gap:2rem; flex-wrap:wrap; padding-block:clamp(2.5rem,5vw,3.5rem); }
.ctaband h2{ font-size:clamp(1.6rem,3vw,2.3rem); color:#fff; letter-spacing:-.02em; }
.ctaband p{ margin:.5rem 0 0; color:rgba(255,255,255,.88); max-width:52ch; }
.ctaband .btn{ --bg:#fff; --fg:var(--rot); border-color:#fff; box-shadow:none; }
.ctaband .btn:hover{ --bg:var(--tinte); --fg:#fff; border-color:var(--tinte); }

/* ===== Reveal ===== */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-revealed{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; } *{ scroll-behavior:auto; } }

/* ============================================================
   ENHANCEMENTS · WhatsApp-Logo, Animationen & Liebe im Detail
   ============================================================ */

/* WhatsApp-Button (offizielles Grün, echtes Logo) */
.btn--wa{ --bg:#25D366; --fg:#fff; box-shadow:0 10px 26px -10px rgba(37,211,102,.75); }
.btn--wa:hover{ --bg:#1ebe5b; box-shadow:0 16px 32px -10px rgba(37,211,102,.85); }
.btn--wa svg{ flex-shrink:0; }

/* Header-WA-Pille: Logo in echtem WhatsApp-Grün */
.header__wa svg{ color:#25D366; }

/* Pfeil-Nudge auf Buttons (WA-Logo bleibt ruhig) */
.btn svg{ transition:transform .25s var(--ease); }
.btn:hover svg{ transform:translateX(3px); }
.btn--wa:hover svg{ transform:none; }

/* Hero: Reassurance-Badges (geringe Hürde, hoch konvertierend) */
.hero__assure{ display:flex; flex-wrap:wrap; gap:.55rem; margin:1.5rem 0 0; padding:0; list-style:none; }
.hero__assure li{ display:inline-flex; align-items:center; gap:.45rem; font-size:.84rem; font-weight:600;
  color:var(--tinte); background:var(--weiss); border:1px solid var(--linie); border-radius:999px; padding:.42rem .85rem; }
.hero__assure li::before{ content:"✓"; display:inline-flex; align-items:center; justify-content:center;
  width:16px; height:16px; border-radius:50%; background:#1f9d55; color:#fff; font-size:.66rem; font-weight:800; }

/* Animierte Zähler: gleichmäßige Ziffern */
.stat__n{ font-variant-numeric:tabular-nums; }

/* Footer-Herz: schlägt mit Liebe */
.dev-credit .heart{ color:#e0245e; display:inline-block; }

@media (prefers-reduced-motion:no-preference){
  /* Hero-Einblendung mit sanftem Stagger */
  .hero__flag, .hero__title, .hero__lead, .hero__cta, .hero__assure, .hero__media{
    opacity:0; animation:heroIn .7s var(--ease) forwards;
  }
  .hero__flag{ animation-delay:.05s }
  .hero__title{ animation-delay:.14s }
  .hero__lead{ animation-delay:.26s }
  .hero__cta{ animation-delay:.38s }
  .hero__assure{ animation-delay:.48s }
  .hero__media{ animation-delay:.30s; animation-name:heroInMedia }

  /* Hero-Foto: sehr dezenter Ken-Burns-Zoom */
  .hero__photo{ animation:kenburns 20s ease-out forwards; }

  /* FAB: einladender Puls-Ring */
  .wa-fab::after{ content:''; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
    box-shadow:0 0 0 0 rgba(37,211,102,.55); animation:fabPing 2.6s ease-out infinite; }

  /* Herzschlag */
  .dev-credit .heart{ animation:heartbeat 1.8s ease-in-out infinite; }
}

@keyframes heroIn{ from{ opacity:0; transform:translateY(16px) } to{ opacity:1; transform:none } }
@keyframes heroInMedia{ from{ opacity:0; transform:translateY(20px) scale(.985) } to{ opacity:1; transform:none } }
@keyframes kenburns{ from{ transform:scale(1.07) } to{ transform:scale(1) } }
@keyframes fabPing{ 0%{ box-shadow:0 0 0 0 rgba(37,211,102,.5) } 70%{ box-shadow:0 0 0 16px rgba(37,211,102,0) } 100%{ box-shadow:0 0 0 0 rgba(37,211,102,0) } }
@keyframes heartbeat{ 0%,100%{ transform:scale(1) } 14%{ transform:scale(1.25) } 28%{ transform:scale(1) } 42%{ transform:scale(1.18) } 56%{ transform:scale(1) } }

/* ============================================================
   HILFSKLASSEN · helle Eyebrow/Headline auf dunklem Grund
   ============================================================ */
.eyebrow--gold{ color:var(--gold); }
.eyebrow--gold::before{ background:var(--gold); }
.h-sec--light{ color:#fff; }

/* ============================================================
   SCROLL-FORTSCHRITTSBALKEN (von main.js erzeugt)
   ============================================================ */
.scrollprog{ position:fixed; top:0; left:0; height:3px; width:0; z-index:200;
  background:linear-gradient(90deg,var(--rot),var(--gold)); box-shadow:0 0 10px rgba(205,20,23,.5);
  transition:width .08s linear; pointer-events:none; }

/* ============================================================
   VERDIENST-RECHNER
   ============================================================ */
.calc{ display:grid; grid-template-columns:1fr 1fr; gap:0; max-width:940px; margin:2.6rem auto 0;
  border:1px solid var(--linie); border-radius:20px; overflow:hidden; background:var(--weiss); box-shadow:var(--schatten-l); }
.calc__controls{ padding:clamp(1.6rem,3.2vw,2.6rem); display:flex; flex-direction:column; }
.calc__label{ font-family:var(--display); font-weight:600; font-size:1rem; color:var(--tinte); }
.calc__label b{ color:var(--rot); }
.calc__pick{ font-family:var(--display); font-weight:800; font-size:2.4rem; color:var(--rot); line-height:1; margin:.4rem 0 .2rem; }
.calc__range{ -webkit-appearance:none; appearance:none; width:100%; height:8px; border-radius:999px; cursor:pointer;
  background:linear-gradient(90deg, var(--rot) 0%, var(--rot) var(--p,40%), var(--papier-2) var(--p,40%), var(--papier-2) 100%);
  outline:none; margin:.6rem 0 .4rem; }
.calc__range::-webkit-slider-thumb{ -webkit-appearance:none; width:28px; height:28px; border-radius:50%; background:#fff;
  border:3px solid var(--rot); box-shadow:0 5px 12px rgba(205,20,23,.42); cursor:pointer; transition:transform .15s var(--ease); }
.calc__range:active::-webkit-slider-thumb{ transform:scale(1.14); }
.calc__range::-moz-range-thumb{ width:24px; height:24px; border-radius:50%; background:#fff; border:3px solid var(--rot);
  box-shadow:0 5px 12px rgba(205,20,23,.42); cursor:pointer; }
.calc__scale{ display:flex; justify-content:space-between; font-size:.72rem; color:var(--grau-hell); font-weight:600; }
.calc__facts{ list-style:none; margin:1.6rem 0 0; padding:0; display:flex; flex-direction:column; gap:.55rem; }
.calc__facts li{ display:flex; align-items:center; gap:.6rem; font-size:.9rem; color:var(--grau); }
.calc__facts svg{ flex-shrink:0; }

.calc__display{ padding:clamp(1.6rem,3.2vw,2.6rem); position:relative; overflow:hidden; color:#fff;
  background:linear-gradient(165deg,#1c1712 0%,#3a1411 75%); display:flex; flex-direction:column; }
.calc__display::before{ content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 50% at 80% 0%, rgba(205,20,23,.45), transparent 60%); pointer-events:none; }
.calc__display > *{ position:relative; }
.calc__display-lbl{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:#f0c98b; font-weight:700; }
.calc__amount{ display:flex; align-items:baseline; gap:.35rem; margin:.5rem 0 .1rem; }
.calc__amount #calcAmount{ font-family:var(--display); font-weight:800; font-size:clamp(2.8rem,6vw,3.8rem); letter-spacing:-.03em; line-height:1; font-variant-numeric:tabular-nums; }
.calc__cur{ font-family:var(--display); font-weight:700; font-size:1.2rem; color:rgba(255,255,255,.85); }
.calc__cur small{ font-size:.8rem; color:rgba(255,255,255,.6); font-weight:500; }
.calc__amount.pop #calcAmount{ animation:numPop .4s var(--ease); }
.calc__bar{ height:8px; border-radius:999px; background:rgba(255,255,255,.14); overflow:hidden; margin:.7rem 0 .9rem; }
.calc__bar span{ display:block; height:100%; border-radius:999px; background:linear-gradient(90deg,#ff5a5f,var(--gold)); transition:width .5s var(--ease); }
.calc__hint{ font-size:.92rem; color:rgba(255,255,255,.82); margin:0 0 1.2rem; min-height:2.4em; }
.calc__cta{ align-self:flex-start; }
.calc__disclaim{ display:block; margin-top:1rem; font-size:.72rem; color:rgba(255,255,255,.45); }
@keyframes numPop{ 0%{ transform:translateY(-4px); opacity:.4 } 100%{ transform:none; opacity:1 } }
@media (max-width:740px){ .calc{ grid-template-columns:1fr; } }

/* ============================================================
   LEADMAGNET-BAND
   ============================================================ */
.lm{ position:relative; overflow:hidden; color:#fff; padding-block:clamp(3rem,7vw,5.5rem);
  background:linear-gradient(165deg,#17130F 0%,#2a1410 58%,#3d0f12 100%); }
.lm__glow{ position:absolute; top:-30%; right:-10%; width:55%; height:160%;
  background:radial-gradient(circle, rgba(205,20,23,.35), transparent 62%); pointer-events:none; }
.lm__inner{ position:relative; display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.lm__media{ position:relative; display:flex; justify-content:center; perspective:1200px; }
.lm__book{ position:relative; width:min(72%,260px); aspect-ratio:3/4; border-radius:4px 10px 10px 4px;
  background:linear-gradient(135deg,#CD1417 0%,#9E0F16 100%); box-shadow:0 40px 70px -25px rgba(0,0,0,.7), inset 0 0 0 1px rgba(255,255,255,.08);
  transform:rotateY(-20deg) rotateX(5deg); transform-style:preserve-3d; }
.lm__book-spine{ position:absolute; left:0; top:0; bottom:0; width:16px; border-radius:4px 0 0 4px;
  background:linear-gradient(90deg,#7d0c11,#a20f12); box-shadow:inset -3px 0 6px rgba(0,0,0,.4); }
.lm__book-face{ position:absolute; inset:0 0 0 16px; padding:1.5rem 1.3rem; display:flex; flex-direction:column; }
.lm__book-ey{ font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700; color:#f7d6a6; }
.lm__book-title{ font-family:var(--serif); font-style:italic; font-size:1.32rem; line-height:1.18; color:#fff; margin-top:.7rem; }
.lm__book-title em{ font-style:italic; color:#ffd9a0; }
.lm__book-rule{ width:34px; height:3px; background:rgba(255,255,255,.6); border-radius:2px; margin:auto 0 .8rem; }
.lm__book-foot{ font-size:.66rem; color:rgba(255,255,255,.7); font-weight:600; }
.lm__chip{ position:absolute; bottom:6%; right:6%; background:var(--gold); color:#17130F; font-family:var(--display);
  font-weight:800; font-size:.72rem; letter-spacing:.04em; padding:.4rem .8rem; border-radius:999px; box-shadow:0 10px 22px -8px rgba(0,0,0,.6); }

.lm__content .eyebrow{ margin-bottom:1rem; }
.lm__sub{ color:rgba(255,255,255,.82); font-size:1.05rem; margin:1.2rem 0 1.3rem; max-width:46ch; }
.lm__points{ list-style:none; padding:0; margin:0 0 1.6rem; display:flex; flex-direction:column; gap:.6rem; }
.lm__points li{ position:relative; padding-left:1.8rem; color:rgba(255,255,255,.9); font-size:.96rem; }
.lm__points li::before{ content:'✓'; position:absolute; left:0; top:0; width:1.2rem; height:1.2rem; border-radius:50%;
  background:rgba(65,215,127,.18); color:#41d77f; font-size:.7rem; font-weight:800; display:flex; align-items:center; justify-content:center; }
.lm__form{ display:flex; flex-wrap:wrap; gap:.7rem; max-width:520px; }
.lm__form input{ flex:1 1 180px; padding:.95rem 1.1rem; border-radius:10px; border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.07); color:#fff; font-family:var(--body,inherit); font-size:1rem; outline:none; transition:border-color .2s var(--ease), background .2s var(--ease); }
.lm__form input::placeholder{ color:rgba(255,255,255,.55); }
.lm__form input:focus{ border-color:var(--gold); background:rgba(255,255,255,.12); }
.lm__btn{ --bg:var(--gold); --fg:#17130F; border-color:var(--gold); flex:0 0 auto; }
.lm__btn:hover{ --bg:#d8b25e; border-color:#d8b25e; }
.lm__note{ font-size:.8rem; color:rgba(255,255,255,.6); margin:1rem 0 0; }
.lm__success{ display:flex; align-items:center; gap:.9rem; margin-top:1.2rem; padding:1rem 1.2rem;
  background:rgba(65,215,127,.12); border:1px solid rgba(65,215,127,.35); border-radius:12px; }
.lm__success b{ display:block; font-family:var(--display); }
.lm__success span{ font-size:.86rem; color:rgba(255,255,255,.8); }
.lm__success a{ color:#ffd9a0; text-decoration:underline; }
@media (max-width:760px){ .lm__inner{ grid-template-columns:1fr; } .lm__media{ order:-1; } .lm__book{ width:200px; } }

/* ============================================================
   MEHR BEWEGUNG · Hover-Lifts & Buch-Schweben
   ============================================================ */
.teaser, .voice, .calc{ transition:transform .3s var(--ease), box-shadow .3s var(--ease); }
.teaser:hover{ transform:translateY(-6px); }
.voice:hover{ transform:translateY(-4px); box-shadow:var(--schatten-l); }
@media (prefers-reduced-motion:no-preference){
  .lm__book{ animation:bookFloat 6s ease-in-out infinite; }
}
@keyframes bookFloat{ 0%,100%{ transform:rotateY(-20deg) rotateX(5deg) translateY(0) } 50%{ transform:rotateY(-16deg) rotateX(5deg) translateY(-12px) } }

/* ============================================================
   JOB-QUIZ
   ============================================================ */
.quiz{ max-width:720px; margin:2.4rem auto 0; background:var(--weiss); border:1px solid var(--linie);
  border-radius:20px; box-shadow:var(--schatten-l); padding:clamp(1.6rem,3.5vw,2.6rem); position:relative; overflow:hidden; }
.quiz__top{ margin-bottom:1.6rem; }
.quiz__step{ font-family:var(--display); font-weight:700; font-size:.76rem; letter-spacing:.1em; text-transform:uppercase; color:var(--rot); }
.quiz__track{ height:6px; border-radius:999px; background:var(--papier-2); margin-top:.6rem; overflow:hidden; }
.quiz__fill{ display:block; height:100%; border-radius:999px; background:linear-gradient(90deg,var(--rot),var(--gold)); width:25%; transition:width .45s var(--ease); }
.quiz__q{ display:none; }
.quiz__q.is-active{ display:block; animation:quizIn .4s var(--ease); }
.quiz__title{ font-family:var(--display); font-weight:800; font-size:clamp(1.2rem,2.4vw,1.6rem); letter-spacing:-.02em; margin-bottom:1.2rem; }
.quiz__opts{ display:flex; flex-direction:column; gap:.7rem; }
.quiz__opt{ text-align:left; padding:1rem 1.2rem; border:1.5px solid var(--linie); border-radius:12px; background:var(--papier);
  font-family:var(--display); font-weight:600; font-size:1rem; color:var(--tinte); cursor:pointer; display:flex; align-items:center; gap:.85rem;
  transition:border-color .2s var(--ease), background .2s var(--ease), transform .15s var(--ease); }
.quiz__opt::before{ content:''; width:20px; height:20px; border-radius:50%; border:2px solid var(--linie); flex-shrink:0; transition:.2s var(--ease); }
.quiz__opt:hover{ border-color:var(--rot); background:#fff; transform:translateX(4px); }
.quiz__opt:hover::before{ border-color:var(--rot); box-shadow:inset 0 0 0 4px var(--rot); }
@keyframes quizIn{ from{ opacity:0; transform:translateY(10px) } to{ opacity:1; transform:none } }

.quiz__result{ text-align:center; animation:quizIn .5s var(--ease); }
.quiz__gauge{ display:flex; justify-content:center; margin-bottom:1.2rem; }
.quiz__ring{ --deg:0deg; width:132px; height:132px; border-radius:50%; position:relative;
  background:conic-gradient(var(--rot) var(--deg), var(--papier-2) 0); display:flex; flex-direction:column; align-items:center; justify-content:center; }
.quiz__ring::before{ content:''; position:absolute; inset:11px; background:var(--weiss); border-radius:50%; }
.quiz__ring b{ position:relative; font-family:var(--display); font-weight:800; font-size:2.1rem; color:var(--rot); line-height:1; font-variant-numeric:tabular-nums; }
.quiz__ring small{ position:relative; font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color:var(--grau); font-weight:700; margin-top:2px; }
.quiz__rh{ font-family:var(--display); font-weight:800; font-size:clamp(1.4rem,3vw,2rem); letter-spacing:-.02em; }
.quiz__rt{ color:var(--grau); max-width:42ch; margin:.6rem auto 1.4rem; }
.quiz__cta{ display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }
.quiz__again{ display:inline-block; margin-top:1.2rem; background:none; border:0; color:var(--grau-hell); font-family:var(--display); font-weight:600; font-size:.9rem; cursor:pointer; }
.quiz__again:hover{ color:var(--rot); }

/* ============================================================
   LEADMAGNET-POPUP
   ============================================================ */
.lmpop{ position:fixed; inset:0; z-index:300; display:flex; align-items:center; justify-content:center; padding:1.2rem; }
.lmpop[hidden]{ display:none; }
.lmpop__overlay{ position:absolute; inset:0; background:rgba(23,19,15,.62); backdrop-filter:blur(4px); opacity:0; transition:opacity .26s var(--ease); }
.lmpop.is-open .lmpop__overlay{ opacity:1; }
.lmpop__box{ position:relative; width:100%; max-width:760px; color:#fff; border-radius:18px; overflow:hidden;
  display:grid; grid-template-columns:.8fr 1.2fr; background:linear-gradient(165deg,#17130F,#3a1411);
  box-shadow:0 40px 90px -20px rgba(0,0,0,.7); transform:translateY(22px) scale(.98); opacity:0; transition:transform .32s var(--ease), opacity .32s var(--ease); }
.lmpop.is-open .lmpop__box{ transform:none; opacity:1; }
.lmpop__x{ position:absolute; top:.7rem; right:.85rem; z-index:3; width:32px; height:32px; border:0; border-radius:50%;
  background:rgba(255,255,255,.14); color:#fff; font-size:1.35rem; line-height:1; cursor:pointer; transition:background .2s var(--ease); }
.lmpop__x:hover{ background:rgba(255,255,255,.26); }
.lmpop__book{ background:linear-gradient(135deg,#CD1417,#9E0F16); padding:1.7rem 1.4rem; display:flex; flex-direction:column; justify-content:space-between; }
.lmpop__book-ey{ font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700; color:#f7d6a6; }
.lmpop__book-t{ font-family:var(--serif); font-style:italic; font-size:1.4rem; line-height:1.2; margin-top:1.2rem; }
.lmpop__book-t em{ font-style:italic; color:#ffd9a0; }
.lmpop__body{ padding:1.9rem; }
.lmpop__body .eyebrow{ margin-bottom:.6rem; }
.lmpop__body h3{ font-family:var(--display); font-weight:800; font-size:1.45rem; letter-spacing:-.02em; margin:.4rem 0 .5rem; }
.lmpop__body p{ color:rgba(255,255,255,.82); font-size:.96rem; margin-bottom:1.1rem; }
.lmpop__body form{ display:flex; flex-direction:column; gap:.6rem; }
.lmpop__body input{ padding:.9rem 1.05rem; border-radius:10px; border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.07); color:#fff; font-size:1rem; outline:none; transition:border-color .2s var(--ease), background .2s var(--ease); }
.lmpop__body input::placeholder{ color:rgba(255,255,255,.55); }
.lmpop__body input:focus{ border-color:var(--gold); background:rgba(255,255,255,.12); }
.lmpop__note{ font-size:.76rem; color:rgba(255,255,255,.55); margin-top:.75rem; }
.lmpop__ok{ display:flex; align-items:center; gap:.6rem; margin-top:1rem; font-size:.9rem; color:rgba(255,255,255,.9); }
.lmpop__ok a{ color:#ffd9a0; text-decoration:underline; }
@media (max-width:620px){ .lmpop__box{ grid-template-columns:1fr; } .lmpop__book{ display:none; } }

/* ============================================================
   FRONTEND-POLISH · Seiten-Fade, Stagger, Tilt, Button-Glanz
   ============================================================ */

/* Gestaffeltes Scroll-Reveal (Verzögerung von main.js gesetzt) */
.reveal{ transition-delay:var(--rd,0ms); }

/* 3D-Tilt-Bühne für Teaser-Karten */
.teasers{ perspective:1100px; }
.teaser{ transform-style:preserve-3d; will-change:transform; transition:transform .18s var(--ease), box-shadow .3s var(--ease), border-color .2s var(--ease); }

/* Button-Glanz (dezenter Sheen-Sweep beim Hover) */
.btn--primary{ position:relative; overflow:hidden; }
.btn--primary > *{ position:relative; z-index:1; }
.btn--primary::after{ content:''; position:absolute; top:0; left:-130%; width:55%; height:100%; z-index:0;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.38), transparent); transform:skewX(-18deg); pointer-events:none; }

@media (prefers-reduced-motion:no-preference){
  /* Sanftes Einblenden der ganzen Seite beim Laden */
  body{ animation:pageFade .5s ease both; }
  /* Button-Glanz nur mit Bewegung */
  .btn--primary:hover::after{ animation:sheen .75s var(--ease); }
  /* Eyebrow-Linie wächst beim Reveal */
  .is-revealed .eyebrow::before{ animation:lineGrow .6s var(--ease) both; }
}
@keyframes pageFade{ from{ opacity:0 } to{ opacity:1 } }
@keyframes sheen{ to{ left:160% } }
@keyframes lineGrow{ from{ width:0 } to{ width:28px } }

/* Honeypot-Feld (Spam-Schutz) – für Menschen unsichtbar */
.hp{ position:absolute !important; left:-9999px !important; width:1px; height:1px; overflow:hidden; opacity:0; pointer-events:none; }

/* ============================================================
   BUGFIXES & MOBILE-FEINSCHLIFF
   ============================================================ */

/* FIX: Das hidden-Attribut darf NICHT von display-Regeln (z. B. .lm__success{display:flex})
   überstimmt werden. Sonst zeigen sich Erfolgs-/Status-Boxen dauerhaft. */
[hidden]{ display:none !important; }

/* FIX: Fakten-Raster (Über den ASB) auf kleinen Phones einspaltig – verhindert Rand-Überlauf */
@media (max-width:480px){
  .facts{ grid-template-columns:1fr; }
  .events{ grid-template-columns:1fr; }
}

/* Mobile-Feinschliff: Story-Badge nicht über das Bild ragen lassen, sondern darunter setzen */
@media (max-width:560px){
  .story__badge{ position:static; right:auto; bottom:auto; margin-top:.9rem; max-width:none; box-shadow:var(--schatten-m,0 8px 20px -12px rgba(23,20,15,.25)); }
  .story__media{ max-width:none; }
  .hero__tag{ position:static; margin-top:.9rem; }
}

/* Saubere Antippziele & kein Zoom-Verlust auf iOS (Eingabefelder ≥16px) */
@media (max-width:560px){
  input, select, textarea{ font-size:16px; }
  .btn{ min-height:46px; }
}
