/* ============================================================
   Ensura Landing (Scan-Hero) — Styles
   OLED-Dark + Emerald, Outfit/JetBrains Mono. Tokens 1:1 aus
   der Live-Landing (ensuraai).
   ============================================================ */

:root{
  --bg:#050506; --bg-2:#0a0a0d; --ink:#f4f4f6;
  --gray-1:#a8a8b3; --gray-2:#6e6e7a; --gray-3:#45454f;
  --glass:rgba(255,255,255,0.035); --glass-2:rgba(255,255,255,0.06);
  --hair:rgba(255,255,255,0.09); --hair-strong:rgba(255,255,255,0.16);
  --inset-hi:inset 0 1px 0 rgba(255,255,255,0.08);
  --emerald:#10b981; --emerald-bright:#34e0a8; --emerald-ink:#04140d;
  --emerald-glow:rgba(16,185,129,0.5);
  --font-display:'Outfit',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-body:'Outfit',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --radius:22px; --radius-in:16px; --maxw:1240px; --pad:130px;
  --ease:cubic-bezier(0.32,0.72,0,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg);overflow-x:clip;width:100%;max-width:100%}
/* Custom-Scrollbar NUR auf Desktop (Maus) — auf Touch wuerde sie die
   native Auto-Hide-Overlay-Scrollbar durch einen permanenten Balken ersetzen */
@media(pointer:fine){
  html{scrollbar-width:thin;scrollbar-color:var(--gray-3) var(--bg)}
  ::-webkit-scrollbar{width:5px}
  ::-webkit-scrollbar-track{background:var(--bg)}
  ::-webkit-scrollbar-thumb{background:var(--gray-3);border-radius:3px}
}
body{background:var(--bg);color:var(--ink);font-family:var(--font-body);line-height:1.6;
  overflow-x:clip;width:100%;max-width:100%;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
em{font-style:normal;color:var(--emerald-bright)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- Atmosphaere ---------- */
.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
/* (Hintergrund-Atmosphaere kommt aus echten Video-Stills — .section-bg) */

/* ---------- Navbar (Floating Glass Pill) ---------- */
.navbar{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:50;
  width:min(100% - 36px,var(--maxw));display:flex;align-items:center;justify-content:space-between;
  height:62px;padding:0 14px 0 24px;border-radius:999px;background:rgba(10,10,13,.62);
  backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);
  border:1px solid var(--hair);box-shadow:var(--inset-hi),0 12px 40px rgba(0,0,0,.4);
  transition:transform .5s var(--ease),background .4s var(--ease)}
/* Logo-Style 1:1 von der Live-Landing (ensuraai) uebernommen */
.nav-logo{font-family:var(--font-body);font-size:1.35rem;font-weight:700;color:#fff;
  text-decoration:none;white-space:nowrap;letter-spacing:-0.3px;
  display:flex;align-items:center;gap:9px;
  transition:transform 0.3s cubic-bezier(0.22,1,0.36,1)}
.nav-logo:hover{transform:translateY(-1px)}
.nav-mark{width:1em;height:1em;flex:0 0 auto}
.nav-logo sup{font-size:0.5em;color:var(--emerald);font-weight:800;vertical-align:super;margin-left:1px}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none}
.nav-links a{font-size:.92rem;color:var(--gray-1);transition:color .3s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{display:inline-flex;align-items:center;gap:9px;padding:10px 12px 10px 20px;border-radius:999px;
  background:var(--emerald);color:var(--emerald-ink)!important;font-weight:600;font-size:.9rem;
  box-shadow:0 0 0 1px rgba(255,255,255,.12) inset,0 8px 26px rgba(16,185,129,.35);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 0 0 1px rgba(255,255,255,.2) inset,0 10px 32px rgba(16,185,129,.5)}
.nav-cta .ico{width:26px;height:26px;border-radius:999px;background:var(--emerald-ink);color:var(--emerald-bright);
  display:grid;place-items:center;font-size:.85rem;transition:transform .4s var(--ease)}
.nav-cta:hover .ico{transform:translate(2px,-1px)}
.nav-hamburger{display:none}

/* ---------- Buttons ---------- */
.btn-primary{display:inline-flex;align-items:center;gap:11px;padding:15px 16px 15px 26px;border-radius:999px;
  background:var(--emerald);color:var(--emerald-ink);font-weight:600;font-size:1rem;border:none;cursor:pointer;
  box-shadow:0 0 0 1px rgba(255,255,255,.14) inset,0 12px 38px rgba(16,185,129,.4);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.btn-primary:hover{transform:scale(1.04);box-shadow:0 0 0 1px rgba(255,255,255,.22) inset,0 16px 46px rgba(16,185,129,.55)}
.btn-primary:active{transform:scale(.98)}
.btn-primary:hover .ico{transform:translate(2px,-1px) scale(1.05)}
.btn-primary:active{transform:scale(.985)}
.btn-primary .ico{width:30px;height:30px;border-radius:999px;background:var(--emerald-ink);color:var(--emerald-bright);
  display:grid;place-items:center;font-size:.95rem}
.btn-ghost{display:inline-flex;align-items:center;gap:9px;padding:15px 24px;border-radius:999px;
  color:var(--ink);font-weight:500;font-size:1rem;border:1px solid var(--hair);background:var(--glass);
  backdrop-filter:blur(8px);transition:border-color .4s var(--ease),background .4s var(--ease)}
.btn-ghost:hover{border-color:var(--hair-strong);background:var(--glass-2)}

/* ---------- HERO Scroll-Scrub ---------- */
.hero-scroll{position:relative;height:560vh}
.hero-sticky{position:sticky;top:0;height:100dvh;overflow:hidden}
#heroCanvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:1}
.hero-scrim{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% 38%,transparent 30%,rgba(5,5,6,.6) 78%,var(--bg) 100%),
    linear-gradient(180deg,rgba(5,5,6,.55) 0%,transparent 26%,transparent 60%,rgba(5,5,6,.9) 100%)}
.hero-inner{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:0 24px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--emerald-bright);
  padding:7px 15px;border:1px solid rgba(16,185,129,.32);border-radius:999px;
  background:rgba(16,185,129,.06);margin-bottom:26px}
.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--emerald);
  box-shadow:0 0 10px var(--emerald-glow);animation:pulse 2.6s var(--ease) infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}
.hero-title{font-family:var(--font-display);font-weight:700;letter-spacing:-.03em;line-height:1.02;
  font-size:clamp(2.6rem,6.4vw,5.4rem);max-width:16ch}
.hero-sub{margin-top:24px;max-width:60ch;font-size:clamp(1.02rem,1.55vw,1.32rem);
  color:var(--gray-1);font-weight:300;line-height:1.55}
.hero-sub b{color:var(--ink);font-weight:500}
.hero-actions{margin-top:38px;display:flex;gap:16px;align-items:center;flex-wrap:wrap;justify-content:center}
.hero-cue{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:3;
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gray-2);transition:opacity .5s var(--ease)}

/* Brand-Reveal: steigt waehrend des Scrub aus dem Scan auf (Live-Logo-Stil) */
.hero-brand{position:absolute;inset:0;z-index:4;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;pointer-events:none;opacity:0;will-change:opacity,transform}
.hero-brand .bw{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:.9;
  font-size:clamp(3.4rem,12vw,10.5rem);color:#fff;text-shadow:0 0 70px rgba(16,185,129,.5)}
/* Daten-E im Brand-Reveal: baut sich scroll-gesteuert Linie fuer Linie auf
   (stroke-dashoffset wird in hero-video-scrub.js/hero-scrub.js getrieben) */
.hero-brand .brand-mark{width:.72em;height:.72em;margin-right:.14em;vertical-align:-.04em}
.hero-brand .bw sup{position:relative;font-size:.5em;color:var(--emerald);font-weight:600;
  vertical-align:super;margin-left:1px;
  text-shadow:0 0 18px var(--emerald-glow);animation:aiPulse 2.2s ease-in-out infinite}
/* pulsierender Halo hinter dem AI */
.hero-brand .bw sup::after{content:"";position:absolute;inset:-45%;z-index:-1;border-radius:50%;
  pointer-events:none;background:radial-gradient(circle,rgba(16,185,129,.55),transparent 66%);
  filter:blur(6px);animation:aiHalo 2.2s ease-in-out infinite}
@keyframes aiPulse{
  0%,100%{text-shadow:0 0 14px rgba(16,185,129,.5),0 0 30px rgba(16,185,129,.22);color:var(--emerald)}
  50%{text-shadow:0 0 26px rgba(16,185,129,.95),0 0 60px rgba(16,185,129,.5);color:var(--emerald-bright)}
}
@keyframes aiHalo{
  0%,100%{opacity:.35;transform:scale(.9)}
  50%{opacity:.9;transform:scale(1.18)}
}
.hero-brand .bt{margin-top:22px;font-family:var(--font-mono);font-size:clamp(.7rem,1.05vw,.92rem);
  letter-spacing:.36em;text-transform:uppercase;color:var(--emerald-bright);
  display:inline-block;padding:9px 20px;border-radius:999px;
  background:rgba(0,0,0,.42);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.06)}

/* ---------- generische Section ---------- */
.section{position:relative;z-index:2;padding:clamp(90px,12vw,160px) 0}
.eyebrow{display:inline-block;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--emerald-bright);margin-bottom:18px}
.s-head{max-width:760px;margin-bottom:64px}
.s-title{font-family:var(--font-display);font-weight:600;letter-spacing:-.025em;line-height:1.06;
  font-size:clamp(2rem,3.8vw,3.3rem)}
.s-sub{margin-top:18px;font-size:clamp(1rem,1.3vw,1.18rem);color:var(--gray-1);font-weight:300;max-width:62ch}
.reveal{opacity:0;transform:translateY(34px);filter:blur(6px);
  transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease)}
.reveal.in{opacity:1;transform:none;filter:none}

/* ---------- Problem ---------- */
.problem .s-title{font-size:clamp(2.1rem,4.4vw,3.6rem);max-width:18ch}
.problem-body{margin-top:26px;max-width:64ch;font-size:clamp(1.05rem,1.45vw,1.3rem);
  color:var(--gray-1);font-weight:300}
.problem-body b{color:var(--ink);font-weight:500}

/* ---------- Pruef-Inhalte (o-*): von Containern entkoppelt, genutzt
   vom Pruefstand-Akkordeon (V1) und vom Bento (V2) ---------- */
.o-num{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1;
  font-size:clamp(2.2rem,3.4vw,3rem);color:var(--emerald-bright)}
.o-num .u{font-size:.42em;color:var(--gray-2);font-weight:500;margin-left:4px}
.o-label{margin-top:14px;font-size:1.05rem;color:var(--ink);font-weight:500}
.o-desc{margin-top:7px;font-size:.92rem;color:var(--gray-2)}
.o-tag{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--emerald-bright)}

/* ---------- Der Pruefstand (V1): horizontales Akkordeon ----------
   Eine Dimension ist immer offen (Default: die erste), Hover faehrt die
   anderen auf. Reines CSS ueber flex-Anteile, kein JS. */
.exam{display:flex;gap:12px;min-height:380px}
.exam-slat{position:relative;flex:1;min-width:64px;overflow:hidden;cursor:pointer;
  padding:7px;border-radius:24px;background:rgba(255,255,255,.03);border:1px solid var(--hair);
  transition:flex .75s var(--ease),border-color .6s var(--ease)}
.exam-slat:hover{border-color:rgba(16,185,129,.35)}
/* Default: erste Dimension offen — sobald irgendwo gehovert wird, regiert der Hover */
.exam:not(:hover) .exam-slat:first-child,
.exam .exam-slat:hover{flex:4.2}
.exam-rail{position:absolute;left:0;top:0;bottom:0;width:64px;display:flex;align-items:flex-end;
  justify-content:center;padding:22px 0;writing-mode:vertical-rl;transform:rotate(180deg);
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--emerald-bright)}
.exam-body{position:absolute;inset:7px 7px 7px 64px;width:min(520px,52vw);
  padding:clamp(20px,2.6vw,32px);border-radius:17px;background:var(--glass);box-shadow:var(--inset-hi);
  display:flex;flex-direction:column;justify-content:flex-end;
  opacity:0;transform:translateX(14px);
  transition:opacity .5s var(--ease) .12s,transform .6s var(--ease) .12s}
.exam:not(:hover) .exam-slat:first-child .exam-body,
.exam .exam-slat:hover .exam-body{opacity:1;transform:translateX(0)}
/* Mobil/Touch: vertikaler Stapel, alles sichtbar — Hover existiert dort nicht */
@media(max-width:900px){
  .exam{flex-direction:column;min-height:0}
  .exam-slat,.exam:not(:hover) .exam-slat:first-child,.exam .exam-slat:hover{flex:none}
  .exam-rail{position:static;width:auto;writing-mode:horizontal-tb;transform:none;
    justify-content:flex-start;padding:14px 16px 0}
  .exam-body{position:static;width:auto;opacity:1;transform:none;justify-content:flex-start}
}

/* ---------- Prozess ---------- */
.proc{display:grid;gap:0}
.proc-row{display:grid;grid-template-columns:84px 1fr auto;gap:30px;align-items:start;
  padding:38px 0;border-top:1px solid var(--hair)}
.proc-row:last-child{border-bottom:1px solid var(--hair)}
.proc-num{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--emerald);
  font-variant-numeric:tabular-nums}
.proc-text h3{font-family:var(--font-display);font-size:clamp(1.3rem,2vw,1.7rem);font-weight:600;
  letter-spacing:-.02em;margin-bottom:10px}
.proc-text p{color:var(--gray-1);font-weight:300;max-width:54ch}
.proc-meta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gray-2);white-space:nowrap;padding-top:7px}

/* ---------- Methodik (Feature-Kacheln) ---------- */
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.fact{padding:32px 28px 34px;border-radius:var(--radius);background:var(--glass);
  border:1px solid var(--hair);box-shadow:var(--inset-hi)}
.fact-h{position:relative;padding-top:20px;font-family:var(--font-display);font-weight:600;
  letter-spacing:-.02em;line-height:1.15;color:var(--ink);font-size:clamp(1.2rem,1.6vw,1.5rem)}
.fact-h::before{content:"";position:absolute;top:0;left:0;width:30px;height:3px;border-radius:2px;
  background:var(--emerald);box-shadow:0 0 12px var(--emerald-glow)}
.fact-label{margin-top:15px;color:var(--gray-1);font-size:.97rem;font-weight:300;line-height:1.55}

/* ---------- Zahlen-Strip (echte Produkt-Fakten, Count-Up via fx.js) ---------- */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  margin-top:clamp(40px,6vw,72px);padding-top:clamp(28px,4vw,44px);border-top:1px solid var(--hair)}
.stat{text-align:center}
.stat-n{font-family:var(--font-display);font-weight:700;letter-spacing:-.03em;line-height:1;
  font-size:clamp(2rem,4.4vw,3.4rem);color:var(--emerald-bright)}
.stat-l{margin-top:10px;color:var(--gray-2);font-family:var(--font-mono);font-size:.68rem;
  letter-spacing:.16em;text-transform:uppercase}
@media(max-width:760px){.stats-strip{grid-template-columns:repeat(2,1fr);gap:26px 14px}}

/* ---------- CTA nach der Demo ---------- */
.demo-cta{text-align:center;margin-top:clamp(44px,6vw,72px)}
.demo-cta-h{font-family:var(--font-display);font-weight:700;letter-spacing:-.03em;line-height:1.1;
  font-size:clamp(1.7rem,3.6vw,2.6rem);color:#fff}
.demo-cta-h em{font-style:normal;color:var(--emerald-bright)}
.demo-cta-sub{margin-top:12px;color:var(--gray-1);font-weight:300;font-size:1.05rem}
.demo-cta-actions{margin-top:26px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Sektions-Backdrop: Still aus dem eigenen Scan-Video ----------
   Stark abgedunkelt, oben/unten ins Schwarz maskiert — die Sektion
   "schwebt" ueber der gescannten Stadt. Echtes Markenmaterial statt Deko. */
.section-bg{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.section-bg img{width:100%;height:100%;object-fit:cover;display:block;
  opacity:.34;filter:brightness(.62) saturate(1.05);
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 22%,#000 78%,transparent);
          mask-image:linear-gradient(180deg,transparent,#000 22%,#000 78%,transparent)}
/* Lazy nachgeladene Akt-Hintergruende: unsichtbar starten und nach dem
   Load weich einblenden (ui.js setzt die Klassen) — sonst ploppt das
   fertig geladene Still mitten im Scrollen hart ins Bild. */
.section-bg img.bg-lazy{opacity:0}
.section-bg img.bg-in{opacity:.34;transition:opacity .9s ease}

/* ---------- Preloader ---------- */
body:not(.loaded){overflow:hidden}
/* Daten-E im Preloader: Balken bauen sich von unten auf (Fundament zuerst) */
.pl-mark{display:flex;flex-direction:column;align-items:flex-start;gap:9px;margin:0 auto 18px;width:56px}
.pl-mark i{display:block;height:8px;border-radius:99px;transform:scaleX(0);transform-origin:left;
  animation:plBar .7s var(--ease) forwards}
.pl-mark i:nth-child(1){width:100%;background:#0c7d5b;animation-delay:.55s}
.pl-mark i:nth-child(2){width:68%;background:#10b981;animation-delay:.35s}
.pl-mark i:nth-child(3){width:100%;background:#34e0a8;animation-delay:.15s}
@keyframes plBar{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@media(prefers-reduced-motion:reduce){.pl-mark i{animation:none;transform:none}}
#preloader{position:fixed;inset:0;z-index:200;background:var(--bg);display:flex;align-items:center;justify-content:center;
  transition:opacity .8s var(--ease),visibility .8s var(--ease)}
#preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.pl-inner{width:min(86vw,340px);text-align:center}
.pl-logo{font-family:var(--font-display);font-weight:700;font-size:2rem;letter-spacing:-.02em;color:#fff;margin-bottom:30px}
.pl-logo sup{font-size:.5em;color:var(--emerald);vertical-align:super;
  text-shadow:0 0 18px var(--emerald-glow);animation:aiPulse 2.2s ease-in-out infinite}
.pl-bar{height:3px;border-radius:999px;background:var(--hair);overflow:hidden}
.pl-bar i{display:block;height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--emerald),var(--emerald-bright));transition:width .3s var(--ease)}
.pl-pct{margin-top:14px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;color:var(--gray-2)}

/* ---------- Pricing ---------- */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.price-card{position:relative;display:flex;flex-direction:column;padding:34px 30px;border-radius:var(--radius);
  background:var(--glass);border:1px solid var(--hair);box-shadow:var(--inset-hi);
  transition:transform .5s var(--ease),border-color .5s var(--ease)}
.price-card:hover{transform:translateY(-4px);border-color:var(--hair-strong)}
.price-card.featured{background:linear-gradient(160deg,rgba(16,185,129,.15),rgba(16,185,129,.02));
  border-color:rgba(16,185,129,.35);box-shadow:var(--inset-hi),0 34px 80px -34px rgba(16,185,129,.45)}
.price-badge{position:absolute;top:-11px;left:30px;font-family:var(--font-mono);font-size:.62rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--emerald-ink);background:var(--emerald);
  padding:5px 13px;border-radius:999px;font-weight:700}
.price-tier{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--gray-1);letter-spacing:.02em}
.price-amount{margin-top:14px;font-family:var(--font-display);font-weight:700;letter-spacing:-.03em;
  font-size:3rem;line-height:1;color:var(--ink)}
.price-amount .per{font-size:.9rem;color:var(--gray-2);font-weight:400;margin-left:7px;letter-spacing:0}
.price-desc{margin-top:13px;color:var(--gray-1);font-weight:300;font-size:.96rem;min-height:44px}
.price-feat{list-style:none;margin:22px 0 28px;display:grid;gap:13px}
.price-feat li{display:flex;gap:11px;align-items:flex-start;color:var(--gray-1);font-size:.95rem}
.price-feat li::before{content:"";width:16px;height:16px;border-radius:50%;flex:0 0 16px;margin-top:3px;
  background:radial-gradient(circle at 50% 50%,var(--emerald) 0 34%,transparent 37%),rgba(16,185,129,.14)}
.price-feat li b{color:var(--ink);font-weight:600}
.price-btn{margin-top:auto;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 22px;border-radius:999px;font-weight:600;font-size:.95rem;cursor:pointer;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .3s var(--ease),border-color .3s}
.price-btn.outline{border:1px solid var(--hair-strong);background:var(--glass);color:var(--ink)}
.price-btn.outline:hover{border-color:var(--emerald);background:var(--glass-2)}
.price-btn.solid{background:var(--emerald);color:var(--emerald-ink);box-shadow:0 12px 34px rgba(16,185,129,.4)}
.price-btn.solid:hover{transform:translateY(-2px);box-shadow:0 16px 46px rgba(16,185,129,.55)}
.price-btn .ico{width:24px;height:24px;border-radius:999px;background:var(--emerald-ink);color:var(--emerald-bright);
  display:grid;place-items:center;font-size:.8rem}
.price-foot{margin-top:36px;text-align:center;color:var(--gray-1);font-size:.96rem;font-weight:300}
.price-foot a{color:var(--emerald-bright)}
/* Personal-Service / Concierge unter den Price-Cards */
.price-concierge{margin-top:28px;display:flex;align-items:center;justify-content:space-between;gap:32px;
  flex-wrap:wrap;padding:36px 40px;border-radius:var(--radius);
  background:linear-gradient(150deg,rgba(16,185,129,.13),rgba(16,185,129,.02));
  border:1px solid rgba(16,185,129,.28);box-shadow:var(--inset-hi)}
.price-concierge .pc-text{flex:1 1 380px}
.price-concierge h3{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;
  font-size:clamp(1.4rem,2.1vw,1.95rem);margin:12px 0 12px;color:var(--ink)}
.price-concierge p{color:var(--gray-1);font-weight:300;line-height:1.55;max-width:62ch}
.price-concierge .pc-cta{flex:0 0 auto}
@media(max-width:760px){.price-concierge{padding:28px 24px}}

/* ---------- Final CTA ---------- */
.cta{position:relative;z-index:2;text-align:center;padding:clamp(110px,15vw,180px) 0}
.cta-title{font-family:var(--font-display);font-weight:700;letter-spacing:-.03em;line-height:1.05;
  font-size:clamp(2.4rem,5.4vw,4.4rem);max-width:20ch;margin:0 auto}
.cta .btn-primary{margin-top:40px;font-size:1.1rem;padding:18px 18px 18px 30px}

/* ---------- Footer ---------- */
.footer{position:relative;z-index:2;border-top:1px solid var(--hair);padding:70px 0 50px}
.footer-inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.footer-brand p{margin-top:14px;color:var(--gray-2);max-width:34ch;font-size:.94rem;font-weight:300}
.footer h4{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-1);margin-bottom:16px}
.footer ul{list-style:none;display:grid;gap:11px}
.footer ul a{color:var(--gray-2);font-size:.94rem;transition:color .3s var(--ease)}
.footer ul a:hover{color:var(--ink)}
.footer-bottom{margin-top:54px;padding-top:26px;border-top:1px solid var(--hair);
  color:var(--gray-2);font-size:.84rem}

/* ---------- Demo-Embed (echte Analyse-App im iframe) ---------- */
.demo-embed{border-radius:var(--radius);overflow:hidden;border:1px solid var(--hair);
  box-shadow:var(--inset-hi),0 50px 120px -40px rgba(0,0,0,.9);background:#0a0b0f}
.demo-embed-bar{display:flex;align-items:center;gap:14px;padding:12px 18px;
  border-bottom:1px solid var(--hair);background:rgba(255,255,255,.02)}
.demo-embed-bar .dots{display:flex;gap:7px}
.demo-embed-bar .dots i{width:11px;height:11px;border-radius:50%;background:var(--gray-3)}
.demo-embed-url{font-family:var(--font-mono);font-size:.72rem;color:var(--gray-2);
  background:var(--glass);padding:5px 16px;border-radius:999px;border:1px solid var(--hair)}
/* Hoehe an den Viewport koppeln: die App soll ohne sofortiges Scrollen
   nutzbar sein (min 780px, sonst ~92% der Bildschirmhoehe) */
.demo-embed iframe{display:block;width:100%;height:max(795px,calc(92vh + 15px));border:0;background:#0a0a0f}
@media(max-width:760px){.demo-embed iframe{height:max(560px,80vh)}}

/* ---------- Premium FX ---------- */
/* Cursor-Spotlight: Karten leuchten unter dem Mauszeiger emerald auf */
.exam-slat,.bcard,.quote,.price-card,.fact{position:relative}
.fact{overflow:hidden}
.exam-slat::after,.bcard::after,.quote::after,.price-card::after,.fact::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  pointer-events:none;opacity:0;transition:opacity .45s var(--ease);
  background:radial-gradient(320px circle at var(--mx,50%) var(--my,50%),rgba(16,185,129,.16),transparent 62%)}
.exam-slat:hover::after,.bcard:hover::after,.quote:hover::after,.price-card:hover::after,.fact:hover::after{opacity:1}
/* Magnetic Buttons: ziehen sich leicht zum Cursor */
.magnetic{transition:transform .25s var(--ease),box-shadow .4s var(--ease)}
/* Hero Load-In: gestaffeltes Einblenden beim Laden */
.hero-inner > *{opacity:0;animation:heroUp .9s var(--ease) forwards}
.hero-eyebrow{animation-delay:.10s}
.hero-title{animation-delay:.22s}
.hero-sub{animation-delay:.36s}
.hero-actions{animation-delay:.50s}
@keyframes heroUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .facts{grid-template-columns:1fr 1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .pricing-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .proc-row{grid-template-columns:54px 1fr;gap:18px}
  .proc-meta{grid-column:2;padding-top:0}
}
@media(max-width:620px){
  .footer-inner{grid-template-columns:1fr 1fr}
  .facts{grid-template-columns:1fr}
}

/* ---------- Mobile-Nav (Hamburger) ---------- */
/* Burger = das Daten-E: drei Balken, Mitte kuerzer, Fundament-Farben.
   Beim Oeffnen morphen die Aussenbalken weiter zum X. */
.nav-burger{display:none;width:42px;height:42px;border:none;background:transparent;cursor:pointer;
  position:relative;z-index:3;flex:0 0 auto;padding:0 0 0 10px;text-align:left}
.nav-burger span{display:block;height:3px;margin:4.5px 0;border-radius:99px;
  transition:transform .35s var(--ease),opacity .25s var(--ease)}
.nav-burger span:nth-child(1){width:22px;background:#0c7d5b}
.nav-burger span:nth-child(2){width:15px;background:#10b981}
.nav-burger span:nth-child(3){width:22px;background:#34e0a8}
.navbar.open .nav-burger span:nth-child(1){transform:translateY(12px) rotate(45deg)}
.navbar.open .nav-burger span:nth-child(2){opacity:0}
.navbar.open .nav-burger span:nth-child(3){transform:translateY(-12px) rotate(-45deg)}
@media(max-width:760px){
  .nav-burger{display:block}
  /* Fullscreen-Glass-Overlay statt Drawer: grosse Display-Typo,
     nummerierte Eintraege, gestaffeltes Einblenden */
  .nav-links{position:fixed;inset:0;height:100dvh;width:100%;
    flex-direction:column;align-items:flex-start;justify-content:center;gap:8px;
    padding:0 clamp(28px,10vw,64px);counter-reset:menu;
    background:rgba(5,5,6,.85);backdrop-filter:blur(28px) saturate(150%);
    -webkit-backdrop-filter:blur(28px) saturate(150%);
    opacity:0;visibility:hidden;
    transition:opacity .45s var(--ease),visibility 0s .45s;z-index:2}
  .navbar.open .nav-links{opacity:1;visibility:visible;transition:opacity .45s var(--ease)}
  .nav-links li{opacity:0;transform:translateY(28px);
    transition:opacity .5s var(--ease),transform .65s var(--ease)}
  .navbar.open .nav-links li{opacity:1;transform:none}
  .navbar.open .nav-links li:nth-child(1){transition-delay:.08s}
  .navbar.open .nav-links li:nth-child(2){transition-delay:.14s}
  .navbar.open .nav-links li:nth-child(3){transition-delay:.20s}
  .navbar.open .nav-links li:nth-child(4){transition-delay:.26s}
  .navbar.open .nav-links li:nth-child(5){transition-delay:.32s}
  .navbar.open .nav-links li:nth-child(6){transition-delay:.40s}
  .nav-links a{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;
    font-size:clamp(1.9rem,8.5vw,2.6rem);color:var(--ink);
    display:flex;align-items:baseline;gap:16px}
  .nav-links a:not(.nav-cta)::before{counter-increment:menu;content:"0" counter(menu);
    font-family:var(--font-mono);font-size:.66rem;letter-spacing:.18em;color:var(--emerald-bright)}
  .nav-links .nav-cta{margin-top:26px;font-size:1rem;font-family:var(--font-body);letter-spacing:0}
}
/* Hintergrund-Scroll sperren, solange das Menue offen ist */
body.nav-open{overflow:hidden}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;filter:none;transition:none}
  .hero-eyebrow .dot{animation:none}
  .hero-inner > *{opacity:1;animation:none}
  .hero-brand .bw sup,.hero-brand .bw sup::after{animation:none}
}
