/* =========================================================
   Nexcent — Design System
   Light, airy, Sora display + Inter body, rounded cards.
   Accent: refined petrol. Edit tokens here once, applies everywhere.
   ========================================================= */
:root{
  --page:#FFFFFF;
  --paper:#F4F3EF;
  --ink:#0E1116;
  --ink-soft:#3A4049;
  --muted:#6B7480;
  --line:#E7E4DC;
  --card:#0A0C16;            /* dark feature/image cards */
  --on-card:#EAF0F2;
  --on-card-muted:#9DB0BC;
  --accent:#0F6E72;
  --accent-bright:#159A9F;
  --radius:34px;
  --radius-md:20px;
  --radius-sm:12px;
  --maxw:1280px;
  --gap:18px;
  --head:"Sora",system-ui,sans-serif;
  --body:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--page)}
body{font-family:var(--body);color:var(--ink);background:transparent;line-height:1.6;-webkit-font-smoothing:antialiased}
/* ambient dot-field sits BEHIND content; content layers above it */
#dotfield{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
main{position:relative;z-index:1}
.site-footer{position:relative;z-index:1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--ink);color:#fff}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}

h1,h2,h3,h4{font-family:var(--head);font-weight:600;line-height:1.08;letter-spacing:-.02em;color:var(--ink)}
.eyebrow{font-family:var(--head);font-size:.8rem;font-weight:600;letter-spacing:.02em;color:var(--accent);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent)}
.section-title{font-size:clamp(1.9rem,3.6vw,3rem)}
.lead{font-size:1.1rem;color:var(--muted);max-width:56ch}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:11px;font-family:var(--head);font-weight:500;font-size:.92rem;
  border:1px solid var(--ink);border-radius:40px;padding:14px 28px;cursor:pointer;position:relative;overflow:hidden;isolation:isolate;transition:color .4s}
.btn .fill{position:absolute;inset:0;z-index:-1;background:var(--ink);transform:translateX(-101%);transition:transform .5s cubic-bezier(.7,0,.2,1)}
.btn:hover{color:#fff}
.btn:hover .fill{transform:translateX(0)}
.btn svg{width:18px;height:14px;stroke:currentColor;fill:none;stroke-width:1.8;transition:transform .4s}
.btn:hover svg{transform:translateX(4px)}
.btn.on-dark{border-color:rgba(255,255,255,.5);color:#fff}
.btn.on-dark .fill{background:#fff}
.btn.on-dark:hover{color:var(--ink)}
.btn.solid{background:var(--ink);color:#fff}
.btn.solid .fill{background:var(--accent)}
.btn.solid:hover{color:#fff}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:40px;height:40px;display:grid;place-items:center;background:var(--ink);color:#fff;font-family:var(--head);font-weight:700;border-radius:11px;font-size:1rem}
.brand .name{font-family:var(--head);font-weight:600;font-size:1.35rem}
.brand-logo{height:40px;width:auto;display:block}
.foot-logo{height:36px}
@media(max-width:560px){.brand-logo{height:32px}}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-family:var(--head);font-size:.92rem;font-weight:500;color:var(--ink-soft);transition:color .2s}
.nav a:hover{color:var(--ink)}
.nav .btn{padding:11px 22px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}
@media(max-width:860px){
  .nav{position:fixed;inset:0 0 0 auto;width:80%;max-width:320px;height:100vh;background:var(--page);flex-direction:column;align-items:flex-start;padding:100px 30px;gap:8px;transform:translateX(100%);transition:transform .35s;border-left:1px solid var(--line)}
  .nav.open{transform:none}
  .nav a{font-size:1.05rem;padding:12px 0;width:100%;border-bottom:1px solid var(--line)}
  .nav .btn{margin-top:14px;width:100%;justify-content:center}
  .burger{display:flex;z-index:101}
}

/* =========================================================
   HERO (rounded image card + carved controls)
   ========================================================= */
.hero{padding:var(--gap)}
.hero-card{position:relative;border-radius:var(--radius);overflow:hidden;min-height:min(82vh,640px);background:var(--card);isolation:isolate}
.hero-card .ribbons{position:absolute;inset:0;z-index:0;width:100%;height:100%}
.hero-card::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 120% at 12% 55%,rgba(10,12,22,.55),transparent 55%),linear-gradient(180deg,rgba(8,10,18,.25),transparent 35%)}
.hero-slides{position:relative;z-index:2;display:flex;align-items:center;min-height:inherit;padding:clamp(30px,6vw,90px);padding-right:34%}
.hero-slide{position:absolute;left:clamp(30px,6vw,90px);right:34%;opacity:0;visibility:hidden;transform:translateY(20px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.3,1),visibility .9s}
.hero-slide.active{position:relative;opacity:1;visibility:visible;transform:none}
.hero-slide h1{color:#fff;font-size:clamp(2.3rem,5vw,4.3rem);line-height:1.04;letter-spacing:-.025em;max-width:16ch}
.hero-slide .txt{margin-top:22px;max-width:46ch;color:rgba(255,255,255,.88);font-size:clamp(1rem,1.4vw,1.16rem)}
.hero-slide .actions{margin-top:32px}
.nav-tab{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:56px;height:96px;background:var(--page);display:grid;place-items:center;cursor:pointer;border:0}
.nav-tab svg{width:20px;height:20px;stroke:var(--ink);fill:none;stroke-width:1.8;transition:transform .3s}
.nav-tab.prev{left:0;border-radius:0 22px 22px 0}
.nav-tab.next{right:0;border-radius:22px 0 0 22px}
.nav-tab.prev:hover svg{transform:translateX(-3px)}
.nav-tab.next:hover svg{transform:translateX(3px)}
.nav-tab::before,.nav-tab::after{content:"";position:absolute;width:22px;height:22px;background:var(--page)}
.nav-tab.prev::before{bottom:100%;left:0;-webkit-mask:radial-gradient(circle at 0 0,transparent 22px,#000 22.5px);mask:radial-gradient(circle at 0 0,transparent 22px,#000 22.5px)}
.nav-tab.prev::after{top:100%;left:0;-webkit-mask:radial-gradient(circle at 0 100%,transparent 22px,#000 22.5px);mask:radial-gradient(circle at 0 100%,transparent 22px,#000 22.5px)}
.nav-tab.next::before{bottom:100%;right:0;-webkit-mask:radial-gradient(circle at 100% 0,transparent 22px,#000 22.5px);mask:radial-gradient(circle at 100% 0,transparent 22px,#000 22.5px)}
.nav-tab.next::after{top:100%;right:0;-webkit-mask:radial-gradient(circle at 100% 100%,transparent 22px,#000 22.5px);mask:radial-gradient(circle at 100% 100%,transparent 22px,#000 22.5px)}
.watch{position:absolute;right:0;bottom:0;z-index:6;background:var(--page);border-radius:28px 0 var(--radius) 0;padding:24px 34px 24px 40px;display:flex;align-items:center;gap:16px;cursor:pointer;border:0}
.watch .play{width:48px;height:48px;border-radius:50%;border:1px solid var(--ink);display:grid;place-items:center;flex:none;position:relative;transition:.35s}
.watch .play::after{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid var(--ink);opacity:.4;animation:ring 2.6s ease-out infinite}
@keyframes ring{0%{transform:scale(1);opacity:.4}100%{transform:scale(1.5);opacity:0}}
.watch .play i{width:0;height:0;border-left:11px solid var(--ink);border-top:7px solid transparent;border-bottom:7px solid transparent;margin-left:3px;transition:.35s}
.watch .lbl{font-family:var(--head);font-weight:500;font-size:.95rem}
.watch:hover .play{background:var(--ink)}
.watch:hover .play i{border-left-color:#fff}
@media(max-width:820px){.hero-slides{padding:clamp(26px,7vw,40px);padding-right:16%}.hero-slide{right:12%}.watch .lbl{display:none}.watch{padding:18px 22px}.nav-tab{width:46px;height:78px}}

/* =========================================================
   SECTION SHELL
   ========================================================= */
.section{padding:clamp(72px,9vw,120px) 0;position:relative}
.section .head{max-width:60ch}
.section .head.center{margin:0 auto;text-align:center}
.section .head.center .eyebrow{justify-content:center}
.section .head .lead{margin-top:16px}
.section.paper{background:var(--paper)}

/* =========================================================
   SERVICES
   ========================================================= */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:52px}
.svc{position:relative;background:var(--page);border:1px solid var(--line);border-radius:var(--radius-md);padding:34px 30px;min-height:260px;display:flex;flex-direction:column;transition:.35s}
.section.paper .svc{background:#fff}
.svc:hover{transform:translateY(-5px);border-color:var(--ink);box-shadow:0 30px 60px -34px rgba(0,0,0,.35)}
.svc .ico{width:50px;height:50px;border-radius:13px;background:var(--paper);display:grid;place-items:center;color:var(--accent);margin-bottom:22px}
.svc .ico svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:1.5}
.svc .tag{font-family:var(--head);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.svc h3{font-size:1.4rem;margin-bottom:10px}
.svc p{color:var(--muted);font-size:.95rem}
.svc .more{margin-top:auto;padding-top:18px;font-family:var(--head);font-weight:500;font-size:.85rem;color:var(--ink);display:inline-flex;gap:.5em;align-items:center;transition:gap .3s}
.svc:hover .more{gap:.9em;color:var(--accent)}

/* =========================================================
   FEATURE CARDS (3 Neuros-Karten, full-bleed unter dem Hero)
   ========================================================= */
.fcards{padding:0 var(--gap) var(--gap);display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--gap)}
.fcard{position:relative;overflow:hidden;border-radius:var(--radius);min-height:clamp(300px,33vw,360px);
  padding:clamp(28px,3vw,40px);display:flex;flex-direction:column;isolation:isolate;transition:transform .4s cubic-bezier(.2,.7,.3,1),box-shadow .4s}
.fcard:hover{transform:translateY(-6px);box-shadow:0 40px 70px -40px rgba(0,0,0,.45)}
.fcard .fc-body{position:relative;z-index:2;max-width:90%}
.fc-title{color:inherit;font-family:var(--head);font-weight:600;line-height:1.08;letter-spacing:-.02em;font-size:clamp(1.4rem,2vw,1.7rem)}
.fc-title.big{font-size:clamp(2rem,3.4vw,3rem)}
.fc-text{margin-top:16px;font-size:.95rem;line-height:1.6;max-width:34ch}

/* round dual-arrow button (slide-horizontal) */
.fbtn{position:absolute;right:24px;bottom:24px;z-index:3;width:56px;height:56px;border-radius:50%;
  background:var(--ink);color:#fff;overflow:hidden;display:block;transition:background .35s}
.fbtn .ar{display:flex;transition:transform .45s cubic-bezier(.7,0,.2,1)}
.fbtn .ar i{flex:none;width:56px;height:56px;display:grid;place-items:center}
.fbtn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8}
.fbtn:hover .ar{transform:translateX(-56px)}
.fbtn:hover{background:var(--accent)}

/* Karte 1 — Foto (Platzhalter-Verlauf; per background-image ersetzbar) */
.fcard.img{color:#fff;background-size:cover;background-position:center;
  background-image:linear-gradient(125deg,#15100c,#3a1c0e 28%,#c4571b 52%,#7c3b2c 66%,#1c2a46 100%)}
.fcard.img::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(8,8,14,.15),rgba(8,8,14,.62))}
.fcard.img .fc-text{color:rgba(255,255,255,.85)}

/* Karte 2 — dunkel mit rotierenden Topografie-Konturen */
.fcard.dark{background:var(--card);color:#fff}
.fcard.dark .topo{position:absolute;right:-8%;bottom:-14%;width:78%;height:auto;z-index:1;opacity:.6}
.fcard.dark .topo ellipse{fill:none;stroke:rgba(21,154,159,.55);stroke-width:1}
.fcard.dark .spin{transform-origin:200px 200px;animation:topo-spin 60s linear infinite}
@keyframes topo-spin{to{transform:rotate(360deg)}}

/* Karte 3 — hell, Zähler 250+ mit Korallverlauf + blaue Ringe */
.fcard.light{background:var(--paper);color:var(--ink)}
.fcard.light .rings{position:absolute;right:0;top:0;width:62%;height:auto;z-index:1}
.fcard.light .rings circle{fill:none;stroke:rgba(21,154,159,.32);stroke-width:1}
.fc-counter{margin-top:auto}
.fc-counter .num{display:block;font-family:var(--head);font-weight:700;line-height:1;font-size:clamp(3rem,6vw,5rem);
  background:linear-gradient(180deg,#159A9F,#0F6E72);-webkit-background-clip:text;background-clip:text;color:transparent}
.fc-counter .cap{display:block;margin-top:8px;font-family:var(--head);font-weight:600;font-size:.95rem;color:var(--ink-soft)}

/* gestaffeltes Reveal */
.fcards .fcard.reveal:nth-child(2){transition-delay:.12s}
.fcards .fcard.reveal:nth-child(3){transition-delay:.24s}

@media(max-width:980px){
  .fcards{grid-template-columns:1fr 1fr}
  .fcard.light{grid-column:1 / -1}
}
@media(max-width:620px){
  .fcards{grid-template-columns:1fr}
  .fcard.light{grid-column:auto}
}

/* =========================================================
   SERVICES MOSAIC (Leistungen als Bild-Kachel-Kollage)
   ========================================================= */
/* full-bleed */
.svcm .wrap{max-width:none;padding:0 var(--gap)}
.svcm .head{max-width:none}
.svcm-grid{column-count:3;column-gap:var(--gap);margin-top:50px}
.svcm-tile{position:relative;display:block;break-inside:avoid;margin-bottom:var(--gap);border-radius:var(--radius);
  overflow:hidden;color:#fff;isolation:isolate;transition:transform .45s cubic-bezier(.2,.7,.3,1),box-shadow .45s}
.svcm-tile:hover{transform:translateY(-6px);box-shadow:0 44px 80px -44px rgba(0,0,0,.55)}
.svcm-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.82);transition:transform .8s ease}
.svcm-tile:hover img{transform:scale(1.07)}
.svcm-tile::after{content:"";position:absolute;inset:0;transition:opacity .45s;
  background:linear-gradient(180deg,rgba(10,12,22,.05) 0%,rgba(11,60,62,.45) 52%,rgba(7,44,46,.95) 100%)}
.svcm-tile:hover::after{background:linear-gradient(180deg,rgba(9,40,42,.35) 0%,rgba(9,52,54,.7) 45%,rgba(6,40,42,.97) 100%)}
.svcm-tile::before{content:"";position:absolute;inset:0;z-index:3;border-radius:inherit;pointer-events:none;
  border:1px solid transparent;transition:border-color .4s}
.svcm-tile:hover::before{border-color:rgba(143,214,217,.5)}
.svcm-body{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(24px,2.4vw,34px)}
.svcm-tag{display:inline-flex;align-items:center;gap:.6em;font-family:var(--head);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:#8fd6d9;margin-bottom:10px}
.svcm-tag::before{content:"";width:22px;height:1px;background:currentColor}
.svcm-tile h3{color:#fff;font-size:clamp(1.3rem,1.7vw,1.7rem);line-height:1.15;letter-spacing:-.01em}
.svcm-desc{margin-top:12px;font-size:.95rem;line-height:1.6;color:rgba(255,255,255,.9);max-width:42ch;opacity:0;max-height:0;overflow:hidden;transition:opacity .45s ease,max-height .5s ease}
.svcm-tile:hover .svcm-desc{opacity:1;max-height:160px}
.svcm-go{position:absolute;right:24px;top:24px;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.45);
  display:grid;place-items:center;opacity:0;transform:translateY(-8px) scale(.9);transition:.4s}
.svcm-tile:hover .svcm-go{opacity:1;transform:none;background:var(--accent);border-color:var(--accent)}
.svcm-go svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:1.8}
@media(max-width:900px){.svcm-grid{column-count:2}}
@media(max-width:600px){.svcm-grid{column-count:1}.svcm-tile{height:300px!important}}

/* =========================================================
   SERVICES SPLIT (Intro + Liste mit Gradient-Icons)
   ========================================================= */
.ss-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:stretch}
.ss-intro{display:flex;flex-direction:column;justify-content:space-between;gap:40px}
.ss-title{font-size:clamp(2.1rem,4vw,3.4rem);margin:18px 0 0;max-width:14ch}
/* Button unten links, mit fuehrender Kreis-Pfeil-Marke */
/* Neuros-Button: Pille mit Gradient-Rand (rot->blau) + fuehrende Kreis-Pfeil-Marke */
.ss-btn{align-self:flex-start;padding:9px 26px 9px 9px;gap:14px;
  color:var(--ink);-webkit-text-fill-color:var(--ink);
  border:1.5px solid transparent;border-radius:40px;transition:transform .3s,box-shadow .3s;
  background:linear-gradient(#fff,#fff) padding-box,
             linear-gradient(95deg,#0F6E72,#159A9F) border-box}
.section.paper .ss-btn{background:linear-gradient(var(--paper),var(--paper)) padding-box,
             linear-gradient(95deg,#0F6E72,#159A9F) border-box}
.ss-btn .fill{display:none}
.ss-btn:hover{color:var(--ink);-webkit-text-fill-color:var(--ink);transform:translateY(-2px);box-shadow:0 16px 30px -18px rgba(21,154,159,.5)}
.ss-arrow{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;flex:none;
  border:1.5px solid transparent;transition:.35s;
  background:linear-gradient(#fff,#fff) padding-box,
             linear-gradient(95deg,#0F6E72,#159A9F) border-box}
.ss-arrow svg{width:14px;height:14px;stroke:var(--ink);fill:none;stroke-width:1.8;transition:transform .4s,stroke .35s}
.ss-btn:hover .ss-arrow{background:linear-gradient(95deg,#0F6E72,#159A9F)}
.ss-btn:hover .ss-arrow svg{stroke:#fff;transform:translateX(2px)}
.ss-list{display:flex;flex-direction:column}
.ss-row{display:grid;grid-template-columns:104px 1fr;gap:26px;align-items:center;padding:30px 0;border-bottom:1px solid var(--line)}
.ss-row:first-child{padding-top:0}
.ss-row:last-child{border-bottom:0}
.ss-ico{width:104px;height:104px}
.ss-ico svg{width:100%;height:100%;overflow:visible}
.ss-ico g{fill:none;stroke-width:.7;stroke-linecap:round;opacity:.92}
.ss-content h3{font-size:1.4rem;margin-bottom:10px}
.ss-content p{color:var(--muted);font-size:.95rem;max-width:44ch}
.ss-row:hover .ss-content h3{color:var(--accent)}
.ss-content h3{transition:color .3s}
.ss-list .ss-row.reveal:nth-child(2){transition-delay:.1s}
.ss-list .ss-row.reveal:nth-child(3){transition-delay:.2s}
@media(max-width:860px){
  .ss-grid{grid-template-columns:1fr;gap:40px}
  .ss-intro{position:static}
  .ss-title{max-width:20ch}
}
@media(max-width:480px){
  .ss-row{grid-template-columns:70px 1fr;gap:18px}
  .ss-ico{width:70px;height:70px}
}

/* =========================================================
   ABOUT SPLIT (Bild + Statistik | Intro mit Ghost-Text)
   ========================================================= */
/* full-bleed: Sektion ueber die volle Breite (nicht zentriert/boxed) */
.about .wrap{max-width:none;padding:0 var(--gap)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,34px);align-items:stretch}
.about-media{display:flex;flex-direction:column;gap:18px}

/* Bild-Karte (Original-Template-Bild) */
.about-img{position:relative;flex:1;min-height:clamp(300px,40vw,440px);border-radius:var(--radius);overflow:hidden;
  background:#0a0c16 url('about-image.jpg') center/cover no-repeat}
.about-img .mark{position:absolute;left:26px;top:24px;z-index:2;color:#fff;opacity:.92}
.about-img .mark svg{width:40px;height:40px;fill:currentColor}
.about-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,8,14,.35))}
.about-watch{position:absolute;right:16px;bottom:16px;z-index:3;display:inline-flex;align-items:center;gap:13px;
  background:#fff;border:0;border-radius:40px;padding:9px 22px 9px 9px;cursor:pointer;color:var(--ink);
  font-family:var(--head);font-weight:500;font-size:.92rem;transition:transform .3s}
.about-watch:hover{transform:translateY(-2px)}
.about-watch .play{width:40px;height:40px;border-radius:50%;background:var(--ink);display:grid;place-items:center;flex:none;transition:background .3s}
.about-watch .play i{width:0;height:0;border-left:10px solid #fff;border-top:6px solid transparent;border-bottom:6px solid transparent;margin-left:3px}
.about-watch:hover .play{background:var(--accent)}

/* Statistik-Karte (dunkel) */
.about-stats{position:relative;overflow:hidden;color:#fff;border-radius:var(--radius);
  padding:clamp(28px,3vw,40px);display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;align-items:center;
  background:url('about-grid.svg') right center/cover no-repeat,var(--card)}
.about-stats .glow{position:absolute;width:380px;height:380px;border-radius:50%;right:-120px;top:-160px;
  background:radial-gradient(circle,rgba(21,154,159,.22),transparent 65%);filter:blur(30px)}
.about-stats .st{position:relative;z-index:2}
.about-stats .st-label{font-family:var(--head);font-weight:600;font-size:clamp(1.1rem,1.6vw,1.4rem);line-height:1.15;color:#fff}
.about-stats .num{display:block;font-family:var(--head);font-weight:700;line-height:1;font-size:clamp(2rem,3.4vw,3rem);color:#fff}
.about-stats .cap{display:block;margin-top:8px;font-size:.8rem;color:var(--on-card-muted)}

/* Intro-Panel (hell) mit Ghost-Text */
.about-intro{position:relative;overflow:hidden;background:var(--paper);border-radius:var(--radius);
  padding:clamp(32px,4vw,58px);display:flex;flex-direction:column}
.about-ghost{margin-bottom:14px}
.about-ghost svg{display:block;width:min(100%,520px);height:auto;overflow:visible}
.about-intro h2{font-size:clamp(1.9rem,3.2vw,2.9rem);margin:12px 0 22px;max-width:18ch}
.about-intro p{color:var(--ink-soft);font-size:1rem;margin-bottom:16px;max-width:54ch}
.about-intro .ss-btn{margin-top:14px}
.section.paper .about-intro .ss-btn,.about-intro .ss-btn{background:linear-gradient(var(--paper),var(--paper)) padding-box,linear-gradient(95deg,#0F6E72,#159A9F) border-box}

@media(max-width:900px){
  .about-grid{grid-template-columns:1fr}
}

/* =========================================================
   MARQUEE (zwei gekreuzte Laufbänder, gegenläufig)
   ========================================================= */
/* diagonal ueber die Nachbar-Sektionen gelegt */
.xmarquee{position:relative;z-index:6;padding:0;background:transparent;
  margin:clamp(-60px,-5vw,-36px) 0;overflow-x:clip;overflow-y:visible}
.xm-band{position:relative;width:132%;left:-3%;overflow:hidden;padding:15px 0;transform-origin:0% 50%;
  box-shadow:0 18px 50px -24px rgba(0,0,0,.4)}
.xm-petrol{background:var(--accent);transform:rotate(-2.4deg);z-index:1}
.xm-dark{background:var(--card);transform:rotate(2.4deg);margin-top:-58px;z-index:2}
.xm-track{display:flex;width:max-content;animation:xm 34s linear infinite;will-change:transform}
.xm-track.xm-rev{animation-direction:reverse;animation-duration:30s}
.xm-group{display:flex;align-items:center;flex:none}
.xm-item{display:inline-flex;align-items:center;gap:.55em;padding:0 .7em;white-space:nowrap;color:#fff;
  font-family:var(--head);font-weight:600;letter-spacing:-.01em;font-size:clamp(1.1rem,2.1vw,1.9rem)}
.xm-petrol .xm-item .sep{color:rgba(255,255,255,.6)}
.xm-dark .xm-item .sep{color:var(--accent-bright)}
@keyframes xm{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.xm-track{animation:none}}

/* =========================================================
   PROJECTS (Akkordeon-Liste mit Ghost-Swirl)
   ========================================================= */
.projects{background:url('projects-swirl.png') left 1% center/auto 88% no-repeat}
.prj-grid{display:grid;grid-template-columns:0.62fr 1.38fr;gap:clamp(28px,4vw,64px);align-items:start}
.prj-title{font-size:clamp(1.9rem,3.4vw,2.9rem);margin:14px 0 26px;max-width:18ch}
.prj-list{border-top:1px solid var(--line)}
.prj-item{border-bottom:1px solid var(--line)}
.prj-head{width:100%;background:none;border:0;cursor:pointer;display:grid;grid-template-columns:auto 1fr auto;gap:22px;
  align-items:center;padding:22px 0;text-align:left}
.prj-year{font-family:var(--head);color:var(--muted);font-size:.8rem;font-weight:500}
.prj-name{font-family:var(--head);font-weight:600;font-size:clamp(1.05rem,1.5vw,1.25rem);line-height:1.25;color:var(--ink);transition:color .3s}
.prj-head:hover .prj-name,.prj-item.open .prj-name{color:var(--accent)}
.prj-tog{width:30px;height:30px;display:grid;place-items:center;color:var(--ink);transition:transform .4s,color .3s}
.prj-tog svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8}
.prj-item.open .prj-tog{transform:rotate(180deg);color:var(--accent)}
.prj-panel{max-height:0;overflow:hidden;transition:max-height .55s cubic-bezier(.4,0,.2,1)}
.prj-panel-inner{padding:4px 0 30px}
.prj-media{display:block;border-radius:var(--radius-md);overflow:hidden}
.prj-media img{width:100%;height:auto;display:block;transition:transform .6s ease}
.prj-media:hover img{transform:scale(1.04)}
.prj-ex{color:var(--muted);font-size:.95rem;line-height:1.6;margin-top:18px;max-width:62ch}
.prj-more{display:inline-flex;align-items:center;gap:9px;margin-top:18px;font-family:var(--head);font-weight:500;font-size:.85rem;color:var(--ink);transition:gap .3s,color .3s}
.prj-more .ic{display:grid;place-items:center}
.prj-more svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2}
.prj-more span:last-child,.prj-more{border:0}
.prj-more{position:relative}
.prj-more::after{content:"";position:absolute;left:22px;right:0;bottom:-2px;height:1px;background:currentColor;transform-origin:left;transition:transform .3s}
.prj-more:hover{color:var(--accent);gap:13px}
.prj-allbtn{margin-top:34px;align-self:flex-start}
@media(max-width:900px){
  .projects{background:none}
  .prj-grid{grid-template-columns:1fr}
  .prj-left{display:none}
}

/* =========================================================
   STEP CAROUSEL (Wie es funktioniert — Slider)
   ========================================================= */
.section.hiw{padding:clamp(46px,6vw,78px) 0}
.hiw-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.hiw-headings{max-width:60ch}
.hiw-title{font-size:clamp(1.9rem,3.6vw,3rem);margin-top:14px;max-width:24ch}
/* Navigations-Pille mit Gradient-Rand */
.hiw-nav{display:inline-flex;align-items:center;gap:4px;padding:5px;flex:none;
  border:1.5px solid transparent;border-radius:40px;
  background:linear-gradient(#fff,#fff) padding-box,linear-gradient(95deg,#0F6E72,#159A9F) border-box}
.hiw-nav button{width:42px;height:42px;border-radius:50%;border:0;background:transparent;cursor:pointer;
  display:grid;place-items:center;color:var(--ink);transition:background .3s,color .3s}
.hiw-nav button:hover{background:linear-gradient(95deg,#0F6E72,#159A9F);color:#fff}
.hiw-nav svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8}

.hiw-viewport{overflow:hidden;margin-top:48px}
.hiw-track{display:flex;gap:24px;will-change:transform}
.step-card{flex:0 0 calc((100% - 48px)/3);display:flex;align-items:flex-start;gap:18px;padding-top:8px}
.step-no{font-family:var(--head);font-weight:700;line-height:.78;flex:none;
  font-size:clamp(3.2rem,5vw,4.6rem);color:transparent;-webkit-text-stroke:1.4px var(--line)}
.step-body h3{font-size:1.18rem;margin-bottom:10px}
.step-body p{color:var(--muted);font-size:.95rem;line-height:1.6}
@media(max-width:980px){.step-card{flex:0 0 calc((100% - 24px)/2)}}
@media(max-width:600px){.step-card{flex:0 0 100%}.hiw-head{align-items:flex-start}}

/* Headline-Animation: Buchstabe fuer Buchstabe */
.anim-letters .wd{display:inline-block}
.anim-letters .ltr{display:inline-block;opacity:0;transform:translateY(.5em) rotate(5deg);
  transition:opacity .5s ease,transform .55s cubic-bezier(.2,.7,.3,1)}
.anim-letters.in .ltr{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.anim-letters .ltr{opacity:1!important;transform:none!important;transition:none}}

/* =========================================================
   HOW IT WORKS (01-04)
   ========================================================= */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:54px;position:relative}
.steps::before{content:"";position:absolute;top:26px;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,var(--line),var(--line),transparent)}
.step{position:relative}
.step .no{display:inline-grid;place-items:center;width:54px;height:54px;border-radius:50%;background:var(--ink);color:#fff;font-family:var(--head);font-weight:600;position:relative;z-index:2;transition:.35s}
.step:hover .no{background:var(--accent)}
.step h3{font-size:1.3rem;margin:22px 0 8px}
.step p{color:var(--muted);font-size:.93rem}

/* =========================================================
   RESULTS / PROOF
   ========================================================= */
.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:52px}
.result{background:var(--card);color:var(--on-card);border-radius:var(--radius-md);padding:38px 32px;position:relative;overflow:hidden;transition:.35s}
.result:hover{transform:translateY(-5px)}
.result .metric{font-family:var(--head);font-weight:700;font-size:2.7rem;line-height:1;color:#fff}
.result .sub{font-family:var(--head);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--on-card-muted);margin:14px 0 16px}
.result p{color:var(--on-card-muted);font-size:.92rem}
.result .branch{margin-top:22px;padding-top:16px;border-top:1px solid rgba(255,255,255,.12);font-family:var(--head);font-size:.74rem;color:var(--accent-bright)}

/* =========================================================
   TEAM (Über uns — Mitarbeiter & Rollen)
   ========================================================= */
.team-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,4vw,64px);align-items:start}
.team-intro{position:sticky;top:100px}
.team-title{font-size:clamp(1.9rem,3.2vw,2.8rem);margin:14px 0 26px;max-width:16ch}
.team-stat{margin-bottom:26px}
.team-stat .ghost-num{display:block;font-family:var(--head);font-weight:700;line-height:.9;font-size:clamp(3rem,6vw,5rem);color:transparent;-webkit-text-stroke:1.4px #cdd4d8}
.team-stat .cap{font-family:var(--head);font-weight:600;color:var(--ink-soft);font-size:.95rem}
.team-cards{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,26px);padding-bottom:50px}
.team-cards .tm-card:nth-child(even){transform:translateY(46px)}
.tm-photo{position:relative;border-radius:var(--radius-md);overflow:hidden;background:var(--paper);aspect-ratio:1/1.16}
.tm-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.tm-card:hover .tm-photo img{transform:scale(1.05)}
.tm-tag{position:absolute;right:12px;top:50%;transform:translateY(-50%);writing-mode:vertical-rl;
  font-family:var(--head);font-weight:700;font-size:clamp(1.5rem,2.3vw,2.3rem);color:rgba(255,255,255,.72);
  text-shadow:0 2px 16px rgba(0,0,0,.18);pointer-events:none}
.tm-soc{position:absolute;left:16px;bottom:16px;display:flex;align-items:center;gap:8px}
.tm-soc-btn{width:44px;height:44px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;flex:none;transition:background .3s}
.tm-card:hover .tm-soc-btn{background:var(--accent)}
.tm-soc-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8}
.tm-soc-list{display:flex;gap:7px;opacity:0;transform:translateX(-10px);transition:opacity .4s,transform .4s;pointer-events:none}
.tm-card:hover .tm-soc-list{opacity:1;transform:none;pointer-events:auto}
.tm-soc-list a{width:38px;height:38px;border-radius:50%;background:#fff;color:var(--ink);display:grid;place-items:center;transition:background .3s,color .3s}
.tm-soc-list a:hover{background:var(--accent);color:#fff}
.tm-soc-list svg{width:16px;height:16px;fill:currentColor}
.tm-card h3{margin-top:16px;font-size:1.12rem}
.tm-role{color:var(--muted);font-size:.85rem;font-family:var(--head)}
@media(max-width:860px){.team-grid{grid-template-columns:1fr;gap:36px}.team-intro{position:static}}
@media(max-width:520px){.team-cards{grid-template-columns:1fr}.team-cards .tm-card:nth-child(even){transform:none}}

/* =========================================================
   BLOG (Heading + Button | zwei Beitragskarten)
   ========================================================= */
.blog-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:46px}
.blog-headings{max-width:60ch}
.blog-title{font-size:clamp(1.9rem,3.4vw,3rem);margin-top:14px;max-width:28ch}
.blog-allbtn{flex:none}
.blog-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,3vw,42px);align-items:start}
.blog-card{display:flex;flex-direction:column}
.blog-media{position:relative;display:block;border-radius:var(--radius-md);overflow:hidden}
.blog-media img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block;transition:transform .6s ease}
.blog-card:hover .blog-media img{transform:scale(1.05)}
.blog-date{position:absolute;left:0;bottom:0;background:var(--page);color:var(--muted);
  font-family:var(--head);font-size:.78rem;padding:12px 20px;border-radius:0 14px 0 var(--radius-md)}
.blog-date b{color:var(--accent);font-weight:600}
.blog-body{padding-top:22px}
.blog-body h3{font-size:clamp(1.1rem,1.5vw,1.3rem);line-height:1.3}
.blog-body h3 a{transition:color .3s}
.blog-card:hover .blog-body h3 a{color:var(--accent)}
.blog-ex{color:var(--muted);font-size:.92rem;margin-top:12px;max-width:46ch}
.blog-cats{display:flex;gap:8px;align-items:center;margin-top:18px;font-family:var(--head);font-size:.8rem;color:var(--line)}
.blog-cats a{color:var(--ink-soft);transition:color .3s}
.blog-cats a:hover{color:var(--accent)}
@media(max-width:780px){.blog-grid{grid-template-columns:1fr}}

/* =========================================================
   TESTIMONIALS (full-bleed: Slider | Heading + Fan + Zähler)
   ========================================================= */
.testimonials{padding:clamp(50px,7vw,100px) var(--gap)}
.testi-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,80px);align-items:center}

.testi-left{position:relative}
.testi-img{position:absolute;inset:0;border-radius:var(--radius);overflow:hidden;background:#0a0c16 url('testi-image.jpg') center/cover no-repeat}
.testi-card{position:relative;z-index:2;margin:clamp(64px,11%,110px) clamp(36px,13%,130px) 0 0;
  background:var(--card);color:#fff;border-radius:var(--radius);padding:clamp(34px,3.4vw,56px);
  min-height:clamp(320px,30vw,400px);display:flex;flex-direction:column;justify-content:center}
.q-mark{color:var(--accent-bright);margin-bottom:22px}
.q-mark svg{width:42px;height:28px;fill:currentColor}
.testi-track{position:relative}
.testi-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .5s ease,transform .5s ease}
.testi-slide.active{position:relative;opacity:1;visibility:visible;transform:none}
.testi-slide p{font-size:clamp(1rem,1.25vw,1.18rem);line-height:1.6;color:rgba(255,255,255,.9)}
.testi-author{margin-top:24px}
.testi-author b{display:block;font-family:var(--head);font-weight:600;font-size:1rem;color:#fff}
.testi-author span{color:var(--on-card-muted);font-size:.85rem}
.testi-nav{position:absolute;right:0;bottom:0;display:flex;background:#fff;border-radius:18px 0 var(--radius) 0;overflow:hidden}
.testi-nav button{width:48px;height:48px;border:0;background:#fff;cursor:pointer;display:grid;place-items:center;color:var(--ink);transition:background .3s,color .3s}
.testi-nav button:hover{background:var(--ink);color:#fff}
.testi-nav button+button{border-left:1px solid var(--line)}
.testi-nav svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8}

.testi-right{position:relative}
.testi-title{font-size:clamp(1.9rem,3.4vw,3rem);margin:14px 0 0;max-width:18ch}
.testi-fan{display:block;width:clamp(180px,26vw,320px);margin:26px 0 0 auto;opacity:.85}
.testi-stat{margin-top:-46px;position:relative;z-index:2}
.testi-stat .ghost-num{display:block;font-family:var(--head);font-weight:700;line-height:.9;
  font-size:clamp(3.5rem,7vw,6rem);color:transparent;-webkit-text-stroke:1.4px #d7dde1}
.testi-stat .cap{font-family:var(--head);font-weight:600;color:var(--ink);font-size:.95rem}

@media(max-width:900px){
  .testi-grid{grid-template-columns:1fr;gap:30px}
  .testi-card{margin:56px 28px 0 0}
  .testi-fan{margin:24px auto 0}
  .testi-stat{margin-top:-30px}
}

/* =========================================================
   TESTIMONIAL
   ========================================================= */
.quote{max-width:900px;margin:0 auto;text-align:center}
.quote blockquote{font-family:var(--head);font-weight:500;font-size:clamp(1.5rem,3vw,2.2rem);line-height:1.35;letter-spacing:-.02em}
.quote .who{display:flex;gap:14px;align-items:center;justify-content:center;margin-top:30px}
.quote .av{width:54px;height:54px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--head);font-weight:600}
.quote .who .m{text-align:left}
.quote .who .m b{display:block;font-family:var(--head)}
.quote .who .m span{color:var(--muted);font-size:.88rem}

/* =========================================================
   PARTNERS
   ========================================================= */
.partners{display:flex;align-items:center;justify-content:center;gap:56px;flex-wrap:wrap;margin-top:14px}
.partners span{font-family:var(--head);font-weight:600;font-size:1.3rem;color:var(--ink);opacity:.4}

/* logo marquee — auto-scrolling, seamless, fades at edges */
.logos-sec{padding:clamp(34px,4vw,52px) 0}
.logos{margin-top:26px;overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.logos-track{display:flex;align-items:center;width:max-content;animation:logos-scroll 34s linear infinite}
.logos:hover .logos-track{animation-play-state:paused}
.logo-item{flex:none;padding:0 clamp(30px,4.5vw,64px);display:grid;place-items:center}
.logo-item img{height:46px;width:auto;filter:grayscale(1);opacity:.5;transition:opacity .35s ease,filter .35s ease}
.logo-item img:hover{opacity:1}
@keyframes logos-scroll{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){
  .logos{-webkit-mask:none;mask:none}
  .logos-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;row-gap:14px}
}

/* =========================================================
   CTA (dark rounded card)
   ========================================================= */
.cta{padding:var(--gap)}
.cta-card{background:var(--card);color:var(--on-card);border-radius:var(--radius);padding:clamp(40px,7vw,80px);display:grid;grid-template-columns:1.3fr 1fr;gap:50px;align-items:center;position:relative;overflow:hidden}
.cta-card .glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(21,154,159,.4),transparent 65%);top:-200px;right:-120px;filter:blur(40px)}
.cta-card>*{position:relative;z-index:2}
.cta-card h2{color:#fff;font-size:clamp(1.9rem,3.6vw,3rem)}
.cta-card .lead{color:var(--on-card-muted);margin-top:16px}
.cta-list{list-style:none}
.cta-list li{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12);font-family:var(--head);font-size:.9rem;color:var(--on-card)}
.cta-list li:last-child{border-bottom:0}
.cta-list .k{color:var(--accent-bright)}
@media(max-width:860px){.cta-card{grid-template-columns:1fr;gap:32px}}

/* =========================================================
   FOOTER (dark)
   ========================================================= */
.site-footer{position:relative;background:var(--card);color:var(--on-card-muted);padding:72px 0 28px;margin-top:var(--gap)}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-bright))}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.25fr;gap:40px;padding-bottom:38px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-grid .brand .name{color:#fff}
.foot-grid .brand .mark{background:var(--accent);color:#fff}
.foot-col h4{font-family:var(--head);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:#fff;margin:0 0 16px}
.foot-col a,.foot-col p{display:block;padding:6px 0;font-size:.9rem;transition:color .25s}
.foot-col a:hover{color:var(--accent-bright)}
.foot-about{font-size:.92rem;max-width:34ch;margin-top:16px;line-height:1.7}
.foot-socials{display:flex;gap:10px;margin-top:22px}
.foot-socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;color:#fff;transition:background .3s,border-color .3s,transform .3s}
.foot-socials a:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}
.foot-socials svg{width:17px;height:17px;fill:currentColor}
.foot-addr{color:var(--on-card-muted);line-height:1.7;margin-bottom:8px}
.foot-cta{display:inline-flex!important;align-items:center;gap:8px;margin-top:14px;color:var(--accent-bright);font-family:var(--head);font-weight:500;transition:gap .3s}
.foot-cta svg{width:16px;height:13px;stroke:currentColor;fill:none;stroke-width:1.8}
.foot-cta:hover{gap:12px}
.foot-trust{display:flex;flex-wrap:wrap;gap:12px;padding:24px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-trust span{display:inline-flex;align-items:center;gap:8px;font-family:var(--head);font-size:.78rem;color:var(--on-card);
  border:1px solid rgba(255,255,255,.14);border-radius:40px;padding:8px 16px}
.foot-trust svg{width:14px;height:14px;stroke:var(--accent-bright);fill:none;stroke-width:2.2}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;flex-wrap:wrap;gap:16px;font-size:.82rem}
.foot-bottom .legal{display:flex;gap:24px;margin-left:auto}
.foot-bottom .legal a:hover{color:var(--accent-bright)}
.foot-top{display:inline-flex;align-items:center;gap:8px;color:#fff;font-family:var(--head);font-weight:500;font-size:.82rem}
.foot-top svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .3s}
.foot-top:hover svg{transform:translateY(-3px)}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.svc-grid,.steps,.results-grid,.foot-grid{grid-template-columns:1fr}.steps::before{display:none}
  .foot-bottom{justify-content:flex-start}.foot-bottom .legal{margin-left:0}}

/* =========================================================
   VIDEO LIGHTBOX (shared)
   ========================================================= */
.lb{position:fixed;inset:0;z-index:300;background:rgba(8,9,14,.9);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:34px;opacity:0;visibility:hidden;transition:.4s}
.lb.open{opacity:1;visibility:visible}
.lb .frame{position:relative;width:min(1000px,100%);aspect-ratio:16/9;background:#000;border-radius:14px;overflow:hidden;transform:scale(.94);transition:transform .4s cubic-bezier(.2,.7,.3,1)}
.lb.open .frame{transform:scale(1)}
.lb iframe{width:100%;height:100%;border:0}
.lb .x{position:absolute;top:-48px;right:0;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.06);color:#fff;cursor:pointer;font-size:20px;display:grid;place-items:center}
.lb .x:hover{background:#fff;color:#000}

/* =========================================================
   SCROLL PROGRESS + HEADER SHRINK
   ========================================================= */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;pointer-events:none}
.scroll-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-bright))}
.site-header{transition:box-shadow .3s,background .3s}
.site-header .wrap{transition:height .3s}
.site-header.shrink{box-shadow:0 10px 34px -20px rgba(0,0,0,.3)}
.site-header.shrink .wrap{height:62px}

/* =========================================================
   TRUST BAND (Zertifikate & Sicherheit)
   ========================================================= */
.trust-band{padding-top:0}
.trust-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px 14px;
  padding:26px 30px;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--paper)}
.trust-item{display:inline-flex;align-items:center;gap:10px;font-family:var(--head);font-weight:600;
  font-size:.92rem;color:var(--ink-soft);padding:0 6px}
.trust-item svg{width:20px;height:20px;stroke:var(--accent-bright);fill:none;stroke-width:2.2;flex:none}
.trust-item + .trust-item{border-left:1px solid var(--line);padding-left:20px}
@media(max-width:760px){.trust-item + .trust-item{border-left:0;padding-left:6px}}

/* =========================================================
   POLISH — gradient accents + staggered entrances
   ========================================================= */
/* eyebrow tick as a brand gradient */
.eyebrow::before{background:linear-gradient(90deg,var(--accent),var(--accent-bright))}

/* services mosaic: tiles rise in, one after another */
.svcm-grid .svcm-tile{opacity:0;transform:translateY(26px);
  transition:opacity .65s ease,transform .65s cubic-bezier(.2,.7,.3,1),box-shadow .45s}
.svcm-grid.in .svcm-tile{opacity:1;transform:none}
.svcm-grid.in .svcm-tile:nth-child(2){transition-delay:.08s}
.svcm-grid.in .svcm-tile:nth-child(3){transition-delay:.16s}
.svcm-grid.in .svcm-tile:nth-child(4){transition-delay:.24s}
.svcm-grid.in .svcm-tile:nth-child(5){transition-delay:.32s}
.svcm-grid.in .svcm-tile:nth-child(6){transition-delay:.40s}

/* trust badges: fade in left-to-right */
.trust-row .trust-item{opacity:0;transform:translateY(10px);transition:opacity .5s ease,transform .5s ease}
.trust-row.in .trust-item{opacity:1;transform:none}
.trust-row.in .trust-item:nth-child(2){transition-delay:.1s}
.trust-row.in .trust-item:nth-child(3){transition-delay:.2s}
.trust-row.in .trust-item:nth-child(4){transition-delay:.3s}

/* team cards: gentle staggered fade (keeps the offset layout via opacity-only) */
.team-cards.in .tm-card{animation:tm-pop .7s cubic-bezier(.2,.7,.3,1) both}
.team-cards.in .tm-card:nth-child(2){animation-delay:.08s}
.team-cards.in .tm-card:nth-child(3){animation-delay:.16s}
.team-cards.in .tm-card:nth-child(4){animation-delay:.24s}
.team-cards.in .tm-card:nth-child(5){animation-delay:.32s}
@keyframes tm-pop{from{opacity:0}to{opacity:1}}

@media(prefers-reduced-motion:reduce){
  .svcm-grid .svcm-tile,.trust-row .trust-item{opacity:1;transform:none}
  .team-cards.in .tm-card{animation:none}
}

/* anchored sections clear the sticky header */
[id]{scroll-margin-top:96px}

/* =========================================================
   PROBLEM -> LOESUNG ("Kennen Sie das?")
   ========================================================= */
.probsol{position:relative;overflow:hidden;padding:clamp(46px,6vw,78px) 0}
.ps-aura{position:absolute;z-index:0;width:min(820px,95vw);height:760px;left:50%;top:-220px;transform:translateX(-50%);
  pointer-events:none;background:radial-gradient(circle,rgba(21,154,159,.16),transparent 62%);filter:blur(24px)}
.probsol .wrap{position:relative;z-index:1}
.ps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px}

/* dark, glowing cards (matches the site's dark-card motif) */
.ps-card{position:relative;overflow:hidden;isolation:isolate;background:var(--card);color:#fff;
  border:1px solid rgba(255,255,255,.07);border-radius:var(--radius);padding:clamp(30px,3vw,42px);
  display:flex;flex-direction:column;opacity:0;transform:translateY(30px);
  transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1),box-shadow .5s,border-color .5s}
.ps-grid.in .ps-card{opacity:1;transform:none}
.ps-grid.in .ps-card:nth-child(2){transition-delay:.12s}
.ps-grid.in .ps-card:nth-child(3){transition-delay:.24s}
.ps-card:hover{transform:translateY(-8px);border-color:rgba(143,214,217,.45);
  box-shadow:0 50px 90px -50px rgba(15,110,114,.85);transition-delay:0s}
.ps-card > *{position:relative;z-index:2}

/* ghost number + teal glow behind */
.ps-num{position:absolute;right:16px;top:2px;z-index:1;font-family:var(--head);font-weight:700;line-height:1;
  font-size:clamp(5rem,9vw,8rem);color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.08)}
.ps-glow{position:absolute;z-index:0;width:300px;height:300px;border-radius:50%;left:-90px;top:-110px;pointer-events:none;
  background:radial-gradient(circle,rgba(21,154,159,.42),transparent 65%);filter:blur(34px);opacity:.55;transition:opacity .5s}
.ps-card:hover .ps-glow{opacity:1}

/* gradient icon that floats on hover */
.ps-ico{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;margin-bottom:22px;
  background:linear-gradient(135deg,var(--accent),var(--accent-bright));box-shadow:0 18px 32px -16px rgba(21,154,159,.75)}
.ps-ico svg{width:30px;height:30px;stroke:#fff;fill:none;stroke-width:1.7}
.ps-card:hover .ps-ico{animation:ps-float 2.4s ease-in-out infinite}
@keyframes ps-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

.ps-tag{align-self:flex-start;font-family:var(--head);font-weight:600;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--on-card-muted);border:1px solid rgba(255,255,255,.16);border-radius:40px;padding:5px 12px;margin-bottom:14px}
.ps-card h3{font-size:clamp(1.2rem,1.6vw,1.45rem);line-height:1.22;color:#fff}

/* solution block with arrow connector */
.ps-sol{margin-top:26px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;gap:15px;align-items:flex-start}
.ps-arrow{flex:none;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;margin-top:2px;
  background:linear-gradient(135deg,var(--accent),var(--accent-bright));box-shadow:0 10px 22px -10px rgba(21,154,159,.8)}
.ps-arrow svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}
.ps-card:hover .ps-arrow{animation:ps-nudge 1.6s ease-in-out infinite}
@keyframes ps-nudge{0%,100%{transform:translateY(0)}50%{transform:translateY(3px)}}
.ps-sol .ps-tag.good{color:#8fd6d9;border-color:rgba(143,214,217,.4);margin-bottom:8px}
.ps-sol p{color:rgba(234,240,242,.84);font-size:.95rem;line-height:1.6}

@media(max-width:880px){.ps-grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){
  .ps-card{opacity:1;transform:none}
  .ps-card:hover .ps-ico,.ps-card:hover .ps-arrow{animation:none}
}

/* =========================================================
   TECH PARTNERS (Technologie-Partner-Leiste)
   ========================================================= */
.tech-partners{padding:clamp(44px,5vw,66px) 0}
.tech-partners .head{margin-bottom:0}
.tp-sub{color:var(--muted);font-size:.95rem;margin-top:10px}
.tp-row{gap:28px 46px;margin-top:26px}
.tp-row span{font-size:1.15rem}

/* =========================================================
   TESTIMONIALS — Rating + Ergebnis-Chip
   ========================================================= */
.testi-foot{margin-top:24px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.testi-result{font-family:var(--head);font-weight:700;font-size:.8rem;color:#fff;white-space:nowrap;
  background:linear-gradient(95deg,var(--accent),var(--accent-bright));border-radius:40px;padding:7px 14px}
.testi-rating{display:flex;align-items:center;gap:12px;margin-top:22px}
.testi-rating .stars{color:#F5B301;letter-spacing:2px;font-size:1.1rem}
.testi-rating .rate-txt{font-size:.88rem;color:var(--ink-soft)}
.testi-rating .rate-txt b{font-family:var(--head);color:var(--ink)}

/* =========================================================
   FAQ (Split-Layout + Karten-Akkordeon)
   ========================================================= */
.faq-sec{position:relative;overflow:hidden}
.faq-aura{position:absolute;z-index:0;width:min(560px,80vw);height:560px;left:-160px;bottom:-200px;pointer-events:none;
  background:radial-gradient(circle,rgba(21,154,159,.12),transparent 64%);filter:blur(24px)}
.faq-sec .wrap{position:relative;z-index:1}
.faq-grid{display:grid;grid-template-columns:.78fr 1.22fr;gap:clamp(36px,5vw,76px);align-items:start}
.faq-aside{position:sticky;top:104px}
.faq-title{font-size:clamp(1.9rem,3.4vw,2.9rem);margin:14px 0 18px;max-width:13ch}
.faq-aside .lead{margin-bottom:28px}
.faq-contact{position:relative;overflow:hidden;background:linear-gradient(155deg,#0f6e72,#0a0c16 82%);
  color:#fff;border-radius:var(--radius-md);padding:30px 28px}
.faq-contact .glow{position:absolute;right:-80px;top:-90px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(21,154,159,.5),transparent 65%);filter:blur(24px)}
.faq-contact b{position:relative;font-family:var(--head);font-weight:600;font-size:1.08rem}
.faq-contact p{position:relative;color:rgba(234,240,242,.8);font-size:.9rem;margin:8px 0 20px}
.faq-contact .btn{position:relative}
.faq-list{display:flex;flex-direction:column;gap:14px}
.faq-item{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);
  transition:border-color .3s,box-shadow .35s,transform .35s}
.faq-item:hover{transform:translateY(-2px);box-shadow:0 22px 44px -32px rgba(0,0,0,.35)}
.faq-item.open{border-color:transparent;box-shadow:0 30px 60px -34px rgba(15,110,114,.45)}
.faq-item.open::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;z-index:2;
  background:linear-gradient(180deg,var(--accent),var(--accent-bright))}
.faq-q{width:100%;background:none;border:0;cursor:pointer;display:flex;align-items:center;gap:18px;text-align:left;
  padding:22px 24px;font-family:var(--head);font-weight:600;font-size:clamp(1rem,1.3vw,1.14rem);color:var(--ink);transition:color .3s}
.faq-qn{flex:none;font-size:.82rem;font-weight:700;color:var(--accent);letter-spacing:.04em}
.faq-qt{flex:1}
.faq-q:hover,.faq-item.open .faq-q{color:var(--accent)}
.faq-ic{position:relative;width:20px;height:20px;flex:none;color:var(--accent)}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;background:currentColor;border-radius:2px;transition:transform .35s,opacity .35s}
.faq-ic::before{left:0;right:0;top:9px;height:2px}
.faq-ic::after{top:0;bottom:0;left:9px;width:2px}
.faq-item.open .faq-ic::after{transform:scaleY(0);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.4,0,.2,1)}
.faq-a p{padding:0 24px 24px 60px;color:var(--muted);font-size:.96rem;line-height:1.65}
@media(max-width:880px){
  .faq-grid{grid-template-columns:1fr;gap:34px}
  .faq-aside{position:static}
  .faq-title{max-width:none}
  .faq-a p{padding-left:24px}
}

/* =========================================================
   HERO LANYARD (desktop badge that drops in over the hero)
   ========================================================= */
.lanyard{position:absolute;top:0;right:7%;z-index:5;width:340px;height:480px;pointer-events:none;visibility:hidden}
.lny-rope{position:absolute;inset:0;overflow:visible;pointer-events:none}
.lny-card{position:absolute;top:0;left:0;width:200px;transform-origin:100px 0;will-change:transform;
  padding:38px 22px 26px;border-radius:18px;text-align:center;
  background:linear-gradient(165deg,#13151f,#0a0c16);color:#fff;border:1px solid rgba(143,214,217,.2);
  box-shadow:0 44px 80px -30px rgba(0,0,0,.75);pointer-events:auto;cursor:grab;user-select:none;touch-action:none}
.lny-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;border-radius:18px 18px 0 0;
  background:linear-gradient(90deg,var(--accent),var(--accent-bright))}
.lny-card.grabbing{cursor:grabbing}
.lny-clip{position:absolute;top:-9px;left:50%;transform:translateX(-50%);z-index:3;width:34px;height:18px;
  border:2px solid #b9bec4;border-radius:6px;background:linear-gradient(180deg,#eef1f3,#cfd4da)}
.lny-hole{position:absolute;top:13px;left:50%;transform:translateX(-50%);width:44px;height:11px;border-radius:7px;
  background:#05060a;box-shadow:0 1px 0 rgba(255,255,255,.07) inset}
.lny-logo{width:124px;height:auto;margin:14px auto 18px;display:block;opacity:.97;pointer-events:none}
.lny-name{display:block;font-family:var(--head);font-weight:600;font-size:1.25rem;letter-spacing:.01em}
.lny-role{display:block;margin-top:5px;font-family:var(--head);font-size:.72rem;letter-spacing:.05em;color:var(--on-card-muted)}
/* desktop only */
@media(max-width:1024px){.lanyard{display:none}}
