/* ============ ENHANCE: Agent-Sektionen + Overrides (zuletzt geladen) ============ */

/* ---- header ---- */
/* ======================================================================
   ZAUNTURA — Floating Glass Header
   Wird ZULETZT geladen → überschreibt die bestehenden .nav-Regeln.
   Markup bleibt unverändert; das .nav-Element selbst ist die schwebende Pille.
   ====================================================================== */

:root{
  /* Steuer-Tokens für den schwebenden Header (zentral anpassbar) */
  --nav-float-top: 14px;                 /* Abstand zur Oberkante */
  --nav-float-maxw: var(--maxw);         /* maximale Breite der Pille */
  --nav-glass-blur: 20px;
  --nav-glass-sat: 160%;
}

/* ---- schwebender Container ------------------------------------------- */
nav.nav{
  /* fixed bleibt, aber mit Abstand zu allen Rändern */
  position:fixed;
  top:var(--nav-float-top);
  left:50%;
  right:auto;
  transform:translateX(-50%);
  width:calc(100% - (var(--gut) * 2));
  max-width:var(--nav-float-maxw);
  z-index:200;

  /* Pillen-Look */
  border-radius:18px;
  padding:12px clamp(18px, 2.4vw, 26px);
  border:1px solid var(--line);
  border-bottom:1px solid var(--line);

  /* Glass-Fallback: etwas opakerer Hintergrund (dunkles Theme #14181B) */
  background:rgba(20,24,27,.72);

  /* weicher, dezenter Schatten */
  box-shadow:
    0 10px 30px -12px rgba(0,0,0,.55),
    0 2px 10px -6px rgba(0,0,0,.4),
    inset 0 1px 0 rgba(255,255,255,.05);

  transition:
    background .4s ease,
    backdrop-filter .4s ease,
    border-color .4s ease,
    box-shadow .4s ease,
    top .4s ease,
    padding .4s ease;
}

/* Glass-Effekt nur wenn unterstützt → sonst greift der opakere Fallback oben */
@supports ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  nav.nav{
    background:rgba(20,24,27,.52);
    -webkit-backdrop-filter:blur(var(--nav-glass-blur)) saturate(var(--nav-glass-sat));
    backdrop-filter:blur(var(--nav-glass-blur)) saturate(var(--nav-glass-sat));
  }
}

/* ---- Scroll-Zustand --------------------------------------------------
   Wichtig: bestehende motion.js togglet .scrolled (window.scrollY > 30).
   Wir behalten das dunkle Glass-Theme bei (Header schwebt durchgehend über
   hellem Content), verdichten beim Scrollen nur Hintergrund + Schatten,
   damit Text über hellen Sektionen lesbar bleibt. Kein JS nötig. */
nav.nav.scrolled{
  top:10px;
  padding-block:10px;
  background:rgba(16,19,22,.86);
  border-color:rgba(199,206,211,.16);
  box-shadow:
    0 14px 38px -14px rgba(0,0,0,.6),
    0 3px 12px -6px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(255,255,255,.06);
}
@supports ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  nav.nav.scrolled{
    background:rgba(16,19,22,.62);
    -webkit-backdrop-filter:blur(calc(var(--nav-glass-blur) + 4px)) saturate(var(--nav-glass-sat));
    backdrop-filter:blur(calc(var(--nav-glass-blur) + 4px)) saturate(var(--nav-glass-sat));
  }
}

/* ---- Theming: durchgehend helle Schrift (dunkles Glass) --------------
   Override der bestehenden .nav.scrolled-Light-Regeln, da der Header jetzt
   NICHT mehr die volle Breite einnimmt und stets auf dunklem Glass sitzt. */
nav.nav .brand,
nav.nav.scrolled .brand{ color:#F4F6F7; }

nav.nav .nav-links a,
nav.nav.scrolled .nav-links a{ color:rgba(244,246,247,.74); }
nav.nav .nav-links a:hover,
nav.nav.scrolled .nav-links a:hover{ color:#fff; }
nav.nav .nav-links a.active,
nav.nav.scrolled .nav-links a.active{ color:rgba(244,246,247,.98); }

nav.nav .lang,
nav.nav.scrolled .lang{ border-color:rgba(244,246,247,.24); }
nav.nav .lang button,
nav.nav.scrolled .lang button{ color:rgba(244,246,247,.74); }
nav.nav .lang button.on,
nav.nav.scrolled .lang button.on{ color:var(--accent-ink); background:var(--accent); }

nav.nav .nav-tel,
nav.nav.scrolled .nav-tel{ color:rgba(244,246,247,.85); }
nav.nav .nav-tel:hover,
nav.nav.scrolled .nav-tel:hover{ color:#fff; }

nav.nav .nav-burger,
nav.nav.scrolled .nav-burger{ border-color:rgba(244,246,247,.24); }
nav.nav .nav-burger span,
nav.nav.scrolled .nav-burger span{ background:#F4F6F7; }

/* ---- Responsive ------------------------------------------------------ */

/* Tablet/Mobile: Burger sichtbar, etwas engere Pille */
@media (max-width:1000px){
  nav.nav{
    padding:11px clamp(14px, 4vw, 20px);
    border-radius:16px;
  }
}

/* Kleine Phones: knapper Rand, damit die Pille nicht zu schmal wird */
@media (max-width:480px){
  :root{ --nav-float-top:10px; }
  nav.nav{
    width:calc(100% - 24px);
    padding:10px 14px;
    border-radius:14px;
  }
  nav.nav.scrolled{ top:8px; }
}

/* Reduced motion: keine Layout-Transitionen */
@media (prefers-reduced-motion:reduce){
  nav.nav{ transition:background .2s ease, border-color .2s ease; }
}

/* ---- team ---- */
/* ======================================================================
   TEAM — „Die Menschen hinter dem Tor"  ·  einheitliche Karten-Grid
   Alle Mitglieder gleich behandelt: Portrait + immer sichtbare Info.
   Gründer nur durch Goldleiste + Badge abgesetzt (gleiche Struktur).
   ====================================================================== */

.team-sec{ position:relative; overflow:hidden; }
.team-sec::before{
  content:""; position:absolute; left:-8%; top:34%; width:62%; height:60%;
  background:radial-gradient(60% 60% at 50% 50%,
    rgba(var(--accent-glow),.10), rgba(var(--accent-glow),0) 70%);
  pointer-events:none; z-index:0;
}
.team-sec .wrap{ position:relative; z-index:1; }
.team-sec .shead .lead{ max-width:46ch; }

/* ---- the board: 4 equal cols ----------------------------------------- */
.team-board{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(16px,1.6vw,24px);
  margin-top:clamp(34px,4vw,54px);
}

/* ---- one shared card for everyone ------------------------------------ */
.tm-card{
  position:relative; display:flex; flex-direction:column;
  border-radius:var(--r-card); overflow:hidden;
  background:#0E1113;
  border:1px solid rgba(199,206,211,.12);
  box-shadow:0 1px 0 rgba(255,255,255,.03) inset,
             0 22px 50px -30px rgba(0,0,0,.55);
  transition:transform .5s cubic-bezier(.2,.7,.2,1),
             border-color .4s ease, box-shadow .5s ease;
}
.tm-card:hover{
  transform:translateY(-6px);
  border-color:rgba(var(--accent-glow),.5);
  box-shadow:0 1px 0 rgba(255,255,255,.05) inset,
             0 34px 70px -32px rgba(0,0,0,.7),
             0 0 0 1px rgba(var(--accent-glow),.16);
}

/* ---- media: identical frame + cohesive desaturated grade ------------- */
.tm-media{ position:relative; overflow:hidden; aspect-ratio:4/5; background:#0E1113; }
.tm-media image-slot{
  position:absolute; inset:0; width:100%; height:100%; display:block; border-radius:0;
  transform:scale(1.02);
  transition:transform 1s cubic-bezier(.2,.7,.2,1), filter .5s ease;
  /* unify mismatched photos into one premium look — color returns on hover */
  filter:saturate(.6) contrast(1.03) brightness(.96);
  z-index:0;
}
.tm-card:hover .tm-media image-slot{
  transform:scale(1.06);
  filter:saturate(1) contrast(1.04) brightness(1.02);
}
/* touch has no hover → show the full-colour grade so photos aren't stuck grey */
@media (hover:none){
  .tm-media image-slot{ filter:saturate(1) contrast(1.04) brightness(1.02); }
}
.tm-veil{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(14,17,19,0) 58%, rgba(14,17,19,.45) 100%);
}

/* founder badge — the single tasteful differentiator */
.tm-badge{
  position:absolute; top:12px; left:12px; z-index:3;
  font-family:var(--font-display); font-size:10.5px; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase; color:var(--accent-ink);
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  padding:6px 11px; border-radius:var(--r-pill);
  box-shadow:0 6px 18px -6px rgba(var(--accent-glow),.7);
}

/* ---- body: always visible, identical for every member ---------------- */
.tm-body{
  position:relative; z-index:2;
  padding:clamp(16px,1.5vw,22px) clamp(16px,1.5vw,22px) clamp(18px,1.6vw,24px);
  background:linear-gradient(180deg,#12161A,#0C0F11);
  border-top:1px solid rgba(199,206,211,.08);
}
.tm-rule{
  display:block; width:30px; height:2px; border-radius:2px; margin-bottom:13px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  box-shadow:0 0 12px rgba(var(--accent-glow),.5);
  transform-origin:left center; transform:scaleX(1);
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.tm-card:hover .tm-rule{ transform:scaleX(2.2); }
.tm-name{
  font-family:var(--font-serif); font-weight:500;
  font-size:clamp(18px,1.5vw,21px); letter-spacing:-.01em; line-height:1.1;
  margin:0; color:#F7F4EC;
}
.tm-role{
  font-family:var(--font-display); font-size:12px; font-weight:600;
  letter-spacing:.05em; text-transform:uppercase; color:var(--accent); margin:7px 0 0;
}
.tm-line{
  font-size:13.5px; line-height:1.5; margin:11px 0 0; color:rgba(244,246,247,.72);
}

/* founder hierarchy without breaking the grid: subtle gold top accent */
.tm-founder{ border-color:rgba(var(--accent-glow),.32); }
.tm-founder::before{
  content:""; position:absolute; top:0; left:0; right:0; height:3px; z-index:4;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
}

/* ---- reveal: lift cards a touch higher than global default ----------- */
.js .tm-card[data-reveal]{ transform:translateY(40px); }
.js .tm-card[data-reveal].in{ transform:none; }
.js .tm-card[data-reveal].in:hover{ transform:translateY(-6px); }

/* ---- responsive ------------------------------------------------------ */
@media(max-width:1000px){ .team-board{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px){
  .team-board{ grid-template-columns:1fr; }
  .tm-media{ aspect-ratio:3/2; }
}

/* ---- reduced motion -------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  .tm-card, .tm-media image-slot, .tm-rule,
  .tm-card:hover, .tm-card:hover .tm-media image-slot{
    transition:none !important; transform:none !important;
  }
  .tm-media image-slot{ filter:saturate(.8); }
}

/* ---- material ---- */
/* ======================================================================
   ZAUNTURA — Material-Showcase  (#material / .mtx)
   Self-contained replacement for the legacy .matx component.
   Light-theme cohesive · brass accent · cross-fade switcher.
   ====================================================================== */

#material .mtx{
  --mtx: #5b656c;          /* per-material accent, set via JS */
  margin-top: clamp(34px, 5vw, 64px);
}

/* ---------- Switcher (segmented, sliding thumb) ------------------------ */
.mtx-switch{
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  padding: 6px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  box-shadow: var(--shadow-sm, 0 8px 24px -18px rgba(27,23,20,.18));
  max-width: 640px;
}
.mtx-thumb{
  position: absolute;
  top: 6px; left: 6px;
  height: calc(100% - 12px);
  width: calc((100% - 12px - 12px) / 3);  /* (track - padding - 2*gap)/3 */
  border-radius: var(--r-pill);
  background: var(--bg-deep);
  box-shadow: inset 0 0 0 1px var(--mtx);
  transform: translateX(var(--mtx-x, 0));
  transition: transform .5s cubic-bezier(.6,.02,.1,1),
              box-shadow .4s ease;
  z-index: 0;
}
.mtx-opt{
  position: relative; z-index: 1;
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  background: none; border: 0; cursor: pointer;
  color: var(--text-dim);
  text-align: left;
  border-radius: var(--r-pill);
  transition: color .35s ease;
}
.mtx-opt .mtx-swatch{
  flex: none; width: 26px; height: 26px; border-radius: 50%;
  background: conic-gradient(from 220deg, var(--c1), var(--c2), var(--c1));
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.18), inset 0 2px 5px rgba(255,255,255,.35);
  transition: transform .35s ease;
}
.mtx-otx{ display: flex; flex-direction: column; line-height: 1.15; min-width: 0; }
.mtx-otx .on{ font-family: var(--font-serif); font-weight: 500; font-size: 16px; color: inherit; }
.mtx-otx .od{ font-size: 11px; letter-spacing: .04em; color: var(--text-dim); opacity: .8;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mtx-opt.is-on{ color: var(--text); }
.mtx-opt.is-on .on{ color: var(--text); }
.mtx-opt.is-on .mtx-swatch{ transform: scale(1.08); }
.mtx-opt:not(.is-on):hover{ color: var(--text); }
.mtx-opt:focus-visible{ outline: 2px solid var(--accent); outline-offset: 2px; }

/* ---------- Body grid -------------------------------------------------- */
.mtx-body{
  margin-top: clamp(20px, 3vw, 34px);
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: clamp(18px, 2.4vw, 34px);
  align-items: stretch;
}

/* ---------- Visual ----------------------------------------------------- */
.mtx-visual{
  position: relative;
  border-radius: var(--r-card);
  overflow: hidden;
  background: var(--bg-deep);
  border: 1px solid var(--line);
  min-height: clamp(360px, 46vw, 560px);
  isolation: isolate;
}
.mtx-stage{
  position: absolute; inset: 0; margin: 0;
  opacity: 0; transform: scale(1.04);
  transition: opacity .65s ease, transform 1.1s cubic-bezier(.2,.7,.2,1);
  pointer-events: none;
}
.mtx-stage.is-on{ opacity: 1; transform: scale(1); }
.mtx-stage image-slot,
.mtx-stage > image-slot{
  position: absolute; inset: 0; width: 100%; height: 100%;
  display: block;
}
.mtx-stage image-slot img,
.mtx-stage image-slot::part(img){ width: 100%; height: 100%; object-fit: cover; }

/* gentle zoom on hover of whole visual */
.mtx-visual:hover .mtx-stage.is-on{ transform: scale(1.05); }

/* WPC typographic stage (no photo) */
.mtx-stage--wpc{
  display: grid; place-content: center; text-align: center; gap: 8px;
  background:
    repeating-linear-gradient(115deg, rgba(0,0,0,.05) 0 3px, transparent 3px 14px),
    linear-gradient(150deg, #a9763f, #7a522c 46%, #4f351c);
}
.mtx-wpc-grain{
  position: absolute; inset: 0;
  background: repeating-linear-gradient(92deg, rgba(255,255,255,.05) 0 1px, transparent 1px 9px);
  mix-blend-mode: overlay; opacity: .6;
}
.mtx-wpc-word{
  position: relative;
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(64px, 12vw, 132px); letter-spacing: -.02em;
  color: rgba(255,247,235,.96);
  text-shadow: 0 2px 30px rgba(0,0,0,.35);
}
.mtx-wpc-sub{
  position: relative;
  font-family: var(--font-display); font-size: 12.5px; font-weight: 600;
  letter-spacing: .26em; text-transform: uppercase; color: rgba(255,247,235,.7);
}

/* overlay gradient for legibility of corner labels */
.mtx-grad{
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(12,14,16,.42) 0%, transparent 26%),
    linear-gradient(0deg, rgba(12,14,16,.58) 0%, transparent 34%);
}

.mtx-vtop{
  position: absolute; z-index: 3; top: 16px; left: 16px; right: 16px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.mtx-finish{
  font-family: var(--font-display); font-size: 10.5px; font-weight: 600;
  letter-spacing: .04em; text-transform: uppercase;
  color: #fff; padding: 7px 13px; border-radius: var(--r-pill);
  background: rgba(20,24,27,.42); backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.16);
}
.mtx-swatches{ display: inline-flex; gap: 6px; }
.mtx-swatches i{
  width: 16px; height: 16px; border-radius: 50%;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.5), 0 1px 4px rgba(0,0,0,.3);
  transition: transform .3s ease;
}
.mtx-swatches i:hover{ transform: scale(1.25); }

.mtx-vbot{
  position: absolute; z-index: 3; left: 18px; bottom: 16px; right: 18px;
}
.mtx-no{
  display: block; font-family: var(--font-display); font-size: 11px; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.72);
}
.mtx-name{
  display: block; margin-top: 2px;
  font-family: var(--font-serif); font-weight: 500;
  font-size: clamp(30px, 4vw, 46px); letter-spacing: -.01em; color: #fff;
  line-height: 1;
}

/* ---------- Panel ------------------------------------------------------ */
.mtx-panel{
  display: flex; flex-direction: column;
  padding: clamp(22px, 2.4vw, 32px);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
}
.mtx-lead{ margin: 0 0 22px; font-size: 16px; line-height: 1.62; color: var(--text-dim); }

/* metrics / spec bars */
.mtx-metrics{ display: grid; gap: 13px; }
.mtx-metric{ display: grid; gap: 7px; }
.mtx-ml{ display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.mtx-mk{ font-size: 13.5px; font-weight: 500; color: var(--text); }
.mtx-mv{
  font-family: var(--font-display); font-size: 12px; font-weight: 600;
  letter-spacing: .04em; color: var(--text-dim);
  font-variant-numeric: tabular-nums;
}
.mtx-track{
  height: 6px; border-radius: var(--r-pill);
  background: var(--bg-deep); overflow: hidden;
}
.mtx-track > i{
  display: block; height: 100%; width: 0%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--mtx), color-mix(in srgb, var(--mtx) 55%, var(--accent)));
  transition: width .9s cubic-bezier(.5,.05,.1,1), background .5s ease;
}

/* facts row */
.mtx-facts{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  margin-top: 22px; padding-top: 22px; border-top: 1px solid var(--line-soft);
}
.mtx-fact{
  padding: 12px 14px; border-radius: var(--r-card);
  background: var(--surface-2); border: 1px solid var(--line-soft);
}
.mtx-fact .fn{
  font-family: var(--font-serif); font-weight: 500; font-size: 21px;
  color: var(--text); line-height: 1.05;
}
.mtx-fact .fn .u{ font-family: var(--font-display); font-size: 12px; font-weight: 600; color: var(--text-dim); margin-left: 2px; }
.mtx-fact .fl{ margin-top: 3px; font-size: 11.5px; letter-spacing: .02em; color: var(--text-dim); }

/* strength tags */
.mtx-tags{ display: flex; flex-wrap: wrap; gap: 7px; margin-top: 18px; }
.mtx-tags span{
  font-family: var(--font-display); font-size: 12px; font-weight: 600;
  letter-spacing: .02em; color: var(--text);
  padding: 7px 13px; border-radius: var(--r-pill);
  background: var(--bg-deep); border: 1px solid var(--line);
  display: inline-flex; align-items: center; gap: 7px;
}
.mtx-tags span::before{
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--mtx); box-shadow: 0 0 0 3px color-mix(in srgb, var(--mtx) 22%, transparent);
}

/* ideal-for */
.mtx-ideal{
  margin-top: auto; padding-top: 20px;
  display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap;
}
.mtx-il{
  flex: none; font-family: var(--font-display); font-size: 11px; font-weight: 600;
  letter-spacing: .16em; text-transform: uppercase; color: var(--accent-2, var(--accent));
}
.mtx-iv{ font-size: 14.5px; color: var(--text); line-height: 1.45; }

/* ---------- soft cross-fade on panel content swap ---------------------- */
.mtx-panel.is-swap .mtx-lead,
.mtx-panel.is-swap .mtx-facts,
.mtx-panel.is-swap .mtx-tags,
.mtx-panel.is-swap .mtx-ideal{
  opacity: 0; transform: translateY(6px);
}
.mtx-lead, .mtx-facts, .mtx-tags, .mtx-ideal{
  transition: opacity .4s ease, transform .4s ease;
}

/* ---------- responsive ------------------------------------------------- */
@media (max-width: 880px){
  .mtx-body{ grid-template-columns: 1fr; }
  .mtx-visual{ min-height: clamp(300px, 64vw, 460px); }
  .mtx-switch{ max-width: none; }
  .mtx-otx .od{ display: none; }
}
@media (max-width: 560px){
  .mtx-opt{ flex-direction: column; align-items: flex-start; gap: 7px; padding: 12px 12px; }
  .mtx-facts{ grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce){
  .mtx-stage, .mtx-track > i, .mtx-thumb,
  .mtx-lead, .mtx-facts, .mtx-tags, .mtx-ideal{ transition: none !important; }
  .mtx-visual:hover .mtx-stage.is-on{ transform: scale(1); }
}

/* ---- warum ---- */
/* ======================================================================
   WARUM — HORIZONTAL PINNED SCROLL  (append after modern.css)
   Desktop: tall section, sticky stage, content translates on scroll.
   Mobile / reduced-motion: native horizontal swipe rail w/ scroll-snap.
   ====================================================================== */

.warum-hx{
  /* nullify the default vertical .section padding — the pin handles rhythm */
  padding-block:0;
  /* tall section = horizontal travel runway. JS reads scrollable height.
     Falls back gracefully even if JS never runs (sticky still pins). */
  background:var(--bg);
  overflow-x:clip;               /* clip ONLY X (Y stays visible so the sticky
                                    .whx-pin still pins on iOS Safari) */
}

/* ---- sticky stage (DESKTOP horizontal-scroll mode) -------------------- */
.warum-hx .whx-pin{
  position:sticky;
  top:0;
  height:100vh;
  height:100svh;
  display:flex;
  align-items:center;
  overflow:hidden;
}

.warum-hx .whx-stage{
  display:flex;
  align-items:stretch;
  gap:clamp(20px,2.4vw,34px);
  padding-inline:var(--gut);
  /* translateX is driven by JS via --whx (0 → -maxTravel px) */
  transform:translate3d(var(--whx,0px),0,0);
  will-change:transform;
}

/* ---- intro / title panel --------------------------------------------- */
.warum-hx .whx-intro{
  flex:0 0 clamp(340px,42vw,560px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding-right:clamp(20px,3vw,48px);
}
.warum-hx .whx-intro .eyebrow{margin-bottom:22px}
.warum-hx .whx-intro .h2{margin-bottom:22px}
.warum-hx .whx-lead{
  font-size:clamp(16px,1.3vw,19px);
  color:var(--text-dim);
  line-height:1.6;
  max-width:42ch;
  margin:0 0 34px;
}
.warum-hx .whx-cue{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-display);font-size:12px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);
}
.warum-hx .whx-cue-arr{
  display:inline-flex;font-size:18px;
  animation:whxNudge 1.8s ease-in-out infinite;
}
@keyframes whxNudge{0%,100%{transform:translateX(0)}50%{transform:translateX(7px)}}

/* ---- moving track + cards -------------------------------------------- */
.warum-hx .whx-track{
  display:flex;
  align-items:stretch;
  gap:clamp(18px,2vw,28px);
  list-style:none;margin:0;padding:0;
}

.warum-hx .whx-card{
  flex:0 0 clamp(280px,28vw,380px);
  display:flex;
  flex-direction:column;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-card);
  padding:clamp(28px,2.4vw,38px) clamp(26px,2vw,34px);
  position:relative;
  overflow:hidden;
  transition:transform .5s cubic-bezier(.16,1,.3,1),border-color .4s,box-shadow .4s,background .4s;
}
.warum-hx .whx-card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(420px circle at 80% 0%,rgba(var(--accent-glow),.10),transparent 55%);
  opacity:0;transition:opacity .45s;
}
.warum-hx .whx-card:hover{
  transform:translateY(-6px);
  border-color:rgba(var(--accent-glow),.45);
  box-shadow:0 30px 70px -34px rgba(0,0,0,.6);
}
.warum-hx .whx-card:hover::after{opacity:1}

.warum-hx .whx-card-top{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:auto;gap:16px;
}
.warum-hx .whx-no{
  font-family:var(--font-serif);font-style:italic;font-weight:400;
  font-size:18px;color:var(--accent-2);letter-spacing:.02em;
}
.warum-hx .whx-ico{
  width:46px;height:46px;flex:none;color:var(--accent-2);
}
.warum-hx .whx-ico svg{
  width:100%;height:100%;stroke:currentColor;fill:none;
  stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;
}
.warum-hx .whx-card h3{
  font-family:var(--font-serif);font-weight:500;letter-spacing:-.012em;
  font-size:clamp(20px,1.7vw,24px);line-height:1.12;
  margin:30px 0 12px;color:var(--text);
}
.warum-hx .whx-card p{
  font-size:15px;line-height:1.6;color:var(--text-dim);margin:0 0 24px;
}
.warum-hx .whx-tag{
  margin-top:auto;align-self:flex-start;
  font-family:var(--font-display);font-size:11px;font-weight:600;
  letter-spacing:.04em;color:var(--accent-2);
  border:1px solid var(--line);border-radius:var(--r-pill);
  padding:8px 14px;
}

/* accent (highlight) card — the garantie one */
.warum-hx .whx-card--accent{
  background:linear-gradient(160deg,rgba(var(--accent-glow),.16),var(--surface) 62%);
  border-color:rgba(var(--accent-glow),.4);
}

/* closing CTA card */
.warum-hx .whx-card--cta{
  justify-content:center;
  background:linear-gradient(150deg,var(--surface-2),var(--bg-deep));
  border-color:rgba(var(--accent-glow),.3);
}
.warum-hx .whx-card--cta .whx-no{margin-bottom:18px}
.warum-hx .whx-card--cta h3{margin-top:0}
.warum-hx .whx-card--cta .btn{align-self:flex-start;margin-top:6px}

/* ---- desktop progress rail ------------------------------------------- */
.warum-hx .whx-progress{
  position:absolute;left:var(--gut);right:var(--gut);bottom:clamp(28px,5vh,56px);
  height:2px;background:var(--line);border-radius:99px;overflow:hidden;z-index:3;
}
.warum-hx .whx-progress-bar{
  display:block;height:100%;width:0;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  border-radius:99px;
}

/* ======================================================================
   FALLBACK MODE — mobile, coarse pointers, reduced-motion, or no-JS-pin.
   Activated by .whx-static on the section (set by JS) OR media query.
   Becomes a normal, always-working horizontal swipe rail.
   ====================================================================== */
.warum-hx.whx-static{padding-block:clamp(72px,11vw,120px)}
.warum-hx.whx-static .whx-pin{
  position:static;height:auto;display:block;overflow:visible;
}
.warum-hx.whx-static .whx-stage{
  flex-direction:column;
  transform:none !important;
  padding-inline:0;
  gap:clamp(28px,5vw,44px);
}
.warum-hx.whx-static .whx-intro{
  flex:none;padding:0 var(--gut);
}
.warum-hx.whx-static .whx-cue{display:none}
.warum-hx.whx-static .whx-track{
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:6px var(--gut) 24px;
  gap:16px;
}
.warum-hx.whx-static .whx-track::-webkit-scrollbar{display:none}
.warum-hx.whx-static .whx-card{
  scroll-snap-align:start;
  flex:0 0 min(82vw,340px);
}
.warum-hx.whx-static .whx-progress{display:none}

/* hard guarantees regardless of JS: if reduced-motion, force static look */
@media (prefers-reduced-motion:reduce){
  .warum-hx{padding-block:clamp(72px,11vw,120px)}
  .warum-hx .whx-pin{position:static;height:auto;display:block;overflow:visible}
  .warum-hx .whx-stage{flex-direction:column;transform:none !important;padding-inline:0;gap:clamp(28px,5vw,44px)}
  .warum-hx .whx-intro{flex:none;padding:0 var(--gut)}
  .warum-hx .whx-cue{display:none}
  .warum-hx .whx-track{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;padding:6px var(--gut) 24px;gap:16px}
  .warum-hx .whx-track::-webkit-scrollbar{display:none}
  .warum-hx .whx-card{scroll-snap-align:start;flex:0 0 min(82vw,340px);transition:none}
  .warum-hx .whx-card:hover{transform:none}
  .warum-hx .whx-progress{display:none}
}

/* coarse pointer / narrow viewport → static even if JS hasn't tagged yet */
@media (max-width:860px),(hover:none) and (pointer:coarse){
  .warum-hx{padding-block:clamp(72px,11vw,120px)}
  .warum-hx .whx-pin{position:static;height:auto;display:block;overflow:visible}
  .warum-hx .whx-stage{flex-direction:column;transform:none !important;padding-inline:0;gap:clamp(28px,5vw,44px)}
  .warum-hx .whx-intro{flex:none;padding:0 var(--gut)}
  .warum-hx .whx-cue{display:none}
  .warum-hx .whx-track{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;padding:6px var(--gut) 24px;gap:16px}
  .warum-hx .whx-track::-webkit-scrollbar{display:none}
  .warum-hx .whx-card{scroll-snap-align:start;flex:0 0 min(82vw,340px)}
  .warum-hx .whx-progress{display:none}
}

/* ---- foerderung ---- */
/* ======================================================================
   FÖRDERUNG & FINANZIERUNG  (#foerderung)
   Premium dark/light cohesive · bronze accent · hairline geometry
   Appended after styles.css → atelier.css → modern.css (uses their tokens)
   ====================================================================== */

.fin-grid{
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:clamp(20px,2.4vw,34px);
  align-items:stretch;
}

/* ---- LEFT: Beispiel-Rate Visualizer (deko) --------------------------- */
.fin-calc{
  margin:0;
  position:relative;
  display:flex;
  flex-direction:column;
  gap:22px;
  padding:clamp(26px,3vw,36px);
  border:1px solid var(--line);
  border-radius:var(--r-card);
  background:
    radial-gradient(120% 90% at 12% 0%, rgba(var(--accent-glow),.10), transparent 56%),
    var(--surface);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.fin-calc::before{
  content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  box-shadow:inset 0 0 0 1px var(--line-soft);
}

.fin-calc-head{display:flex;flex-direction:column;gap:14px}
.fin-tag{
  display:inline-flex;align-items:center;gap:9px;align-self:flex-start;
  font-family:var(--font-display);font-size:11px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);
  border:1px solid var(--line);border-radius:var(--r-pill);padding:7px 13px;
}
.fin-tag svg{width:15px;height:15px;color:var(--accent);flex:none}
.fin-rate-eff{
  font-family:var(--font-serif);font-size:clamp(22px,2.4vw,30px);
  font-weight:500;letter-spacing:-.01em;color:var(--text);line-height:1.1;
}
.fin-rate-eff b{color:var(--accent);font-weight:600}
.theme-dark .fin-rate-eff b{color:var(--accent-2)}

/* decorative rate bar — illustrates "longer term = smaller rate" */
.fin-bar-wrap{display:flex;flex-direction:column;gap:11px}
.fin-bar{
  position:relative;height:9px;border-radius:var(--r-pill);
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  opacity:.9;
}
.fin-bar-fill{
  position:absolute;inset:0;border-radius:inherit;transform-origin:right;
  background:var(--line);transform:scaleX(.62);
  transition:transform 1.1s cubic-bezier(.5,0,.2,1) .25s;
}
.fin-calc.in .fin-bar-fill{transform:scaleX(.18)}
.fin-bar-dot{
  position:absolute;top:50%;left:18%;width:22px;height:22px;border-radius:50%;
  transform:translate(-50%,-50%);background:var(--surface);
  border:2px solid var(--accent);
  box-shadow:0 4px 14px -4px rgba(var(--accent-glow),.7);
  transition:left 1.1s cubic-bezier(.5,0,.2,1) .25s;
}
.fin-calc.in .fin-bar-dot{left:82%}
.theme-dark .fin-bar-dot{border-color:var(--accent-2)}
.fin-scale{
  display:flex;justify-content:space-between;
  font-family:var(--font-display);font-size:11px;letter-spacing:.06em;
  color:var(--text-dim);
}

.fin-illus{
  display:flex;align-items:baseline;gap:9px;flex-wrap:wrap;margin:0;
  padding-bottom:20px;border-bottom:1px solid var(--line);
}
.fin-illus-k{font-family:var(--font-serif);font-style:italic;font-size:17px;color:var(--accent)}
.theme-dark .fin-illus-k{color:var(--accent-2)}
.fin-illus-v{font-size:15px;color:var(--text-dim)}

.fin-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.fin-mini-c{display:flex;flex-direction:column;gap:4px}
.fin-mini-c b{
  font-family:var(--font-serif);font-weight:500;font-size:clamp(20px,2vw,26px);
  letter-spacing:-.01em;color:var(--text);line-height:1;
}
.fin-mini-c span{font-size:12px;color:var(--text-dim);line-height:1.3}

.fin-disclaimer{
  margin:auto 0 0;font-size:12.5px;line-height:1.5;color:var(--text-dim);
  padding-top:4px;
}

/* ---- RIGHT: cards + steps ------------------------------------------- */
.fin-cards{display:flex;flex-direction:column;gap:clamp(16px,1.8vw,20px)}

.fin-card{
  display:flex;gap:20px;align-items:flex-start;
  padding:clamp(24px,2.6vw,30px);
  border:1px solid var(--line);border-radius:var(--r-card);
  background:var(--surface);box-shadow:var(--shadow-sm);
  transition:transform .55s cubic-bezier(.16,1,.3,1),box-shadow .55s cubic-bezier(.16,1,.3,1),border-color .4s;
}
.fin-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--line)}
.theme-dark .fin-card{box-shadow:none}
.theme-dark .fin-card:hover{background:var(--surface-2)}

.fin-ico{
  flex:none;width:50px;height:50px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);
  background:rgba(var(--accent-glow),.12);
  border:1px solid rgba(var(--accent-glow),.28);
}
.theme-dark .fin-ico{color:var(--accent-2)}
.fin-ico svg{width:26px;height:26px}

.fin-card-tx{min-width:0}
.fin-card-k{
  font-family:var(--font-serif);font-style:italic;font-size:16px;
  color:var(--accent);letter-spacing:.01em;
}
.theme-dark .fin-card-k{color:var(--accent-2)}
.fin-card h3{
  font-family:var(--font-serif);font-weight:500;font-size:22px;
  letter-spacing:-.012em;margin:5px 0 9px;line-height:1.12;color:var(--text);
}
.fin-card p{margin:0;font-size:15px;line-height:1.55;color:var(--text-dim)}
.fin-card p b{color:var(--text);font-weight:600}

/* So läuft die Finanzierung */
.fin-steps{
  list-style:none;margin:2px 0 0;padding:0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border:1px solid var(--line);border-radius:var(--r-card);overflow:hidden;
  background:var(--surface);box-shadow:var(--shadow-sm);
}
.theme-dark .fin-steps{box-shadow:none}
.fin-step{
  position:relative;display:flex;flex-direction:column;gap:12px;
  padding:22px clamp(18px,2vw,24px);
}
.fin-step + .fin-step{border-left:1px solid var(--line)}
.fin-step-n{
  font-family:var(--font-serif);font-style:italic;font-weight:400;
  font-size:15px;color:var(--accent);letter-spacing:.02em;
  position:relative;padding-bottom:12px;
}
.theme-dark .fin-step-n{color:var(--accent-2)}
.fin-step-n::after{content:"";position:absolute;left:0;bottom:0;width:26px;height:1px;background:var(--accent)}
.theme-dark .fin-step-n::after{background:var(--accent-2)}
.fin-step b{display:block;font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--text);margin-bottom:3px}
.fin-step span{font-size:13.5px;color:var(--text-dim);line-height:1.45}

/* ---- Trust + CTA ----------------------------------------------------- */
.fin-foot{
  display:flex;align-items:center;justify-content:space-between;gap:24px 40px;
  flex-wrap:wrap;
  margin-top:clamp(28px,3vw,40px);padding-top:clamp(26px,3vw,34px);
  border-top:1px solid var(--line);
}
.fin-trust{
  list-style:none;margin:0;padding:0;
  display:flex;flex-wrap:wrap;gap:14px 28px;
}
.fin-trust li{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-size:14px;font-weight:500;color:var(--steel);
}
.fin-trust svg{
  width:18px;height:18px;flex:none;color:var(--accent);
  padding:3px;border-radius:50%;background:rgba(var(--accent-glow),.12);
  box-sizing:border-box;
}
.theme-dark .fin-trust svg{color:var(--accent-2)}
.fin-foot .btn{flex:none}

/* ---- responsive ------------------------------------------------------ */
@media (max-width:980px){
  .fin-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .fin-card{flex-direction:column;gap:16px}
  .fin-steps{grid-template-columns:1fr}
  .fin-step + .fin-step{border-left:0;border-top:1px solid var(--line)}
  .fin-mini{gap:10px}
  .fin-foot .btn{width:100%;justify-content:center}
}

/* respect reduced motion: bar shows final illustrative state, no sweep */
@media (prefers-reduced-motion:reduce){
  .fin-bar-fill{transition:none;transform:scaleX(.3)}
  .fin-bar-dot{transition:none;left:70%}
}

/* ======== Overrides (Hasan-Wünsche) ======== */
/* Custom-Cursor entfernen, nativen Mauszeiger wiederherstellen */
.cursor-dot,.cursor-ring{display:none!important}
*{cursor:auto!important}
a,button,.btn,[role=button],summary,label,select,[data-magnetic],.nav-burger,.qopt,[onclick],.crow .btn{cursor:pointer!important}
input:not([type=submit]):not([type=button]),textarea{cursor:text!important}

/* Hero: Text weiter an den linken Rand */
@media(min-width:821px){ #hero.hero{padding-left:clamp(18px,3vw,40px)} }

/* Cookie-Consent nach unten rechts (verdeckt nicht mehr die CTA-Buttons) */
.consent{left:auto;right:16px}
@media(max-width:520px){ .consent{left:12px;right:12px} }

/* ---- accessibility: skip-link + visible focus (launch audit) ---- */
.skip-link{position:fixed;left:12px;top:-60px;z-index:2147483647;
  background:var(--accent);color:var(--accent-ink);font-family:var(--font-display);
  font-weight:600;font-size:14px;padding:10px 16px;border-radius:10px;text-decoration:none;
  transition:top .2s ease;box-shadow:0 10px 30px -8px rgba(0,0,0,.5)}
.skip-link:focus{top:12px}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,
select:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
