/* ============================================================
   DJ 24 — Shared design system (Dark Premium + Teal)
   ============================================================ */
:root{
  --bg:#0A0B0D;
  --bg-2:#0E1014;
  --surface:#121419;
  --surface-2:#171A20;
  --border:#23272F;
  --border-soft:#1B1E25;
  --teal:#40B5C2;
  --teal-bright:#5FD2DF;
  --teal-deep:#2A8C99;
  --grey:#6E727B;
  --text:#EDEFF2;
  --muted:#969CA6;
  --gold:#E7C66B;
  --grad:linear-gradient(118deg,#40B5C2 0%,#63D6E0 100%);
  --maxw:1240px;
  --pad:clamp(88px,11vw,150px);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html{overflow-x:hidden}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--teal);color:#04181b}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3{font-family:'Space Grotesk',sans-serif;font-weight:700;line-height:1.03;letter-spacing:-.025em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.teal{color:var(--teal)}
.eyebrow{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.2em;color:var(--teal);display:inline-flex;align-items:center;gap:11px;margin-bottom:22px}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--teal);border-radius:2px}

/* Grain + scroll progress (the "expensive" layer) */
.grain{position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.045;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.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--grad);z-index:9001;transition:width .1s linear}

/* Page intro */
.intro{position:fixed;inset:0;z-index:9500;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s}
.intro img{height:54px;opacity:0;transform:translateY(8px);animation:introLogo .7s .15s cubic-bezier(.2,.8,.2,1) forwards}
.intro.done{opacity:0;visibility:hidden}
html:not(.js) .intro{display:none}
@keyframes introLogo{to{opacity:1;transform:none}}

/* Custom cursor */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;mix-blend-mode:screen;opacity:0;transition:opacity .3s}
.cursor-dot{width:7px;height:7px;background:var(--teal-bright);margin:-3.5px 0 0 -3.5px}
.cursor-ring{width:38px;height:38px;border:1.5px solid rgba(95,210,223,.6);margin:-19px 0 0 -19px;transition:width .25s,height .25s,margin .25s,background .25s,opacity .3s}
.cursor-ring.hov{width:62px;height:62px;margin:-31px 0 0 -31px;background:rgba(64,181,194,.08)}
body.cursor-on{cursor:none}
body.cursor-on a,body.cursor-on button{cursor:none}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:16px;padding:15px 28px;border-radius:100px;cursor:pointer;border:1px solid transparent;transition:transform .2s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .25s,border-color .25s,color .25s;will-change:transform}
.btn-primary{background:var(--grad);color:#06191c;box-shadow:0 10px 36px -10px rgba(64,181,194,.55)}
.btn-primary:hover{box-shadow:0 16px 48px -8px rgba(64,181,194,.7)}
.btn-ghost{background:rgba(255,255,255,.02);border-color:var(--border);color:var(--text)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn svg{width:18px;height:18px;flex-shrink:0}

/* Header */
header{position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 0;transition:padding .3s,background .3s,border-color .3s,backdrop-filter .3s;border-bottom:1px solid transparent}
header.scrolled{padding:10px 0;background:rgba(10,11,13,.78);backdrop-filter:blur(16px);border-bottom:1px solid var(--border-soft)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:22px}
.nav-left{display:flex;align-items:center;gap:16px}
.nav .logo img{height:36px;width:auto;transition:height .3s;display:block}
header.scrolled .logo img{height:31px}
/* Header mini live-EQ */
.eq{display:flex;align-items:flex-end;gap:3px;height:22px}
.eq span{width:3px;background:var(--teal);border-radius:2px;height:30%;animation:eqbar 1s ease-in-out infinite}
.eq span:nth-child(1){animation-duration:.9s}
.eq span:nth-child(2){animation-duration:1.3s;animation-delay:.15s}
.eq span:nth-child(3){animation-duration:.7s;animation-delay:.05s}
.eq span:nth-child(4){animation-duration:1.1s;animation-delay:.25s}
@keyframes eqbar{0%,100%{height:25%}50%{height:100%}}
.nav-links{display:flex;gap:30px;font-size:15px;color:var(--muted);font-weight:500;align-items:center}
.nav-links>a,.nav-drop>button{position:relative;transition:color .2s;background:none;border:none;font:inherit;color:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.nav-links>a:hover,.nav-drop>button:hover,.nav-links>a.active{color:var(--text)}
.nav-links>a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--teal);transition:width .25s}
.nav-links>a:hover::after,.nav-links>a.active::after{width:100%}
/* Dropdown */
.nav-drop{position:relative}
.nav-drop>button .chev{font-size:10px;transition:transform .2s}
.nav-drop:hover>button .chev{transform:rotate(180deg)}
.drop-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);min-width:230px;background:rgba(14,16,20,.96);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:14px;padding:8px;opacity:0;visibility:hidden;transition:opacity .22s,transform .22s;box-shadow:0 24px 60px -20px rgba(0,0,0,.7)}
/* unsichtbare Hover-Brücke über die Lücke zwischen Button und Menü */
.drop-menu::before{content:"";position:absolute;left:0;right:0;top:-16px;height:16px}
.nav-drop:hover .drop-menu,.drop-menu:hover,.nav-drop:focus-within .drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(10px)}
.drop-menu a{display:block;padding:11px 14px;border-radius:9px;font-size:14.5px;color:var(--muted);transition:background .2s,color .2s}
.drop-menu a:hover{background:rgba(64,181,194,.1);color:var(--text)}
.drop-menu a b{display:block;color:var(--text);font-weight:600;font-size:14.5px;margin-bottom:1px}
.drop-menu a span{font-size:12px;color:var(--muted)}
.nav .btn{padding:11px 22px;font-size:15px}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:12px;margin:-12px -10px -12px 0;z-index:55}
.burger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:transform .3s,opacity .25s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile-Menü (Vollbild-Overlay) */
.mobile-menu{position:fixed;inset:0;z-index:48;background:rgba(10,11,13,.98);backdrop-filter:blur(14px);padding:96px 26px 48px;overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .3s ease,transform .38s cubic-bezier(.2,.8,.2,1),visibility .3s;display:none}
.mobile-menu.open{opacity:1;visibility:visible;transform:none}
.mobile-menu nav{display:flex;flex-direction:column}
.mm-label{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--teal);font-weight:600;margin:18px 0 6px}
.mm-label:first-child{margin-top:0}
.mobile-menu nav a{font-family:'Space Grotesk';font-weight:600;font-size:21px;padding:14px 2px;border-bottom:1px solid var(--border-soft);color:var(--text);display:flex;align-items:center;justify-content:space-between}
.mobile-menu nav a::after{content:"→";color:var(--muted);font-size:16px;opacity:.5}
.mobile-menu nav a:active{color:var(--teal)}
.mobile-menu .btn{margin-top:26px;justify-content:center;font-size:18px;padding:17px}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;padding:160px 0 70px;overflow:hidden}
.hero.compact{min-height:74vh;padding:170px 0 90px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:118%;object-fit:cover;object-position:center 35%;will-change:transform}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(10,11,13,.55) 0%,rgba(10,11,13,.35) 30%,rgba(10,11,13,.82) 78%,var(--bg) 100%),
  linear-gradient(95deg,rgba(10,11,13,.85) 0%,rgba(10,11,13,.30) 55%,rgba(10,11,13,.05) 100%)}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);z-index:1;pointer-events:none;opacity:.5}
.hero-orb.o1{width:460px;height:460px;background:rgba(64,181,194,.28);top:-120px;right:-60px;animation:drift 16s ease-in-out infinite}
.hero-orb.o2{width:380px;height:380px;background:rgba(42,140,153,.22);bottom:-140px;left:-100px;animation:drift 20s ease-in-out infinite reverse}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(28px,-26px)}}
#wavecanvas{position:absolute;left:0;right:0;bottom:0;z-index:2;width:100%;height:160px;pointer-events:none}
.hero-inner{position:relative;z-index:3;width:100%;max-width:940px}
.hero h1{font-size:clamp(46px,8.4vw,116px);line-height:.95;margin:16px 0 26px;letter-spacing:-.035em}
.hero.compact h1{font-size:clamp(40px,6.4vw,82px)}
.hero p.sub{font-size:clamp(17px,2.1vw,21px);color:#C9CDD4;max-width:620px;margin-bottom:36px}
.hero-cta{display:flex;gap:15px;flex-wrap:wrap;align-items:center}
.hero-micro{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:14px;margin-top:26px}
.dotlive{width:9px;height:9px;border-radius:50%;background:var(--teal-bright);box-shadow:0 0 0 0 rgba(95,210,223,.6);animation:pulse 2.2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 9px rgba(95,210,223,0)}100%{box-shadow:0 0 0 0 rgba(95,210,223,0)}}
.wave-hint{position:absolute;right:24px;bottom:30px;z-index:3;color:var(--muted);font-size:12px;letter-spacing:.08em;display:flex;align-items:center;gap:8px;opacity:.7}
.wave-hint .mvdot{width:6px;height:6px;border-radius:50%;background:var(--teal)}
/* breadcrumb (subpages) */
.crumb{font-size:13px;color:var(--muted);margin-bottom:18px;display:flex;gap:8px;align-items:center}
.crumb a:hover{color:var(--teal)}
.crumb .sep{opacity:.5}

/* Trust strip */
.trust{padding:34px 0;border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);background:var(--bg-2);position:relative;overflow:hidden}
.trust .lead{text-align:center;color:var(--muted);font-size:13.5px;letter-spacing:.04em;margin-bottom:22px}
.trust .lead b{color:var(--text);font-weight:600}
.marquee{display:flex;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.marquee+.marquee{margin-top:12px}
.mq-track{display:flex;gap:16px;padding-right:16px;flex-shrink:0;animation:scroll 50s linear infinite;align-items:center}
.mq-track.rev{animation-direction:reverse;animation-duration:62s}
.marquee:hover .mq-track{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-100%)}}
.logo-chip{height:80px;width:200px;flex-shrink:0;background:#fff;border-radius:13px;display:flex;align-items:center;justify-content:center;padding:14px 24px;filter:grayscale(.25);opacity:.82;transition:filter .3s,opacity .3s,transform .3s}
.logo-chip img{max-height:100%;max-width:100%;object-fit:contain}
.logo-chip:hover{filter:grayscale(0);opacity:1;transform:translateY(-3px)}

/* Larger static reference grid (recognisable) */
.reflogos{display:grid;grid-template-columns:repeat(auto-fill,minmax(184px,1fr));gap:14px}
.reflogo{background:#fff;border-radius:14px;height:104px;display:flex;align-items:center;justify-content:center;padding:20px 24px;filter:grayscale(.15);transition:transform .3s,box-shadow .3s,filter .3s}
.reflogo img{max-height:100%;max-width:100%;object-fit:contain}
.reflogo:hover{filter:grayscale(0);transform:translateY(-4px);box-shadow:0 18px 40px -18px rgba(0,0,0,.6)}
@media(max-width:680px){.reflogos{grid-template-columns:repeat(2,1fr)}.reflogo{height:88px;padding:16px}}

/* Sections */
section.block{padding:var(--pad) 0;position:relative}
.head-row{max-width:720px;margin-bottom:54px}
.head-row.center{margin:0 auto 54px;text-align:center}
.head-row.center .eyebrow{justify-content:center}
.head-row h2{font-size:clamp(33px,5vw,56px);margin-bottom:18px}
.head-row p{color:var(--muted);font-size:18px}

/* ---------- Use-case Bento hub ---------- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:240px;gap:18px}
.tile{position:relative;border-radius:18px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:26px;border:1px solid var(--border);isolation:isolate;transform-style:preserve-3d;transition:border-color .35s,transform .2s ease-out}
.tile .tbg{position:absolute;inset:0;z-index:-2;overflow:hidden}
.tile .tbg img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.8,.2,1);will-change:transform}
.tile::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,11,13,.12) 0%,rgba(10,11,13,.5) 52%,rgba(10,11,13,.93) 100%);transition:background .4s}
.tile:hover .tbg img{transform:scale(1.07)}
.tile:hover::after{background:linear-gradient(180deg,rgba(64,181,194,.12) 0%,rgba(10,11,13,.55) 55%,rgba(10,11,13,.95) 100%)}
.tile:hover{border-color:rgba(64,181,194,.5)}
.tile.big{grid-column:span 2;grid-row:span 2}
.tile.tall{grid-row:span 2}
.tile .tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-bright);margin-bottom:9px;font-weight:600}
.tile h3{font-size:23px;margin-bottom:8px}
.tile.big h3{font-size:34px}
.tile p{color:#C5C9D0;font-size:14.5px;max-width:46ch}
.tile .more{margin-top:14px;font-size:14px;font-weight:600;color:var(--teal-bright);display:inline-flex;align-items:center;gap:7px;opacity:0;transform:translateX(-6px);transition:opacity .35s,transform .35s}
.tile:hover .more{opacity:1;transform:none}
.tile-ic{position:absolute;top:22px;left:22px;z-index:1;width:48px;height:48px;border-radius:14px;background:rgba(8,9,11,.42);backdrop-filter:blur(9px);border:1px solid rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;color:#fff;transition:background .4s,color .4s,border-color .4s,transform .4s;box-shadow:0 6px 22px -10px rgba(0,0,0,.6)}
.tile-ic svg{width:24px;height:24px}
.tile:hover .tile-ic{background:var(--grad);color:#06191c;border-color:transparent;transform:translateY(-3px) scale(1.05)}

/* Why / stats */
.why{background:radial-gradient(120% 100% at 50% 0%,rgba(64,181,194,.05),transparent 60%);overflow:hidden}
.why-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center;position:relative;z-index:2}
.why-grid .copy h2{font-size:clamp(30px,4.2vw,50px);margin-bottom:20px}
.why-grid .copy p{color:var(--muted);font-size:17px;margin-bottom:16px}
.why-watermark{position:absolute;right:-2%;top:50%;transform:translateY(-50%);font-family:'Space Grotesk';font-weight:700;font-size:clamp(220px,34vw,520px);line-height:1;color:rgba(64,181,194,.045);z-index:1;pointer-events:none;user-select:none}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:28px 26px 26px;position:relative;overflow:hidden;transition:border-color .35s,transform .35s,box-shadow .35s}
.stat:hover{border-color:rgba(64,181,194,.45);transform:translateY(-4px);box-shadow:0 26px 54px -30px rgba(64,181,194,.5)}
.stat::after{content:"";position:absolute;left:0;bottom:0;height:3px;width:0;background:var(--grad);transition:width 1.1s cubic-bezier(.2,.8,.2,1)}
.stat.in::after{width:100%}
.stat-ic{width:46px;height:46px;border-radius:13px;background:rgba(64,181,194,.1);color:var(--teal-bright);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:background .35s,color .35s,transform .35s}
.stat-ic svg{width:24px;height:24px}
.stat:hover .stat-ic{background:var(--grad);color:#06191c;transform:scale(1.06) rotate(-3deg)}
.stat .num{font-family:'Space Grotesk';font-weight:700;font-size:clamp(38px,4.5vw,52px);line-height:1;margin-bottom:8px}
.stat .lbl{color:var(--muted);font-size:14.5px}

/* Ablauf — edle Roadmap */
.roadmap{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:8px}
.rm-track{position:absolute;top:36px;left:16.66%;right:16.66%;height:2px;background:var(--border);border-radius:2px;z-index:0;overflow:hidden}
.rm-track::after{content:"";position:absolute;inset:0;width:0;background:var(--grad);box-shadow:0 0 16px rgba(64,181,194,.6);transition:width 1.7s cubic-bezier(.3,.7,.3,1)}
.roadmap.draw .rm-track::after{width:100%}
.rm-step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 6px}
.rm-node{position:relative;width:72px;height:72px;border-radius:50%;background:var(--bg-2);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:border-color .5s,color .5s,box-shadow .5s}
.rm-node svg{width:30px;height:30px}
.rm-node::before{content:"";position:absolute;inset:-7px;border-radius:50%;border:1px solid rgba(64,181,194,0)}
.rm-num{position:absolute;top:-3px;right:-3px;width:26px;height:26px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border);font-family:'Space Grotesk';font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:color .5s,background .5s,border-color .5s}
.roadmap.draw .rm-node{border-color:var(--teal);color:var(--teal-bright);box-shadow:0 0 0 6px rgba(64,181,194,.07),0 14px 38px -10px rgba(64,181,194,.5)}
.roadmap.draw .rm-node::before{border-color:rgba(64,181,194,.18);animation:rmpulse 2.6s ease-out infinite}
.roadmap.draw .rm-num{color:#06191c;background:var(--grad);border-color:transparent}
.roadmap.draw .rm-step:nth-child(2) .rm-node,.roadmap.draw .rm-step:nth-child(2) .rm-num{transition-delay:.1s}
.roadmap.draw .rm-step:nth-child(3) .rm-node,.roadmap.draw .rm-step:nth-child(3) .rm-num{transition-delay:.6s}
.roadmap.draw .rm-step:nth-child(4) .rm-node,.roadmap.draw .rm-step:nth-child(4) .rm-num{transition-delay:1.1s}
@keyframes rmpulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.4);opacity:0}}
.rm-step h3{font-size:21px;margin:22px 0 9px}
.rm-step p{color:var(--muted);font-size:15px;max-width:34ch}
@media(max-width:680px){
  .roadmap{grid-template-columns:1fr;gap:14px}
  .rm-track{display:none}
  .rm-step{flex-direction:row;text-align:left;gap:18px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px}
  .rm-node{flex-shrink:0;width:58px;height:58px}
  .rm-step h3{margin:0 0 6px}
}

/* Steps with self-drawing line */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;position:relative}
.steps-line{position:absolute;top:56px;left:8%;right:8%;height:2px;z-index:0}
.steps-line path{stroke:var(--teal);stroke-width:2;fill:none;stroke-dasharray:1;stroke-dashoffset:1;opacity:.55}
.steps-line.draw path{animation:draw 1.6s ease forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.step{position:relative;z-index:1;padding:34px 28px;border-radius:16px;background:var(--surface);border:1px solid var(--border);transition:border-color .3s,transform .3s}
.step:hover{border-color:rgba(64,181,194,.45);transform:translateY(-4px)}
.step .n{font-family:'Space Grotesk';font-weight:700;font-size:16px;width:46px;height:46px;border-radius:50%;border:1.5px solid var(--teal);color:var(--teal);display:flex;align-items:center;justify-content:center;margin-bottom:22px;background:var(--bg);position:relative}
.step .n::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1px solid rgba(64,181,194,.25);animation:ring 2.6s ease-out infinite}
@keyframes ring{0%{transform:scale(.85);opacity:.7}100%{transform:scale(1.4);opacity:0}}
.step h3{font-size:21px;margin-bottom:10px}
.step p{color:var(--muted);font-size:15.5px}

/* DJ team cards */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.dj{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:30px 28px;transition:border-color .3s,transform .3s}
.dj:hover{border-color:rgba(64,181,194,.45);transform:translateY(-4px)}
.dj .avatar{width:58px;height:58px;border-radius:14px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk';font-weight:700;font-size:22px;color:#06191c;margin-bottom:18px}
.dj h3{font-size:20px;margin-bottom:4px}
.dj .role{font-size:13px;color:var(--teal-bright);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;font-weight:600}
.dj p{color:var(--muted);font-size:14.5px}

/* Team profile cards (image-free, premium) */
.team-pro{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tp{background:var(--surface);border:1px solid var(--border);border-radius:20px;overflow:hidden;transition:border-color .35s,transform .35s,box-shadow .35s}
.tp:hover{border-color:rgba(64,181,194,.5);transform:translateY(-5px);box-shadow:0 30px 60px -34px rgba(64,181,194,.5)}
.tp-head{position:relative;height:160px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:radial-gradient(120% 120% at 30% 20%,rgba(64,181,194,.22),rgba(42,140,153,.05) 60%,transparent),var(--surface-2);border-bottom:1px solid var(--border)}
.tp-mono{font-family:'Space Grotesk';font-weight:700;font-size:62px;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;position:relative;z-index:1}
.tp-head .wm{position:absolute;right:-14px;bottom:-22px;color:rgba(255,255,255,.05);transition:transform .5s}
.tp-head .wm svg{width:130px;height:130px}
.tp:hover .tp-head .wm{transform:rotate(-8deg) scale(1.05)}
.tp-body{padding:24px 26px 28px}
.tp-body h3{font-size:22px;margin-bottom:3px}
.tp-role{color:var(--teal-bright);font-size:12.5px;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:15px}
.tp-body p{color:var(--muted);font-size:14.5px;line-height:1.6;margin-bottom:16px}
.tp-tags{display:flex;flex-wrap:wrap;gap:7px}
.tp-tag{font-size:12px;color:#cfd3da;background:rgba(64,181,194,.09);border:1px solid rgba(64,181,194,.22);border-radius:100px;padding:5px 11px}

/* Value cards */
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.value{display:flex;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 26px;transition:border-color .3s,transform .3s}
.value:hover{border-color:rgba(64,181,194,.45);transform:translateY(-3px)}
.value .vic{width:46px;height:46px;border-radius:12px;background:rgba(64,181,194,.1);color:var(--teal-bright);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s,color .3s}
.value:hover .vic{background:var(--grad);color:#06191c}
.value .vic svg{width:23px;height:23px}
.value h3{font-size:18px;margin-bottom:6px}
.value p{color:var(--muted);font-size:14.5px;line-height:1.55}

/* Pull stat (story) */
.pullstat{border-left:2px solid var(--teal);padding-left:24px;margin:6px 0}
.pullstat .pn{font-family:'Space Grotesk';font-weight:700;font-size:clamp(44px,6vw,68px);line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.pullstat .pl{color:var(--muted);font-size:15px;margin-top:6px}
@media(max-width:920px){.team-pro{grid-template-columns:1fr 1fr}.values{grid-template-columns:1fr}}
@media(max-width:680px){.team-pro{grid-template-columns:1fr}}

/* Testimonials */
.feature-quote{background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:clamp(34px,5vw,60px);position:relative;overflow:hidden;margin-bottom:20px}
.feature-quote::before{content:"\201C";position:absolute;top:-30px;left:24px;font-family:'Space Grotesk';font-size:240px;color:rgba(64,181,194,.07);line-height:1}
.feature-quote .stars{color:var(--gold);font-size:18px;letter-spacing:4px;margin-bottom:18px}
.feature-quote blockquote{font-family:'Space Grotesk';font-weight:500;font-size:clamp(22px,3vw,34px);line-height:1.3;letter-spacing:-.02em;max-width:900px;position:relative}
.feature-quote .who{margin-top:26px;display:flex;align-items:center}
.feature-quote .who .nm{border-left:2px solid var(--teal);padding-left:14px;display:flex;flex-direction:column}
.feature-quote .who b{font-weight:600;font-size:16px}.feature-quote .who span{color:var(--muted);font-size:13px}
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.quote{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:30px 28px;display:flex;flex-direction:column;gap:15px}
.quote .stars{color:var(--gold);font-size:15px;letter-spacing:3px}
.quote p{font-size:16.5px;line-height:1.55}
.quote .who{display:flex;align-items:center;margin-top:auto;padding-top:15px;border-top:1px solid var(--border-soft)}
.quote .who .nm{border-left:2px solid var(--teal);padding-left:11px;display:flex;flex-direction:column}
.quote .who b{font-weight:600}.quote .who span{color:var(--muted);font-size:13px;font-weight:400}
.rating-head{display:flex;align-items:center;gap:14px;justify-content:center;margin-bottom:40px;color:var(--muted);font-size:15px}
.rating-head .big{font-family:'Space Grotesk';font-weight:700;font-size:22px;color:var(--text)}
.rating-head .stars{color:var(--gold);letter-spacing:3px}
/* Review wall: aggregate badges + slider */
.rating-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;margin-bottom:44px}
.rbadge{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:15px 22px;transition:border-color .3s,transform .3s}
.rbadge:hover{border-color:rgba(64,181,194,.45);transform:translateY(-3px)}
.rbadge .ri{width:44px;height:44px;border-radius:12px;background:rgba(64,181,194,.1);color:var(--teal-bright);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rbadge .ri svg{width:24px;height:24px}
.rbadge b{display:block;font-family:'Space Grotesk';font-weight:700;font-size:17px;line-height:1.1}
.rbadge .sub{color:var(--muted);font-size:12.5px;margin-top:3px}
.rbadge .rstars{color:var(--gold);font-size:14px;letter-spacing:2px}
.review-rail-wrap{margin-top:48px;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.review-rail{display:flex}
.rr-track{display:flex;gap:18px;padding-right:18px;flex-shrink:0;animation:scroll 64s linear infinite}
.review-rail:hover .rr-track{animation-play-state:paused}
.rcard{width:366px;flex-shrink:0;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:26px;display:flex;flex-direction:column;gap:14px;white-space:normal;transition:border-color .3s,transform .3s}
.rcard:hover{border-color:rgba(64,181,194,.45);transform:translateY(-4px)}
.rcard .stars{color:var(--gold);font-size:14px;letter-spacing:3px}
.rcard p{font-size:15.5px;line-height:1.55;color:var(--text)}
.rcard .who{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:16px;border-top:1px solid var(--border-soft)}
.rcard .who .nm{border-left:2px solid var(--teal);padding-left:11px;display:flex;flex-direction:column}
.rcard .who b{font-weight:600;font-size:14.5px}
.rcard .who span{color:var(--muted);font-size:12.5px}
.rcard .src{margin-left:auto;color:var(--muted);font-size:11px;display:inline-flex;align-items:center;gap:5px;align-self:flex-start}
.rcard .src svg{width:15px;height:15px;color:var(--teal)}
@media(max-width:680px){.rcard{width:290px}}

/* CTA */
.cta-box{position:relative;border-radius:26px;border:1px solid var(--border);overflow:hidden;isolation:isolate}
.cta-box .cbg{position:absolute;inset:0;z-index:-2}
.cta-box .cbg img{width:100%;height:100%;object-fit:cover}
.cta-box::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(110deg,rgba(8,9,11,.95) 0%,rgba(8,9,11,.82) 45%,rgba(42,140,153,.45) 100%)}
.cta-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:start;padding:clamp(38px,5.5vw,66px)}
.cta-box h2{font-size:clamp(30px,4.3vw,48px);margin-bottom:18px}
.cta-box .lede{color:#C9CDD4;font-size:18px;margin-bottom:28px}
.contact-line{display:flex;align-items:center;gap:13px;margin-bottom:15px;font-size:16.5px}
.contact-line .ic{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.05);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.contact-line a:hover{color:var(--teal)}
form{display:flex;flex-direction:column;gap:13px;background:rgba(10,11,13,.55);backdrop-filter:blur(6px);padding:30px;border-radius:18px;border:1px solid var(--border)}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12.5px;color:var(--muted);font-weight:500}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
input,select,textarea{background:var(--bg);border:1px solid var(--border);border-radius:11px;padding:12px 14px;color:var(--text);font-family:inherit;font-size:15px;transition:border-color .2s,box-shadow .2s;width:100%}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(64,181,194,.16)}
textarea{resize:vertical;min-height:80px}
form .btn-primary{justify-content:center;margin-top:4px}
.form-micro{font-size:12.5px;color:var(--muted);text-align:center}

/* Rich text (subpage prose) */
.prose{max-width:780px}
.prose p{color:#C5C9D0;font-size:17.5px;margin-bottom:20px}
.prose p.lead{font-size:20px;color:var(--text)}
.benefits{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
.benefit{display:flex;gap:12px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:18px 20px}
.benefit .chk{width:24px;height:24px;border-radius:50%;background:rgba(64,181,194,.14);color:var(--teal-bright);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.benefit .chk svg{width:13px;height:13px}
.benefit span{font-size:15.5px}

/* Cross-links */
.crosslinks{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.crosslink{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;transition:border-color .3s,transform .3s;display:flex;flex-direction:column;gap:6px}
.crosslink:hover{border-color:rgba(64,181,194,.5);transform:translateY(-3px)}
.crosslink b{font-size:16px;font-family:'Space Grotesk'}
.crosslink span{color:var(--muted);font-size:13px}
.crosslink .arw{color:var(--teal-bright);font-size:14px;margin-top:6px}

/* Footer */
footer{border-top:1px solid var(--border-soft);padding:58px 0 38px;background:var(--bg-2)}
.foot-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start}
.foot-grid .logo img{height:40px;margin-bottom:16px}
.foot-claim{max-width:300px;color:var(--muted);font-size:15px}
.foot-links{display:flex;gap:46px;flex-wrap:wrap}
.foot-col h4{font-size:12.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:15px;font-family:'Inter';font-weight:600}
.foot-col a,.foot-col span{display:block;color:var(--muted);font-size:14.5px;margin-bottom:9px;transition:color .2s}
.foot-col a:hover{color:var(--teal)}
.foot-bottom{margin-top:46px;padding-top:22px;border-top:1px solid var(--border-soft);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:#5a5f68;font-size:13px}

/* Price cards */
.price-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.price-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:30px 28px;position:relative;overflow:hidden;transition:border-color .3s,transform .3s,box-shadow .3s}
.price-card:hover{transform:translateY(-4px);border-color:rgba(64,181,194,.45);box-shadow:0 26px 54px -30px rgba(64,181,194,.5)}
.price-card.feat{border-color:rgba(64,181,194,.55);background:linear-gradient(180deg,rgba(64,181,194,.07),transparent)}
.price-card .pc-label{font-size:12.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--teal-bright);font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.price-card .pc-label svg{width:15px;height:15px;flex-shrink:0}
.price-card .pc-amount{font-family:'Space Grotesk';font-weight:700;font-size:clamp(28px,3.6vw,40px);line-height:1;margin-bottom:10px}
.price-card .pc-amount small{font-size:15px;color:var(--muted);font-weight:500}
.price-card .pc-desc{color:var(--muted);font-size:14.5px}
.price-note{color:var(--muted);font-size:14px;margin-top:20px;text-align:center}

/* FAQ accordion */
.faq{max-width:880px;margin:0 auto}
.faq-item{border:1px solid var(--border);border-radius:14px;background:var(--surface);margin-bottom:12px;overflow:hidden;transition:border-color .3s,background .3s}
.faq-item.open{border-color:rgba(64,181,194,.5)}
.faq-q{width:100%;text-align:left;background:none;border:none;color:var(--text);font-family:'Space Grotesk';font-weight:600;font-size:clamp(16px,2vw,18px);padding:21px 24px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px}
.faq-q .fic{width:30px;height:30px;border-radius:9px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.35s;color:var(--teal-bright)}
.faq-q .fic svg{width:16px;height:16px}
.faq-item.open .fic{background:var(--grad);color:#06191c;border-color:transparent;transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-inner{padding:0 24px 22px;color:var(--muted);font-size:15.5px;line-height:1.62}
.faq-inner ul{margin:14px 0 0;padding:0;list-style:none;display:grid;gap:9px}
.faq-inner li{display:flex;gap:11px;align-items:flex-start}
.faq-inner li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal);margin-top:8px;flex-shrink:0}

/* Legal prose */
.legal{max-width:820px}
.legal h2{font-size:24px;margin:38px 0 12px}
.legal h3{font-size:17px;margin:24px 0 8px;color:var(--text)}
.legal p{color:#C5C9D0;font-size:16px;margin-bottom:14px}
.legal a{color:var(--teal)}.legal a:hover{text-decoration:underline}
.legal ul{margin:0 0 14px;padding-left:20px;color:#C5C9D0}
.legal li{margin-bottom:6px}
.legal .addr{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px 24px;margin:6px 0 10px;color:var(--text)}
.legal .note{background:rgba(231,198,107,.08);border:1px solid rgba(231,198,107,.3);border-radius:12px;padding:15px 18px;color:var(--gold);font-size:13.5px;margin-bottom:26px}
@media(max-width:680px){.price-cards{grid-template-columns:1fr}}

/* Reveal — nur mit aktivem JS versteckt, damit ohne JS alles sichtbar bleibt */
.reveal{transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1)}
.js .reveal{opacity:0;transform:translateY(26px)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}.d4{transition-delay:.28s}.d5{transition-delay:.35s}

/* Responsive */
@media(max-width:920px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .tile.big{grid-column:span 2;grid-row:span 1}
  .why-grid,.cta-grid{grid-template-columns:1fr;gap:40px}
  .team,.crosslinks{grid-template-columns:1fr 1fr}
  .benefits{grid-template-columns:1fr}
}
@media(max-width:680px){
  :root{--pad:clamp(58px,13vw,82px)}
  .nav-links,.nav>.btn,.eq{display:none}
  .burger{display:flex}
  .mobile-menu{display:block}
  .wrap{padding:0 20px}
  .head-row{margin-bottom:40px}
  .bento{grid-template-columns:1fr;grid-auto-rows:220px}
  .tile.big{grid-column:span 1}
  .steps,.quotes,.stats,.team,.crosslinks{grid-template-columns:1fr}
  .steps-line{display:none}
  .row2{grid-template-columns:1fr}
  .hero{min-height:88vh;padding:124px 0 56px}
  .why-watermark{display:none}
  /* kompaktere Logos */
  .logo-chip{height:60px;width:144px;padding:10px 16px}
  .reflogos{grid-template-columns:repeat(2,1fr);gap:10px}
  .reflogo{height:68px;padding:12px 15px}
  /* Bewertungs-Badges gestapelt */
  .rating-badges{gap:12px}
  .rbadge{flex:1 1 100%;justify-content:flex-start}
  /* Footer aufgeräumt */
  .foot-grid{flex-direction:column;gap:30px}
  .foot-links{gap:24px 36px}
  .foot-bottom{flex-direction:column;gap:8px;align-items:flex-start}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
  .cursor-dot,.cursor-ring,.grain{display:none!important}
  body.cursor-on{cursor:auto}
  .intro{display:none}
}
