:root{
  --bg:#161b35; --bg-2:#1e2444; --card:#232a52; --card-2:#2a3160;
  --text:#eef1fb; --muted:#9aa3c9; --gold:#d9b16a; --gold-soft:rgba(217,177,106,.15);
  --danger:#c96a6a; --ok:#7fd1a6; --radius:18px; --shadow:0 8px 30px rgba(0,0,0,.35);
  --maxw:980px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  line-height:1.55;
}
a{color:var(--gold)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
h1,h2,h3{line-height:1.15;margin:0 0 .4em}
h1{font-size:clamp(2.1rem,6vw,3.6rem);letter-spacing:-.02em}
h2{font-size:clamp(1.5rem,4vw,2.2rem)}
p{color:var(--muted);margin:0 0 16px}
.lead{font-size:clamp(1.05rem,2.4vw,1.3rem);color:#cfd5f0;max-width:46ch}

/* ---------- Header ---------- */
header.nav{position:sticky;top:0;z-index:20;backdrop-filter:blur(8px);
  background:rgba(22,27,53,.6);border-bottom:1px solid rgba(255,255,255,.06)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:60px}
.logo{font-weight:800;font-size:1.25rem;text-decoration:none;color:var(--text)}
.logo .dot{color:var(--gold)}
.nav a.cta{font-size:.95rem}

/* ---------- Hero + Boids ---------- */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;padding-bottom:8vh}
/* touch-action:pan-y -> vertikales Scrollen am Canvas bleibt moeglich (Mobile) */
#boids{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0;touch-action:pan-y}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent 40%,rgba(22,27,53,.55) 78%,var(--bg) 100%)}
.hero-content{position:relative;z-index:2;width:100%;pointer-events:none}
.hero-content a{pointer-events:auto}
.tagline{color:var(--gold);font-weight:600;letter-spacing:.34em;text-transform:uppercase;font-size:.78rem;margin-bottom:14px}
.hero-cap{font-size:clamp(1.3rem,3.4vw,2.2rem);font-weight:700;max-width:22ch;line-height:1.15;
  background:linear-gradient(180deg,#fff,#ece3cf);-webkit-background-clip:text;background-clip:text;color:transparent;
  margin:0 0 22px;min-height:2.4em}
.hero-cap.show{animation:capIn .6s ease both}
@keyframes capIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Boid-Text-Überschriften */
.boidtext{position:relative;width:100%;height:clamp(96px,16vw,180px);margin:0 0 .3em;min-height:96px}
.boidtext.center{max-width:none}
.boidtext.sm{height:74px;min-height:74px;margin:0 0 10px}
.boidtext canvas{touch-action:pan-y}
@media(prefers-reduced-motion:reduce){.hero-cap.show{animation:none;opacity:1}}
.btn{display:inline-block;background:linear-gradient(135deg,#f2d79b,var(--gold));color:#20253f;font-weight:700;
  text-decoration:none;padding:15px 28px;border-radius:14px;border:0;cursor:pointer;font-size:1rem;
  box-shadow:0 8px 30px rgba(217,177,106,.28);transition:transform .15s,box-shadow .15s,filter .15s}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(217,177,106,.45)}
.btn.ghost{background:rgba(255,255,255,.04);color:var(--text);border:1px solid rgba(255,255,255,.18);box-shadow:none;backdrop-filter:blur(6px)}
.btn.ghost:hover{border-color:var(--gold);box-shadow:0 8px 30px rgba(0,0,0,.25)}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}

/* ---------- Sections ---------- */
section.block{padding:78px 0}
.kicker{color:var(--gold);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;margin-bottom:10px}
.grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));margin-top:26px}
.card{position:relative;background:linear-gradient(180deg,rgba(42,49,96,.55),rgba(35,42,82,.35));
  border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:26px;
  backdrop-filter:blur(10px);box-shadow:var(--shadow);overflow:hidden;
  transition:transform .2s,border-color .2s}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(140deg,rgba(217,177,106,.5),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .25s}
.card:hover{transform:translateY(-4px);border-color:rgba(217,177,106,.3)}
.card:hover::before{opacity:1}
.card h3{font-size:1.15rem}
.card .num{font-size:1.4rem;color:#20253f;font-weight:800;margin-bottom:14px;
  width:42px;height:42px;display:grid;place-items:center;border-radius:12px;
  background:linear-gradient(135deg,#f2d79b,var(--gold));box-shadow:0 6px 18px rgba(217,177,106,.35)}
.card p{margin:0}

/* ---------- How it works (3D) ---------- */
.how{background:
  radial-gradient(80% 60% at 50% -10%,rgba(217,177,106,.10),transparent 60%),
  var(--bg-2)}
.steps3d{display:grid;gap:22px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  margin-top:34px;perspective:1100px}
.step{perspective:900px}
.step-inner{position:relative;height:100%;min-height:240px;padding:28px;border-radius:22px;
  transform-style:preserve-3d;transform:translateZ(0) rotateX(0) rotateY(0);
  background:linear-gradient(180deg,rgba(42,49,96,.6),rgba(30,36,68,.4));
  border:1px solid rgba(255,255,255,.09);backdrop-filter:blur(12px);
  box-shadow:0 18px 50px rgba(0,0,0,.4);
  transition:transform .5s cubic-bezier(.2,.8,.2,1),box-shadow .4s;
  opacity:0;transform-origin:50% 100%}
/* 3D-Eintritt beim Scrollen */
.step .step-inner{transform:translateY(40px) rotateX(22deg) scale(.96)}
.step.in .step-inner{opacity:1;transform:translateY(0) rotateX(0) scale(1);transition-delay:var(--d)}
.step.in .step-inner{animation:float 7s var(--d) ease-in-out infinite}
.step:hover .step-inner{animation:none;box-shadow:0 30px 70px rgba(0,0,0,.55),0 0 0 1px rgba(217,177,106,.35)}
@keyframes float{0%,100%{translate:0 0}50%{translate:0 -8px}}

.step-layer{transform:translateZ(var(--lz,0));transition:transform .3s}
.step .ico{width:64px;height:64px;margin-bottom:18px}
.step .badge{position:absolute;top:22px;right:24px;font-weight:800;font-size:1.1rem;
  color:var(--gold);opacity:.55;letter-spacing:.04em}
.step h3{font-size:1.18rem;margin:0 0 8px}
.step p{margin:0;font-size:.96rem}

/* Glanz-Reflex, folgt dem Cursor (--mx/--my von JS) */
.glare{position:absolute;inset:0;border-radius:22px;pointer-events:none;opacity:0;
  transition:opacity .3s;mix-blend-mode:screen;
  background:radial-gradient(220px 220px at var(--mx,50%) var(--my,0%),rgba(255,224,170,.28),transparent 60%)}
.step:hover .glare{opacity:1}

/* ---- animierte Icons ---- */
.ic{width:64px;height:64px;overflow:visible}
.ic [fill]{fill:none}
.ic circle,.ic rect,.ic path,.ic line{stroke:var(--gold);stroke-width:2.4;fill:none;
  stroke-linecap:round;stroke-linejoin:round}
.ic-ghost circle,.ic-ghost path{animation:ghostFade 3s ease-in-out infinite}
.ic-ghost .slash{stroke:#fff;opacity:.85;stroke-dasharray:60;stroke-dashoffset:60;
  animation:slashIn 3s ease-in-out infinite}
@keyframes ghostFade{0%,100%{opacity:.25}50%{opacity:.9}}
@keyframes slashIn{0%{stroke-dashoffset:60}40%,100%{stroke-dashoffset:0}}
.ic-scan rect{fill:rgba(217,177,106,.12)}
.ic-scan .beam{stroke:#fff;stroke-width:2.4;filter:drop-shadow(0 0 6px rgba(255,224,170,.9));
  animation:scan 2.2s ease-in-out infinite}
@keyframes scan{0%{transform:translateY(-16px);opacity:0}15%,85%{opacity:1}50%{transform:translateY(16px)}100%{transform:translateY(-16px);opacity:0}}
.ic-signal .core{fill:var(--gold)}
.ic-signal .ring{transform-origin:32px 32px;opacity:0}
.ic-signal .r1{animation:ping 2.4s ease-out infinite}
.ic-signal .r2{animation:ping 2.4s .5s ease-out infinite}
.ic-signal .r3{animation:ping 2.4s 1s ease-out infinite}
@keyframes ping{0%{transform:scale(.3);opacity:.9}80%,100%{transform:scale(1);opacity:0}}
.ic-match .node{fill:var(--gold)}
.ic-match .link{stroke-dasharray:24;stroke-dashoffset:24;animation:linkDraw 3s ease-in-out infinite}
.ic-match .heart{fill:rgba(217,177,106,.18);transform-origin:32px 34px;opacity:0;
  animation:matchPop 3s ease-in-out infinite}
@keyframes linkDraw{0%,20%{stroke-dashoffset:24}50%,100%{stroke-dashoffset:0}}
@keyframes matchPop{0%,45%{opacity:0;transform:scale(.4)}60%{opacity:1;transform:scale(1.15)}75%{transform:scale(1)}100%{opacity:1;transform:scale(1)}}

@media(prefers-reduced-motion:reduce){
  .step .step-inner{opacity:1;transform:none;animation:none}
  .ic *{animation:none!important}
}

/* ---------- Waitlist ---------- */
.signup{background:linear-gradient(180deg,var(--bg-2),var(--bg));border-top:1px solid rgba(255,255,255,.06)}
.form-card{background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow);max-width:560px;margin:26px auto 0}
label{display:block;font-size:.85rem;color:var(--muted);margin:14px 0 6px}
input[type=email],input[type=text],select{
  width:100%;padding:13px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.12);
  background:var(--bg-2);color:var(--text);font-family:inherit;font-size:1rem}
input:focus,select:focus{outline:none;border-color:var(--gold)}
.row2{display:grid;gap:12px;grid-template-columns:1fr 1fr}
@media(max-width:480px){.row2{grid-template-columns:1fr}}
.consent{display:flex;gap:10px;align-items:flex-start;margin:18px 0 6px;font-size:.85rem;color:var(--muted)}
.consent input{margin-top:3px;width:18px;height:18px;accent-color:var(--gold);flex:0 0 auto}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-card .btn{width:100%;margin-top:18px}
.msg{margin-top:14px;font-size:.92rem;min-height:1.2em}
.msg.ok{color:var(--ok)}
.msg.err{color:var(--danger)}
.count{color:var(--gold);font-weight:700}

/* ---------- Footer ---------- */
footer{border-top:1px solid rgba(255,255,255,.06);padding:34px 0;color:var(--muted);font-size:.9rem}
footer .wrap{display:flex;gap:18px;flex-wrap:wrap;justify-content:space-between;align-items:center}
footer a{color:var(--muted);text-decoration:none;margin-right:16px}
footer a:hover{color:var(--gold)}

/* ---------- Legal pages ---------- */
.legal{max-width:760px;margin:0 auto;padding:48px 20px}
.legal h1{font-size:2rem}
.legal h2{font-size:1.25rem;margin-top:32px}
.legal p,.legal li{color:#cfd5f0}
.legal .todo{background:var(--gold-soft);border:1px dashed var(--gold);color:var(--gold);
  padding:2px 7px;border-radius:6px;font-size:.92em}

@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
