/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --black:#000;--white:#fff;
  --g1:rgba(255,255,255,.04);--g2:rgba(255,255,255,.08);--g3:rgba(255,255,255,.18);--g4:rgba(255,255,255,.40);--g5:rgba(255,255,255,.60);
  --font:'Inter',sans-serif;--heading:'Outfit',sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --radius-card:0px;
  --radius-panel:0px;
  --radius-button:999px;
}
html{scroll-behavior:smooth;cursor:none}
body{
  background:var(--black);color:var(--white);font-family:var(--font);
  font-size:16px;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased;
  cursor:none;
}
*{cursor:none!important}
a{color:inherit;text-decoration:none;cursor:none}
button{cursor:none}
body,a,button,[href],input,textarea,select,summary,label,.btn,.nav-cta,.contact-bar{cursor:none!important}
ul{list-style:none}
img{max-width:100%;display:block}
::selection{background:var(--white);color:var(--black)}



/* ===== PAGE LOADER ===== */
body.page-loading{overflow:hidden}
.page-loader{
  position:fixed;
  inset:0;
  z-index:100001;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#000;
  opacity:1;
  visibility:visible;
  transition:opacity .7s ease, visibility .7s ease;
}
.page-loader.is-hidden{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}
.page-loader-inner{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  width:180px;
  height:180px;
  font-family:var(--heading);
  font-size:1rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.page-loader-orbit{
  position:absolute;
  inset:0;
  border-radius:50%;
  animation:pageLoaderSpin 2.2s linear infinite;
}
@keyframes pageLoaderSpin{
  0%{
    transform:rotate(90deg);
    box-shadow:
      0 10px 20px 0 #ffffff inset,
      0 25px 40px 0 #aaaaaa inset,
      0 60px 80px 0 #222222 inset;
  }
  50%{
    transform:rotate(270deg);
    box-shadow:
      0 10px 20px 0 #ffffff inset,
      0 15px 20px 0 #888888 inset,
      0 50px 70px 0 #111111 inset;
  }
  100%{
    transform:rotate(450deg);
    box-shadow:
      0 10px 20px 0 #ffffff inset,
      0 25px 40px 0 #aaaaaa inset,
      0 60px 80px 0 #222222 inset;
  }
}
.page-loader-letter{
  position:relative;
  z-index:1;
  display:inline-block;
  opacity:.35;
  animation:pageLoaderLetters 1.8s infinite;
}
.page-loader-letter:nth-child(1){animation-delay:0s}
.page-loader-letter:nth-child(2){animation-delay:.1s}
.page-loader-letter:nth-child(3){animation-delay:.2s}
.page-loader-letter:nth-child(4){animation-delay:.3s}
.page-loader-letter:nth-child(5){animation-delay:.4s}
.page-loader-letter:nth-child(6){animation-delay:.5s}
.page-loader-letter:nth-child(7){animation-delay:.6s}
.page-loader-letter:nth-child(8){animation-delay:.7s}
.page-loader-letter:nth-child(9){animation-delay:.8s}
.page-loader-letter:nth-child(10){animation-delay:.9s}
@keyframes pageLoaderLetters{
  0%,100%{opacity:.28;transform:translateY(0)}
  25%{opacity:1;transform:translateY(-4px)}
  50%{opacity:.65;transform:translateY(0)}
}

/* ===== GRAIN ===== */
.grain{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:256px 256px;
}

/* ===== CURSOR (single circle) ===== */
.cursor{
  position:fixed;width:20px;height:20px;
  border:1.5px solid var(--white);border-radius:50%;
  pointer-events:none;z-index:99999;
  transform:translate(-50%,-50%);
  transition:width .4s var(--ease),height .4s var(--ease),border-color .3s,background .3s;
  opacity:0;mix-blend-mode:difference;
}
.cursor.visible{opacity:1}
.cursor.hover{width:60px;height:60px;background:rgba(255,255,255,.06);border-color:var(--g5)}

/* ===== SIDE NAV ===== */
.side-nav{
  position:fixed;
  left:26px;
  top:50%;
  transform:translateY(-50%);
  z-index:800;
  display:flex;
  flex-direction:column;
  gap:16px;
  opacity:0;
  transition:opacity .42s ease, transform .55s var(--ease);
}
.side-nav.visible{opacity:1}
.side-nav-kicker,.side-dot-index{display:none!important}
.side-nav-rail{
  position:absolute;
  left:2px;
  top:4px;
  bottom:4px;
  width:1px;
  background:rgba(255,255,255,.08);
  overflow:hidden;
}
.side-nav-rail-fill{
  display:block;
  width:100%;
  height:100%;
  background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,.22));
  transform-origin:top center;
  transform:scaleY(.12);
}
.side-dot{
  appearance:none;
  border:none;
  background:none;
  color:inherit;
  font:inherit;
  position:relative;
  display:flex;
  align-items:center;
  gap:0;
  min-height:14px;
  padding:0;
  cursor:none;
  text-align:left;
}
.side-dot-core{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  width:24px;
  height:14px;
}
.side-dot-line{
  display:block;
  width:12px;
  height:1px;
  background:rgba(255,255,255,.22);
  transform-origin:left center;
  transition:transform .32s var(--ease), background .32s var(--ease), width .32s var(--ease);
}
.side-dot-orb{
  position:absolute;
  left:0;
  top:50%;
  width:4px;
  height:4px;
  border-radius:50%;
  background:rgba(255,255,255,.56);
  transform:translateY(-50%);
  transition:transform .32s var(--ease), background .32s var(--ease), box-shadow .32s var(--ease);
}
.side-dot::after{display:none}
.side-dot-label{
  position:absolute;
  left:26px;
  top:50%;
  font-size:10px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:rgba(255,255,255,.68);
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transform:translate3d(-8px,-50%,0);
  transition:opacity .26s var(--ease), transform .26s var(--ease), color .26s var(--ease);
}
.side-dot:hover .side-dot-label,
.side-dot:focus-visible .side-dot-label{
  opacity:1;
  transform:translate3d(0,-50%,0);
  color:var(--white);
}
.side-dot:hover .side-dot-line,
.side-dot:focus-visible .side-dot-line{
  width:18px;
  background:rgba(255,255,255,.72);
}
.side-dot:hover .side-dot-orb,
.side-dot:focus-visible .side-dot-orb{
  transform:translateY(-50%) scale(1.35);
  background:var(--white);
  box-shadow:0 0 14px rgba(255,255,255,.14);
}
.side-dot.active .side-dot-line{
  width:18px;
  background:rgba(255,255,255,.92);
  transform:scaleX(1);
}
.side-dot.active .side-dot-orb{
  transform:translateY(-50%) scale(1.5);
  background:var(--white);
  box-shadow:0 0 0 4px rgba(255,255,255,.04), 0 0 14px rgba(255,255,255,.12);
}

/* ===== CONTACT BAR ===== */
.contact-bar{
  position:fixed;
  left:50%;
  bottom:24px;
  transform:translateX(-50%);
  z-index:2500;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-width:min(220px, calc(100vw - 32px));
  padding:14px 32px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  font-size:13px;
  font-weight:600;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--white);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
  transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease), opacity .35s var(--ease);
  background:rgba(0,0,0,.72);
}
.contact-bar:hover{border-color:rgba(255,255,255,.38);background:rgba(255,255,255,.08);box-shadow:0 24px 80px rgba(0,0,0,.42)}
.contact-bar svg{transition:transform .35s var(--ease)}
.contact-bar:hover svg{transform:translate(3px,-3px)}
.contact-bar.hidden{opacity:0;transform:translateX(-50%) translateY(20px);pointer-events:none}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:28px 80px;transition:all .6s var(--ease);
}
.nav.scrolled{padding:18px 80px}
.nav.scrolled::after{
  content:'';position:absolute;bottom:0;left:80px;right:80px;height:1px;
  background:linear-gradient(90deg,transparent,var(--g2),transparent);
}
.nav-logo img{width:44px;height:44px;border-radius:50%;transition:transform .5s var(--ease)}
.nav-logo:hover img{transform:rotate(-15deg) scale(1.1)}

.nav-center{display:flex;gap:40px;transition:all .6s var(--ease)}
/* nav links get hidden & become side dots on scroll */
.nav-center.morphed{opacity:0;pointer-events:none;transform:translateY(-8px)}

.nav-link{
  font-size:13px;font-weight:400;color:var(--g4);letter-spacing:.5px;
  transition:color .3s;position:relative;
}
.nav-link::after{
  content:'';position:absolute;bottom:-6px;left:50%;width:0;height:1px;
  background:var(--white);transition:all .4s var(--ease);transform:translateX(-50%);
}
.nav-link:hover{color:var(--white)}
.nav-link:hover::after{width:100%}

.nav-cta{
  font-size:13px;font-weight:500;color:var(--white);
  padding:10px 28px;border:1px solid var(--g2);border-radius:50px;
  transition:all .4s var(--ease);
}
.nav-cta:hover{background:var(--white);color:var(--black);border-color:var(--white)}

.burger{display:none;flex-direction:column;gap:6px;background:none;border:none;padding:8px;z-index:1001}
.burger span{display:block;width:22px;height:1.5px;background:var(--white);transition:all .3s var(--ease)}
.burger.active span:first-child{transform:rotate(45deg) translate(2.5px,2.5px)}
.burger.active span:last-child{transform:rotate(-45deg) translate(2.5px,-2.5px)}

/* MOBILE NAV */
.mobile-nav{
  position:fixed;inset:0;z-index:999;background:rgba(0,0,0,.97);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;
  opacity:0;pointer-events:none;transition:opacity .4s;
}
.mobile-nav.active{opacity:1;pointer-events:auto}
.mobile-link{
  font-family:var(--heading);font-size:28px;font-weight:600;color:var(--g4);
  transition:all .3s;transform:translateY(16px);opacity:0;
}
.mobile-nav.active .mobile-link{transform:translateY(0);opacity:1}
.mobile-nav.active .mobile-link:nth-child(1){transition-delay:.05s}
.mobile-nav.active .mobile-link:nth-child(2){transition-delay:.1s}
.mobile-nav.active .mobile-link:nth-child(3){transition-delay:.15s}
.mobile-nav.active .mobile-link:nth-child(4){transition-delay:.2s}
.mobile-nav.active .mobile-link:nth-child(5){transition-delay:.25s}
.mobile-link:hover{color:var(--white)}

/* ===== HERO VIDEO SECTION ===== */
.hero-video-section{
  position:relative;
  width:100%;
  min-height:100vh;
}

.hero-stage{
  position:sticky;
  top:0;
  height:100vh;
  overflow:hidden;
  background:#000;
}

.hero-canvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100vh;
  object-fit:cover;
  z-index:1;
  backface-visibility:hidden;
  will-change:opacity;
  transform:translateZ(0);
}

/* LOGO REVEAL */
.logo-reveal{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 24px;
  z-index:2;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s linear;
}
.logo-reveal.visible{opacity:1}

.logo-reveal-img{
  position:absolute;
  top:50%;
  left:50%;
  width:min(86vw, 1120px);
  height:auto;
  opacity:0;
  object-fit:contain;
  transform:translate(-50%,-50%) scale(.96);
  z-index:1;
  will-change:transform, opacity;
}

.logo-reveal-text{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  max-width:min(1180px, 94vw);
  font-family:var(--heading);
  font-size:clamp(28px,4.3vw,56px);
  font-weight:500;
  letter-spacing:.12em;
  text-transform:uppercase;
  line-height:1.1;
  text-shadow:0 10px 38px rgba(0,0,0,.42);
  opacity:0;
  transform:translateY(10px);
  will-change:transform, opacity;
}
.logo-reveal.visible .logo-reveal-text{opacity:1}

.reveal-line{
  display:block;
  text-wrap:balance;
}

.logo-glow{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:min(92vw, 1200px);
  height:min(92vw, 1200px);
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.08) 0%,rgba(255,255,255,.03) 40%,transparent 72%);
  opacity:0;
  pointer-events:none;
  z-index:0;
  will-change:transform, opacity;
}
.logo-reveal.visible .logo-glow{opacity:1}

.hero-scroll-hint{
  position:absolute;
  bottom:80px;
  left:50%;
  transform:translateX(-50%);
  z-index:3;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  font-size:10px;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--g3);
  transition:opacity .35s ease;
}
.hero-scroll-hint.hidden{opacity:0;pointer-events:none}

.scroll-pill{width:20px;height:36px;border:1px solid var(--g3);border-radius:12px;display:flex;justify-content:center;padding-top:6px}
.scroll-pill-dot{width:3px;height:8px;background:var(--white);border-radius:3px;animation:scrollBounce 2s ease-in-out infinite}
@keyframes scrollBounce{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(10px);opacity:.3}}

/* ===== BUTTONS ===== */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;background:var(--white);color:var(--black);
  border:none;border-radius:var(--radius-button);font-family:var(--heading);
  font-size:14px;font-weight:600;cursor:none;
  transition:all .4s var(--ease);overflow:hidden;
}
.btn:hover{box-shadow:0 0 40px rgba(255,255,255,.08)}
.btn--big{padding:20px 48px;font-size:17px}
.btn-text{position:relative;z-index:1}
.btn-arrow{display:flex;transition:transform .4s var(--ease);position:relative;z-index:1}
.btn:hover .btn-arrow{transform:translate(3px,-3px)}

/* circular fill effect */
.btn-fill-circle{
  position:absolute;width:0;height:0;
  border-radius:50%;background:rgba(0,0,0,.1);
  transform:translate(-50%,-50%);
  transition:width .6s var(--ease),height .6s var(--ease);
  pointer-events:none;
}
.btn:hover .btn-fill-circle{width:400px;height:400px}

.btn--outline{background:transparent;color:var(--white);border:1px solid var(--g2)}
.btn--outline .btn-fill-circle{background:rgba(255,255,255,.06)}
.btn--outline:hover{border-color:var(--g4)}

/* ===== MARQUEE ===== */
.marquee{padding:20px 0;overflow:hidden;white-space:nowrap;border-top:1px solid var(--g1);border-bottom:1px solid var(--g1)}
.marquee-track{
  display:inline-flex;gap:32px;animation:marquee 20s linear infinite;
  font-family:var(--heading);font-size:14px;font-weight:500;
  text-transform:uppercase;letter-spacing:2px;color:var(--g3);
}
.marquee-sep{font-size:8px;color:var(--g2)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== SECTIONS ===== */
.section{padding:160px 80px}
.wrap{max-width:1100px;margin:0 auto;position:relative}
.section-label{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--g3);margin-bottom:16px}
.section-h2{
  font-family:var(--heading);font-size:clamp(36px,5vw,68px);font-weight:800;
  line-height:1.05;letter-spacing:-2px;margin-bottom:20px;overflow:hidden;
}

/* ===== VORTEILE ===== */
.vorteil-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:80px}
.vorteil{padding:40px 24px;position:relative}
.vorteil::before{
  content:'';position:absolute;top:0;left:0;width:24px;height:24px;
  border-top:1px solid var(--g2);border-left:1px solid var(--g2);
  transition:all .5s var(--ease);
}
.vorteil:hover::before{width:36px;height:36px;border-color:var(--g4)}
.vorteil-num{font-family:var(--heading);font-size:11px;letter-spacing:2px;color:var(--g3);display:block;margin-bottom:16px}
.vorteil-sep{width:24px;height:1px;background:var(--g2);margin-bottom:20px;transition:width .5s var(--ease)}
.vorteil:hover .vorteil-sep{width:48px;background:var(--g4)}
.vorteil h3{font-family:var(--heading);font-size:18px;font-weight:700;margin-bottom:10px}
.vorteil p{font-size:14px;font-weight:300;color:var(--g4);line-height:1.7}

/* ===== HORIZONTAL SHOWCASE ===== */
.showcase-intro{
  max-width:720px;
  font-size:16px;
  line-height:1.8;
  color:var(--g4);
}
.horizontal-showcase{
  --showcase-scroll-height:200vh;
  position:relative;
  height:var(--showcase-scroll-height);
  margin-top:64px;
}
.horizontal-showcase-sticky{
  position:sticky;
  top:0;
  height:100vh;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:36px 0;
}
.showcase-viewport{
  width:100%;
  overflow:hidden;
  cursor:none!important;
  user-select:none;
  padding:0 max(24px, calc((100vw - 1120px) / 2 + 72px)) 0 clamp(24px, calc((100vw - 1120px) / 2 + 72px), 140px);
  touch-action:pan-y pan-x;
  contain:paint;
  overscroll-behavior:contain;
}
.showcase-viewport.is-dragging{cursor:none!important}
.horizontal-showcase-sticky::before,
.horizontal-showcase-sticky::after{
  content:'';
  position:absolute;
  top:0;
  bottom:0;
  width:clamp(28px, 5vw, 84px);
  z-index:2;
  pointer-events:none;
}
.horizontal-showcase-sticky::before{
  left:0;
  background:linear-gradient(90deg, rgba(0,0,0,.98), rgba(0,0,0,0));
}
.horizontal-showcase-sticky::after{
  right:0;
  background:linear-gradient(270deg, rgba(0,0,0,.98), rgba(0,0,0,0));
}
.showcase-progress{
  position:relative;
  left:0;
  right:0;
  bottom:auto;
  height:1px;
  margin:0 clamp(24px, calc((100vw - 1120px) / 2 + 72px), 140px) 24px;
  background:rgba(255,255,255,.1);
  z-index:3;
}
.showcase-progress span{
  display:block;
  height:100%;
  width:100%;
  transform-origin:left center;
  transform:scaleX(.06);
  background:linear-gradient(90deg, rgba(255,255,255,.95), rgba(255,255,255,.24));
}
.showcase-track{
  display:flex;
  gap:28px;
  align-items:stretch;
  width:max-content;
  min-width:max-content;
  overflow:visible;
  padding:6px clamp(110px, 16vw, 260px) 14px 0;
  will-change:transform;
  transform:translate3d(0,0,0);
  transition:none;
  transform-style:preserve-3d;
  backface-visibility:hidden;
  touch-action:none;
}
.showcase-card{
  flex:0 0 auto;
  scroll-snap-align:start;
  --card-shift:0px;
  --card-rotate:0deg;
  --card-scale:1;
  --visual-scale:1;
  position:relative;
  width:min(54vw, 560px);
  min-width:min(54vw, 560px);
  min-height:min(72vh, 760px);
  padding:34px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
  overflow:hidden;
  transform:translate3d(0, var(--card-shift), 0) rotate(var(--card-rotate)) scale(var(--card-scale));
  transition:transform .42s var(--ease), border-color .42s var(--ease), background .42s var(--ease), box-shadow .42s var(--ease), opacity .42s var(--ease);
  transform-origin:center center;
}
.showcase-card::before,
.showcase-card::after{
  content:'';
  position:absolute;
  pointer-events:none;
}
.showcase-card::before{
  inset:0;
  background:radial-gradient(circle at 18% 18%, rgba(255,255,255,.1), transparent 40%);
  opacity:.55;
}
.showcase-card::after{
  top:18px;
  left:18px;
  width:32px;
  height:32px;
  border-top:1px solid rgba(255,255,255,.16);
  border-left:1px solid rgba(255,255,255,.16);
}
.showcase-number{
  position:absolute;
  top:18px;
  right:20px;
  font-family:var(--heading);
  font-size:clamp(78px, 9vw, 132px);
  line-height:1;
  font-weight:900;
  letter-spacing:-.06em;
  color:rgba(255,255,255,.07);
}
.showcase-kicker{
  position:relative;
  z-index:1;
  margin-bottom:12px;
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--g3);
}
.showcase-card h3{
  position:relative;
  z-index:1;
  font-family:var(--heading);
  font-size:clamp(30px, 3.3vw, 52px);
  line-height:1.03;
  letter-spacing:-.04em;
  max-width:11ch;
  margin-bottom:16px;
}
.showcase-card p{
  position:relative;
  z-index:1;
  max-width:440px;
  font-size:15px;
  line-height:1.8;
  color:var(--g4);
}
.showcase-card:hover{
  border-color:rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.018));
  box-shadow:0 22px 58px rgba(0,0,0,.18);
}
.showcase-visual{
  position:absolute;
  top:22px;
  left:22px;
  right:22px;
  height:46%;
  border-radius:var(--radius-card);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.07);
  background:
    radial-gradient(circle at 28% 30%, rgba(255,255,255,.13), transparent 22%),
    radial-gradient(circle at 72% 58%, rgba(255,255,255,.08), transparent 20%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.008));
}
.showcase-visual::before,
.showcase-visual::after{
  content:'';
  position:absolute;
  inset:0;
}
.showcase-visual::before{
  background-image:radial-gradient(rgba(255,255,255,.18) 1px, transparent 1px);
  background-size:12px 12px;
  opacity:.22;
  transform:scale(var(--visual-scale));
  transition:transform .7s var(--ease), opacity .45s var(--ease);
}
.showcase-visual::after{
  background:linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.42));
}
.showcase-card:hover .showcase-visual::before{opacity:.3}
.showcase-visual--signal{
  background:
    linear-gradient(135deg, transparent 0 44%, rgba(255,255,255,.12) 44% 47%, transparent 47% 100%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.008));
}
.showcase-visual--zoom{
  background:
    radial-gradient(circle at center, rgba(255,255,255,.1), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.008));
}
.showcase-visual--focus{
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.14), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.008));
}
.showcase-visual--flow{
  background:
    linear-gradient(125deg, transparent 0 36%, rgba(255,255,255,.1) 36% 39%, transparent 39% 100%),
    radial-gradient(circle at 72% 42%, rgba(255,255,255,.1), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.008));
}
.showcase-visual--frame{
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.008));
}
.showcase-visual--frame::after{
  background:
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.5)),
    linear-gradient(90deg, transparent 0 18%, rgba(255,255,255,.08) 18% 19%, transparent 19% 81%, rgba(255,255,255,.08) 81% 82%, transparent 82% 100%);
}
.showcase-logo-mark{
  position:absolute;
  left:50%;
  top:50%;
  width:min(56%, 240px);
  transform:translate(-50%, -50%) scale(var(--visual-scale));
  opacity:.18;
  filter:brightness(0) invert(1);
  transition:transform .7s var(--ease), opacity .45s var(--ease);
  z-index:1;
  pointer-events:none;
}
.showcase-card:hover .showcase-logo-mark{opacity:.28}
.showcase-visual--logo::before{opacity:.16}
.bracket{position:absolute;width:20px;height:20px;transition:all .5s var(--ease)}
.bracket-tl{top:0;left:0;border-top:1px solid var(--g1);border-left:1px solid var(--g1)}
.bracket-br{bottom:0;right:0;border-bottom:1px solid var(--g1);border-right:1px solid var(--g1)}

/* ===== TIMELINE ===== */
.ablauf-intro{font-size:16px;font-weight:300;color:var(--g4);max-width:500px;line-height:1.8;margin-bottom:80px}
.timeline{position:relative;padding-left:80px}
.timeline-line{position:absolute;left:24px;top:0;bottom:0;width:1px;background:var(--g1)}
.timeline-fill{width:100%;height:0;background:linear-gradient(to bottom,var(--white),var(--g3));transition:height .05s linear}
.tl-step{padding:32px 0;display:flex;align-items:flex-start;gap:32px;opacity:.25;transition:opacity .6s var(--ease);position:relative}
.tl-step.active{opacity:1}
.tl-dot{position:absolute;left:-80px;top:36px;width:48px;height:48px;display:flex;align-items:center;justify-content:center}
.tl-dot-inner{width:8px;height:8px;border-radius:50%;border:1px solid var(--g2);background:var(--black);transition:all .5s var(--ease)}
.tl-step.active .tl-dot-inner{background:var(--white);border-color:var(--white);box-shadow:0 0 16px rgba(255,255,255,.3)}
.tl-num{font-family:var(--heading);font-size:11px;letter-spacing:2px;color:var(--g3);display:block;margin-bottom:8px}
.tl-body h3{font-family:var(--heading);font-size:22px;font-weight:700;margin-bottom:10px}
.tl-body p{font-size:15px;font-weight:300;color:var(--g4);max-width:440px;line-height:1.8}

/* ===== LEISTUNGEN ===== */
.leistung-grid{margin-top:80px;display:grid;grid-template-columns:repeat(2,1fr);gap:0}
.leistung{padding:48px;position:relative}
.leistung::before{content:'';position:absolute;top:0;left:0;width:20px;height:20px;border-top:1px solid var(--g1);border-left:1px solid var(--g1);transition:all .5s var(--ease)}
.leistung:hover::before{width:32px;height:32px;border-color:var(--g3)}
.leistung-head{display:flex;align-items:baseline;gap:16px;margin-bottom:24px}
.leistung-num{font-family:var(--heading);font-size:11px;letter-spacing:2px;color:var(--g3)}
.leistung h3{font-family:var(--heading);font-size:22px;font-weight:700}
.leistung li{font-size:14px;font-weight:300;color:var(--g4);padding:8px 0;transition:color .3s}
.leistung:hover li{color:var(--g5)}
.leistung-rule{width:32px;height:1px;background:var(--g1);margin-top:24px;transition:width .5s var(--ease)}
.leistung:hover .leistung-rule{width:64px;background:var(--g3)}
.leistung.scroll-float,
.vorteil.scroll-float,
.ueber-logo-wrap.scroll-float{
  transform:translate3d(0, var(--float-y, 0px), 0);
}

/* ===== ÜBER ===== */
.ueber-grid{display:grid;grid-template-columns:280px 1fr;gap:80px;margin-top:80px;align-items:start}
.ueber-logo-wrap{position:relative;padding:48px;display:flex;align-items:center;justify-content:center}
.ueber-logo{width:160px;height:160px;border-radius:50%;filter:invert(1)}
.ueber-body p{font-size:16px;font-weight:300;color:var(--g5);line-height:1.8;margin-bottom:24px}
.fact-row{display:flex;gap:40px;margin-top:40px}
.fact{display:flex;flex-direction:column}
.fact-val{font-family:var(--heading);font-size:28px;font-weight:800;letter-spacing:-1px}
.fact-label{font-size:12px;color:var(--g3);letter-spacing:1px;text-transform:uppercase;margin-top:4px}

/* ===== BIG CTA ===== */
.bigcta{padding:200px 80px;text-align:center;position:relative;overflow:hidden}
.bigcta-wrap{display:flex;flex-direction:column;align-items:center}
.bigcta-h2{font-family:var(--heading);font-size:clamp(44px,7vw,90px);font-weight:900;line-height:1.05;letter-spacing:-3px;overflow:hidden}
.bigcta-h2--stroke{-webkit-text-stroke:1.5px var(--white);-webkit-text-fill-color:transparent}
.bigcta .btn{margin-top:48px}

/* ===== FOOTER ===== */
.footer{padding:80px 80px 120px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;position:relative}
.footer-top::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--g1),var(--g2),var(--g1))}
.footer-brand{display:flex;align-items:center;gap:12px}
.footer-brand img{border-radius:50%}
.footer-brand span{font-family:var(--heading);font-size:20px;font-weight:700}
.footer-seo-copy{margin-top:8px;max-width:320px;font-size:12px;line-height:1.6;color:var(--g3)}
.footer-col{display:flex;flex-direction:column;gap:8px}
.footer-col-title{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--g3);margin-bottom:8px}
.footer-col a{font-size:14px;color:var(--g4);transition:color .3s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{display:flex;justify-content:space-between;padding-top:24px;font-size:12px;color:var(--g3)}
.footer-bottom a{transition:color .3s}
.footer-bottom a:hover{color:var(--white)}

/* ===== KONTAKT PAGE ===== */
.kontakt-page{min-height:100vh;padding:180px 80px 120px;position:relative}
.kontakt-h1{font-family:var(--heading);font-size:clamp(44px,6vw,80px);font-weight:900;letter-spacing:-3px;margin-bottom:16px;overflow:hidden}
.kontakt-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;margin-top:64px}
.kontakt-info-block{margin-bottom:28px}
.kontakt-info-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--g3);display:block;margin-bottom:4px}
.kontakt-info-val{font-size:16px;font-weight:400;display:block;transition:color .3s}
a.kontakt-info-val:hover{color:var(--g5)}
.kontakt-form{display:flex;flex-direction:column;gap:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.form-field{position:relative}
.form-field label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--g3);display:block;margin-bottom:8px}
.form-field input,.form-field textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--g1);padding:12px 0;color:var(--white);font-family:var(--font);font-size:15px;font-weight:300;outline:none;transition:border-color .4s;cursor:none}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--g2)}
.form-field input:focus,.form-field textarea:focus{border-color:var(--g4)}
.form-field textarea{min-height:150px;resize:vertical}
.field-line{position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--white);transition:width .6s var(--ease)}
.form-field input:focus~.field-line,.form-field textarea:focus~.field-line{width:100%}
.form-hint{font-size:13px;color:var(--g3);margin-top:4px}
.form-hint a{text-decoration:underline;text-underline-offset:3px}
.form-hint a:hover{color:var(--white)}
.form-success{text-align:center;padding:48px 0}
.form-success h3{font-family:var(--heading);font-size:28px;font-weight:700;margin-bottom:12px}
.form-success p{color:var(--g4);margin-bottom:12px}
.form-success a{text-decoration:underline;color:var(--g4)}
.form-error{text-align:center;padding:32px 0;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.form-error h3{font-family:var(--heading);font-size:24px;font-weight:700;margin-bottom:12px}
.form-error p{color:var(--g4);margin-bottom:0}
.form-error a{text-decoration:underline;color:var(--g4)}
.kontakt-form .btn[disabled]{opacity:.7;pointer-events:none}

/* Legal pages */
.legal-page{min-height:100vh;padding:180px 80px 120px}
.legal-page h1{font-family:var(--heading);font-size:clamp(36px,5vw,60px);font-weight:800;letter-spacing:-2px;margin-bottom:40px}
.legal-page h2{font-family:var(--heading);font-size:22px;font-weight:700;margin:40px 0 16px}
.legal-page p,.legal-page li{font-size:15px;font-weight:300;color:var(--g5);line-height:1.8;margin-bottom:12px}
.legal-page a{text-decoration:underline;text-underline-offset:3px;transition:color .3s}
.legal-page a:hover{color:var(--white)}

/* ===== ANIMATIONS ===== */
.anim{will-change:transform,opacity,filter,clip-path}
.anim[data-scroll-x]{--scroll-x:0px}

.anim[data-anim="fade"]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.anim[data-anim="fade"].visible{opacity:1;transform:translateY(0)}

.anim[data-anim="slide-up"]{opacity:0;transform:translateY(42px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.anim[data-anim="slide-up"].visible{opacity:1;transform:translateY(0)}

.anim[data-anim="blur-up"]{opacity:0;filter:blur(14px);transform:translateY(calc(22px + var(--float-y, 0px))) scale(.985);transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease)}
.anim[data-anim="blur-up"].visible{opacity:1;filter:blur(0);transform:translateY(var(--float-y, 0px)) scale(1)}

.anim[data-anim="fade-right"]{opacity:0;transform:translate3d(-36px, var(--float-y, 0px), 0);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.anim[data-anim="fade-right"].visible{opacity:1;transform:translate3d(0, var(--float-y, 0px), 0)}

.anim[data-anim="fade-left"]{opacity:0;transform:translate3d(36px, var(--float-y, 0px), 0);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.anim[data-anim="fade-left"].visible{opacity:1;transform:translate3d(0, var(--float-y, 0px), 0)}

.anim[data-anim="soft-zoom"]{opacity:0;transform:translateY(calc(18px + var(--float-y, 0px))) scale(.94);filter:blur(8px);transition:opacity .85s var(--ease),transform .85s var(--ease),filter .85s var(--ease)}
.anim[data-anim="soft-zoom"].visible{opacity:1;transform:translateY(var(--float-y, 0px)) scale(1);filter:blur(0)}

.anim[data-anim="clip-up"]{opacity:0;clip-path:inset(0 0 100% 0);transform:translateY(18px);transition:opacity .9s var(--ease),transform .9s var(--ease),clip-path .95s var(--ease)}
.anim[data-anim="clip-up"].visible{opacity:1;clip-path:inset(0 0 0 0);transform:translateY(0)}


.anim[data-anim="mask-side"]{
  opacity:0;
  clip-path:inset(0 100% 0 0);
  transform:translate3d(calc(var(--scroll-x, 0px) - 18px), 0, 0);
  transition:opacity .85s var(--ease),transform .95s var(--ease),clip-path .95s var(--ease);
}
.anim[data-anim="mask-side"].visible{
  opacity:1;
  clip-path:inset(0 0 0 0);
  transform:translate3d(var(--scroll-x, 0px), 0, 0);
}

.anim[data-anim="drift-fade"]{
  opacity:0;
  filter:blur(10px);
  transform:translate3d(calc(var(--scroll-x, 0px) * .55), 18px, 0) scale(.985);
  transition:opacity .9s var(--ease),transform 1s var(--ease),filter .9s var(--ease);
}
.anim[data-anim="drift-fade"].visible{
  opacity:1;
  filter:blur(0);
  transform:translate3d(var(--scroll-x, 0px), 0, 0) scale(1);
}

.anim[data-anim="float-in"]{
  opacity:0;
  filter:blur(8px);
  transform:translate3d(calc(var(--scroll-x, 0px) * -.45), 14px, 0) scale(.992);
  transition:opacity .85s var(--ease),transform .95s var(--ease),filter .85s var(--ease);
}
.anim[data-anim="float-in"].visible{
  opacity:1;
  filter:blur(0);
  transform:translate3d(var(--scroll-x, 0px), 0, 0) scale(1);
}

.anim[data-anim="zoom-in-soft"]{
  opacity:0;
  filter:blur(10px);
  transform:translate3d(var(--scroll-x, 0px), 22px, 0) scale(.9);
  transition:opacity .9s var(--ease), transform 1s var(--ease), filter .9s var(--ease);
}
.anim[data-anim="zoom-in-soft"].visible{
  opacity:1;
  filter:blur(0);
  transform:translate3d(var(--scroll-x, 0px), 0, 0) scale(1);
}

.anim[data-anim="zoom-out-soft"]{
  opacity:0;
  filter:blur(8px);
  transform:translate3d(var(--scroll-x, 0px), -12px, 0) scale(1.06);
  transition:opacity .88s var(--ease), transform .98s var(--ease), filter .88s var(--ease);
}
.anim[data-anim="zoom-out-soft"].visible{
  opacity:1;
  filter:blur(0);
  transform:translate3d(var(--scroll-x, 0px), 0, 0) scale(1);
}

.anim[data-anim="reveal"]{overflow:hidden;position:relative}
.anim[data-anim="reveal"]::after{
  content:'';position:absolute;inset:0;background:var(--black);
  transform:scaleX(1);transform-origin:right;
  transition:transform 1s var(--ease);
}
.anim[data-anim="reveal"].visible::after{transform:scaleX(0);transform-origin:left}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .vorteil-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .ueber-grid{grid-template-columns:1fr;gap:48px}
  .showcase-card{width:min(72vw, 560px);min-width:min(72vw, 560px)}
}
@media(max-width:768px){
  body{cursor:auto}
  a,button,[href],input,textarea,select,summary,label,.btn,.nav-cta,.contact-bar{cursor:auto!important}
  .cursor{display:none!important}
  .side-nav{display:none}
  .nav{padding:16px 24px}
  .nav.scrolled{padding:12px 24px}
  .nav.scrolled::after{left:24px;right:24px}
  .nav-center{display:none}
  .burger{display:flex}
  .section{padding:100px 24px}
  .bigcta{padding:120px 24px}
  .kontakt-page,.legal-page{padding:140px 24px 80px}
  .footer{padding:60px 24px 108px}
  .vorteil-grid,.leistung-grid{grid-template-columns:1fr}
  .kontakt-layout,.form-row{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:24px}
  .footer-bottom{flex-direction:column;gap:8px}
  .timeline{padding-left:56px}
  .tl-dot{left:-56px}
  .contact-bar{bottom:16px;min-width:min(230px, calc(100vw - 24px));padding:12px 24px;font-size:12px}
  .horizontal-showcase{margin-top:40px}
  .horizontal-showcase-sticky{padding:20px 0 0;height:100svh}
  .showcase-progress{margin:0 24px 18px}
  .showcase-viewport{padding:0 24px;overflow:hidden}
  .showcase-track{gap:16px;padding:0 28vw 8px 0}
  .showcase-card{width:min(86vw, 420px);min-width:min(86vw, 420px);min-height:auto;padding:30px 22px 26px;opacity:1!important}
  .showcase-visual{position:relative;top:auto;left:auto;right:auto;height:200px;margin-bottom:22px}
  .showcase-visual,.showcase-visual--logo,.showcase-visual--signal,.showcase-visual--zoom,.showcase-visual--focus,.showcase-visual--flow,.showcase-visual--frame{width:100%;height:200px}
  .showcase-number{font-size:72px}
}

@media(max-width:480px){
  .bigcta-h2{letter-spacing:-1.5px}
  .fact-row{flex-direction:column;gap:20px}
}


@media (max-width: 768px){
  .logo-reveal{padding:0 18px}
  .logo-reveal-img{width:min(98vw, 760px)}
  .logo-reveal-text{font-size:clamp(22px,8vw,36px);letter-spacing:.08em;max-width:96vw}
}

@media (prefers-reduced-motion: reduce){
  .showcase-card,.leistung.scroll-float,.vorteil.scroll-float,.ueber-logo-wrap.scroll-float{transform:none!important}
}


.sr-only{
  position:absolute !important;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}



/* ===== SERVICE CLUSTER ===== */
.section--compact{padding-top:110px;padding-bottom:120px}
.service-cluster-copy{max-width:860px;color:var(--g5);font-size:18px;line-height:1.9}
.service-cluster-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:42px}
.service-cluster-card{
  display:flex;flex-direction:column;gap:14px;padding:28px;border:1px solid var(--g2);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
  transition:transform .45s var(--ease),border-color .3s,background .3s;
}
.service-cluster-card:hover{transform:translateY(-6px);border-color:var(--g4);background:rgba(255,255,255,.03)}
.service-cluster-kicker{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--g3)}
.service-cluster-card h3{font-family:var(--heading);font-size:28px;line-height:1.1}
.service-cluster-card p{color:var(--g5);font-size:15px;line-height:1.8}
.service-cluster-link{margin-top:auto;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--g4)}
.service-links-intro{margin-top:30px;color:var(--g4);font-size:14px}
.service-inline-links{display:flex;gap:18px;flex-wrap:wrap;margin-top:14px}
.service-inline-links a{
  padding:12px 18px;border:1px solid var(--g2);font-size:14px;color:var(--g5);
  border-radius:0;
  transition:border-color .3s,color .3s,transform .3s;
}
.service-inline-links a:hover{border-color:var(--g4);color:var(--white);transform:translateY(-2px)}

/* ===== SERVICE PAGES ===== */
.service-page{
  position:relative;
  min-height:100vh;
  padding:170px 80px 110px;
}
.service-page::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.05), transparent 32%),
    radial-gradient(circle at bottom left, rgba(255,255,255,.03), transparent 28%);
  pointer-events:none;
}
.service-page .wrap{position:relative;z-index:1;max-width:1260px}
.service-hero{display:grid;grid-template-columns:minmax(0,1.12fr) minmax(320px,.72fr);gap:96px;align-items:start}
.service-page h1{font-family:var(--heading);font-size:clamp(42px,6vw,78px);line-height:1.02;letter-spacing:-3px;font-weight:900;max-width:13ch}
.service-lead{margin-top:34px;max-width:34ch;font-size:18px;line-height:2.08;color:var(--g5)}
.service-hero-card{
  padding:30px;
  border:1px solid var(--g2);
  border-radius:var(--radius-panel);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  box-shadow:0 18px 60px rgba(0,0,0,.18);
}
.service-hero-card span{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--g3);margin-bottom:10px}
.service-hero-card p{font-size:15px;color:var(--g5);line-height:1.8}
.service-hero-points{display:grid;gap:14px;margin-top:22px}
.service-hero-point{
  padding:14px 16px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-card);
  background:rgba(255,255,255,.02);
}
.service-hero-point strong{display:block;font-family:var(--heading);font-size:18px;line-height:1.15;margin-bottom:4px}
.service-hero-point small{display:block;color:var(--g4);font-size:13px;line-height:1.7}
.service-cta-row{display:flex;gap:18px;flex-wrap:wrap;margin-top:34px}
.service-section{margin-top:86px}
.service-section h2{font-family:var(--heading);font-size:clamp(28px,4vw,44px);letter-spacing:-1.8px;line-height:1.08;margin-bottom:20px;max-width:16ch}
.service-section p{color:var(--g5);line-height:1.9}
.service-kicker{display:block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--g3);margin-bottom:16px}
.service-highlight-band{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:38px}
.service-highlight-item{
  padding:22px 22px 20px;
  border:1px solid var(--g2);
  border-radius:var(--radius-card);
  background:rgba(255,255,255,.018);
}
.service-highlight-item strong{display:block;font-family:var(--heading);font-size:26px;line-height:1.02;margin-bottom:8px}
.service-highlight-item p{font-size:14px;color:var(--g4);line-height:1.75}
.service-section--split .service-split{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:start}
.service-copy-card,.service-stack-card,.service-step,.service-card,.service-outro-card,.service-faq-item,.service-accordion details{
  border:1px solid var(--g2);
  border-radius:var(--radius-panel);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.012));
}
.service-copy-card{padding:30px}
.service-copy-card p + p{margin-top:14px}
.service-stack{display:grid;gap:16px}
.service-stack-card{padding:22px}
.service-stack-card h3{font-family:var(--heading);font-size:22px;line-height:1.08;margin-bottom:8px}
.service-stack-card p{font-size:14px;color:var(--g5)}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:28px}
.service-grid--2{grid-template-columns:repeat(2,1fr)}
.service-card{padding:26px;min-height:100%}
.service-card h3{font-family:var(--heading);font-size:24px;line-height:1.1;margin-bottom:10px}
.service-card p{font-size:15px;color:var(--g5)}
.service-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.service-card-index{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--g3)}
.service-tag-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.service-tag{
  padding:9px 14px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:0;
  font-size:13px;
  color:var(--g4);
  background:rgba(255,255,255,.018);
}
.service-list{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:24px}
.service-list li{
  padding:18px 20px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-card);
  color:var(--g5);
  font-size:15px;
  background:rgba(255,255,255,.015);
}
.service-process{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:28px}
.service-step{padding:24px}
.service-step-number{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.12);font-family:var(--heading);font-size:18px;margin-bottom:18px}
.service-step h3{font-family:var(--heading);font-size:22px;line-height:1.1;margin-bottom:8px}
.service-step p{font-size:14px;color:var(--g5)}
.service-accordion{display:grid;gap:16px;margin-top:24px}
.service-accordion details{padding:0;overflow:hidden}
.service-accordion summary{
  list-style:none;
  display:flex;
  justify-content:space-between;
  gap:24px;
  align-items:center;
  padding:22px 24px;
  font-family:var(--heading);
  font-size:21px;
  line-height:1.2;
  cursor:pointer;
}
.service-accordion summary::-webkit-details-marker{display:none}
.service-accordion summary::after{content:'+';font-size:28px;line-height:1;color:var(--g4);transition:transform .3s var(--ease), color .3s ease}
.service-accordion details[open] summary::after{transform:rotate(45deg);color:var(--white)}
.service-accordion-content{padding:0 24px 22px;color:var(--g5);font-size:15px;line-height:1.85;max-width:900px}
.service-breadcrumbs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px;color:var(--g4);font-size:13px}
.service-breadcrumbs a{color:var(--g4)}
.service-breadcrumbs a:hover{color:var(--white)}
.service-mini-links{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.service-mini-links a{font-size:14px;color:var(--g4);text-decoration:underline;text-underline-offset:4px}
.service-mini-links a:hover{color:var(--white)}
.service-outro-card{padding:34px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:end}
.service-outro-card h2{margin-bottom:12px;max-width:12ch}
.service-outro-card p{max-width:760px}

@media(max-width:1200px){
  .service-highlight-band{grid-template-columns:repeat(2,1fr)}
  .service-process{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:1024px){
  .service-cluster-grid,.service-grid{grid-template-columns:1fr 1fr}
  .service-hero,.service-section--split .service-split,.service-outro-card{grid-template-columns:1fr}
}
@media(max-width:768px){
  .section--compact{padding-top:80px;padding-bottom:90px}
  .service-page{padding:140px 24px 80px}
  .service-cluster-copy,.service-lead{font-size:16px}
  .service-cluster-grid,.service-grid,.service-grid--2,.service-list,.service-highlight-band,.service-process{grid-template-columns:1fr}
  .service-copy-card,.service-stack-card,.service-step,.service-card,.service-hero-card,.service-outro-card{padding:22px}
  .service-accordion summary{font-size:18px;padding:18px 20px}
  .service-accordion-content{padding:0 20px 20px}
}



/* ===== MINIMAL SPACE & FLOW REFINEMENTS ===== */
.section-h2{margin-bottom:28px}
.service-page .wrap{max-width:1220px}
.service-cluster-grid,.vorteil-grid,.leistung-grid,.service-grid,.service-highlight-band,.service-process{gap:20px}
.service-cluster-card,.vorteil,.leistung,
.service-hero-card,.service-copy-card,.service-stack-card,.service-step,.service-card,.service-highlight-item,.service-outro-card,.service-accordion details,
.service-rail-card,.service-mosaic-card,.index-faq-intro{
  position:relative;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.016), rgba(255,255,255,.008));
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  box-shadow:none;
  overflow:hidden;
}
.service-cluster-card::before,.vorteil::before,.leistung::before,
.service-hero-card::before,.service-copy-card::before,.service-stack-card::before,.service-step::before,.service-card::before,.service-highlight-item::before,.service-outro-card::before,
.service-accordion details::before,.service-rail-card::before,.service-mosaic-card::before,.index-faq-intro::before{
  content:'';
  position:absolute;
  top:0;
  left:24px;
  right:24px;
  height:1px;
  background:linear-gradient(90deg, rgba(255,255,255,.2), rgba(255,255,255,0));
  pointer-events:none;
}
.service-cluster-copy,.showcase-intro,.ablauf-intro,.index-faq-copy{max-width:62ch;line-height:1.95}
.vorteil-grid,.leistung-grid{margin-top:96px}
.vorteil,.leistung{padding:38px 30px 34px}
.vorteil p,.leistung li,.tl-body p,.ueber-body p{max-width:36ch}
.ueber-grid{gap:96px}
.fact-row{gap:48px;margin-top:52px}
.service-page{padding:190px 80px 140px}
.service-hero{gap:78px;align-items:start}
.service-page h1{max-width:11.5ch;line-height:1}
.service-lead{max-width:58ch;font-size:18px;line-height:2.02;margin-top:28px}
.service-cta-row{margin-top:40px}
.service-mini-links{margin-top:34px;gap:18px}
.service-mini-links a{padding-bottom:2px}
.service-highlight-band{margin-top:82px}
.service-highlight-item{padding:30px 26px 28px;border-radius:var(--radius-panel);min-height:170px}
.service-highlight-item strong{margin-bottom:14px}
.service-section{margin-top:156px;content-visibility:auto;contain-intrinsic-size:1px 860px}
.service-section h2{margin-bottom:26px;max-width:14ch}
.service-section p,.service-copy-card p,.service-stack-card p,.service-card p,.service-step p,.service-accordion-content,.service-outro-card p{max-width:58ch;line-height:1.95}
.service-copy-card{padding:48px 42px;min-height:100%}
.service-copy-card p + p{margin-top:26px}
.service-stack{gap:18px}
.service-stack-card{padding:30px 26px 24px}
.service-grid{margin-top:46px}
.service-card{padding:38px 32px 30px}
.service-list{gap:18px;margin-top:30px}
.service-list li{padding:20px 22px;border-radius:22px}
.service-process{margin-top:40px}
.service-step{padding:36px 30px 28px;min-height:240px}
.service-step-number{margin-bottom:26px}
.service-accordion{gap:20px;margin-top:42px}
.service-accordion summary{padding:28px 30px;font-size:20px}
.service-accordion-content{padding:0 30px 30px}
.service-outro-card{padding:48px 42px;align-items:center}
.service-section-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,420px);gap:28px;align-items:end;margin-bottom:18px}
.service-section-note{color:var(--g4);font-size:15px;line-height:1.9;max-width:34ch}
.service-rail-section{margin-top:124px}
.service-rail-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:26px}
.service-rail-note{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--g3)}
.service-rail{
  display:grid;
  margin-top:18px;
  grid-auto-flow:column;
  grid-auto-columns:minmax(260px, 30vw);
  gap:18px;
  overflow-x:auto;
  overscroll-behavior-x:contain;
  scroll-snap-type:x proximity;
  padding:8px 4px 18px;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.18) transparent;
  mask-image:linear-gradient(90deg, transparent 0, #000 3%, #000 97%, transparent 100%);
}
.service-rail::-webkit-scrollbar{height:8px}
.service-rail::-webkit-scrollbar-track{background:transparent}
.service-rail::-webkit-scrollbar-thumb{background:rgba(255,255,255,.16);border-radius:999px}
.service-rail-card{scroll-snap-align:start;min-height:280px;padding:36px 32px 30px;border-radius:var(--radius-panel)}
.service-rail-card span{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--g3);margin-bottom:18px}
.service-rail-card h3{font-family:var(--heading);font-size:30px;line-height:1.02;letter-spacing:-.04em;max-width:10ch;margin-bottom:16px}
.service-rail-card p{font-size:15px;color:var(--g5);line-height:1.9;max-width:30ch}
.service-rail-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.14)}
.service-mosaic{display:grid;grid-template-columns:1.18fr .82fr .82fr;gap:24px;margin-top:42px}
.service-mosaic-card{padding:32px 28px 28px;border-radius:var(--radius-panel);min-height:240px}
.service-mosaic-card--wide{grid-row:span 2;min-height:560px;display:flex;flex-direction:column;justify-content:space-between}
.service-mosaic-card--wide p{max-width:34ch}
.service-mosaic-card h3{font-family:var(--heading);font-size:clamp(26px,2.6vw,40px);line-height:1.04;letter-spacing:-.04em;margin-bottom:16px;max-width:11ch}
.service-mosaic-card p{font-size:15px;color:var(--g5);line-height:1.95}
.service-mosaic-list{display:grid;gap:18px;margin-top:28px}
.service-mosaic-list li{padding-top:18px;border-top:1px solid rgba(255,255,255,.08);color:var(--g4);line-height:1.85}
.service-mosaic-eyebrow{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--g3);margin-bottom:18px}
.service-mosaic-stat{font-family:var(--heading);font-size:clamp(44px,5vw,88px);line-height:1;letter-spacing:-.06em;color:rgba(255,255,255,.88);margin-top:auto}
.service-mosaic-stat small{display:block;font-family:var(--font);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--g3);margin-top:14px}
.index-faq-section{padding-top:72px;content-visibility:auto;contain-intrinsic-size:1px 720px}
.index-faq-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,430px);gap:34px;align-items:end;margin-bottom:44px}
.index-faq-layout{display:grid;grid-template-columns:minmax(260px,.82fr) minmax(0,1.18fr);gap:28px;align-items:start}
.index-faq-intro{padding:34px 28px 30px;border-radius:var(--radius-panel);min-height:100%}
.index-faq-intro h3{font-family:var(--heading);font-size:28px;line-height:1.05;letter-spacing:-.04em;margin-bottom:16px;max-width:10ch}
.index-faq-intro p{font-size:15px;color:var(--g5);line-height:1.9;max-width:28ch}
.index-faq-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.index-faq-tags span{padding:10px 14px;border:1px solid rgba(255,255,255,.08);border-radius:0;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--g4)}
.index-faq .service-accordion{margin-top:0}
.index-faq .service-accordion summary{font-size:19px}
@media(max-width:1200px){
  .service-mosaic{grid-template-columns:1fr 1fr}
  .service-mosaic-card--wide{grid-column:1 / -1;grid-row:auto;min-height:320px}
}
@media(max-width:1024px){
  .index-faq-head,.index-faq-layout,.service-section-head{grid-template-columns:1fr}
  .service-rail{grid-auto-columns:minmax(240px, 64vw)}
}
@media(max-width:768px){
  .vorteil-grid,.leistung-grid{gap:18px;margin-top:64px}
  .vorteil,.leistung{padding:28px 22px 24px}
  .service-page{padding:152px 24px 96px}
  .service-section{margin-top:88px}
  .service-highlight-item,.service-copy-card,.service-stack-card,.service-step,.service-card,.service-hero-card,.service-outro-card,.service-rail-card,.service-mosaic-card,.index-faq-intro{padding:24px 20px 22px}
  .service-highlight-item{min-height:auto}
  .service-accordion summary{padding:20px;font-size:18px}
  .service-accordion-content{padding:0 20px 20px}
  .service-rail{grid-auto-columns:82vw;mask-image:none}
  .service-mosaic{grid-template-columns:1fr}
  .service-mosaic-card--wide{min-height:auto}
}


/* ===== MINIMAL CONTAINER TUNING ===== */
.service-hero-card,.service-copy-card,.service-stack-card,.service-step,.service-card,.service-highlight-item,.service-outro-card,.service-accordion details,.service-rail-card,.service-mosaic-card,.index-faq-intro,.service-hero-point,.service-list li{border-radius:var(--radius-panel)}
.service-highlight-item,.service-card,.service-step,.service-stack-card,.service-copy-card,.service-hero-card,.service-outro-card,.service-accordion details,.service-rail-card,.service-mosaic-card,.index-faq-intro{background:linear-gradient(180deg, rgba(255,255,255,.014), rgba(255,255,255,.006));border-color:rgba(255,255,255,.085)}
.service-grid .service-card:nth-child(odd),.service-process .service-step:nth-child(odd),.service-stack-card:nth-child(odd){background:linear-gradient(180deg, rgba(255,255,255,.016), rgba(255,255,255,.004))}
.service-grid .service-card:nth-child(even),.service-process .service-step:nth-child(even),.service-stack-card:nth-child(even){background:linear-gradient(180deg, rgba(255,255,255,.010), rgba(255,255,255,.003))}
.service-rail-card,.service-mosaic-card,.service-highlight-item{position:relative}
.service-rail-card::after,.service-mosaic-card::after,.service-highlight-item::after,.service-card::after,.service-step::after,.service-copy-card::after,.service-stack-card::after,.service-hero-card::after,.service-outro-card::after,.service-accordion details::after,.index-faq-intro::after{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,0));opacity:.45;pointer-events:none}
.service-hero-card{max-width:420px;justify-self:end;padding:34px 30px 32px}
.service-hero-points{gap:16px;margin-top:26px}
.service-hero-point{padding:18px 18px;background:rgba(255,255,255,.012);border-color:rgba(255,255,255,.075)}
.service-highlight-item{min-height:186px;padding:34px 30px 30px}
.service-section h2{max-width:11ch}
.service-rail-card h3,.service-mosaic-card h3{max-width:11ch}
.service-section p,.service-copy-card p,.service-stack-card p,.service-card p,.service-step p,.service-accordion-content,.service-outro-card p,.service-mosaic-card p{max-width:30ch}
.service-copy-card p{max-width:34ch}
.service-mosaic-list{gap:20px;margin-top:32px}
.service-mosaic-list li{padding-top:20px;max-width:28ch}
.section,.service-section,.index-faq-section{contain:layout paint style}
@media(max-width:1024px){.service-hero-card{max-width:none;justify-self:start}.service-section{margin-top:124px}}
@media(max-width:768px){.service-page{padding:164px 24px 112px}.service-section{margin-top:96px}.service-hero{gap:44px}.service-lead{max-width:none}.service-copy-card,.service-card,.service-step,.service-rail-card,.service-mosaic-card,.service-outro-card,.service-highlight-item,.service-stack-card,.service-hero-card,.index-faq-intro{padding:28px 22px 24px}.service-accordion summary{padding:22px}.service-accordion-content{padding:0 22px 22px}}


/* ===== FINAL SPACING OVERRIDES ===== */
.service-page{padding:214px 88px 168px}
.service-page .wrap{max-width:1260px}
.service-hero{grid-template-columns:minmax(0,1.12fr) minmax(320px,.72fr);gap:96px;align-items:start}
.service-lead{max-width:34ch;font-size:18px;line-height:2.08;margin-top:34px}
.service-rail{gap:24px}
.service-mosaic-card{padding:40px 34px 32px;min-height:260px}
.index-faq-intro{padding:40px 34px 34px}
.index-faq-layout{gap:28px}
.index-faq-head{margin-bottom:44px}
@media(max-width:1024px){.service-page{padding:192px 56px 140px}.service-hero{grid-template-columns:1fr;gap:56px}}
@media(max-width:768px){.service-page{padding:164px 24px 112px}.service-hero{gap:44px}.service-lead{max-width:none;line-height:1.95}.service-rail{gap:18px}.service-mosaic-card{padding:28px 22px 24px;min-height:auto}.index-faq-intro{padding:28px 22px 24px}}


/* ===== LIGHTER SERVICE SURFACES ===== */
.service-copy-card,
.service-stack-card,
.service-card,
.service-step,
.service-outro-card{
  background:transparent!important;
  border-color:transparent!important;
  box-shadow:none!important;
}
.service-copy-card::before,
.service-copy-card::after,
.service-stack-card::before,
.service-stack-card::after,
.service-card::before,
.service-card::after,
.service-step::before,
.service-step::after,
.service-outro-card::before,
.service-outro-card::after{display:none!important}
.service-section--split .service-split{gap:44px}
.service-copy-card{padding:10px 0 6px!important}
.service-stack{gap:24px}
.service-stack-card,
.service-card,
.service-step,
.service-outro-card{
  padding-left:0!important;
  padding-right:0!important;
  padding-bottom:0!important;
  border-top:1px solid rgba(255,255,255,.08)!important;
}
.service-stack-card{padding-top:24px!important}
.service-card{padding-top:24px!important}
.service-step{padding-top:26px!important}
.service-outro-card{padding-top:30px!important;align-items:start}
.service-grid{gap:32px}
.service-process{gap:32px}
.service-card-top{margin-bottom:18px}
.service-step-number{margin-bottom:20px}
@media(max-width:768px){
  .service-section--split .service-split{gap:30px}
  .service-stack{gap:20px}
  .service-grid,.service-process{gap:24px}
  .service-stack-card,.service-card,.service-step,.service-outro-card{padding-top:22px!important}
}


.service-hero-side{max-width:420px;justify-self:end;display:grid;gap:20px}
.service-hero-summary{display:grid;gap:10px;align-content:start}
.service-hero-summary span{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--g3)}
.service-hero-summary p{font-size:15px;color:var(--g5);line-height:1.86;max-width:30ch}
.service-hero-side .service-hero-points{margin-top:0}

.footer-social-strip{position:relative;margin-top:34px;padding-top:28px}
.footer-social-strip::before{content:'';position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,var(--g1),var(--g2),var(--g1))}
.footer-social-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:16px}
.footer-social-link{display:flex;align-items:center;gap:14px;padding:16px 0;border-top:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.68);transition:color .3s ease, transform .3s ease}
.footer-social-link:hover{color:var(--white);transform:translateY(-1px)}
.footer-social-link span:last-child{display:grid;gap:3px}
.footer-social-link strong{font-size:14px;font-weight:500;letter-spacing:-.02em}
.footer-social-link small{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--g3)}
.footer-social-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid rgba(255,255,255,.1)}
.footer-social-icon svg{width:18px;height:18px}
@media(max-width:1024px){.service-hero-side{max-width:none;justify-self:start}.footer-social-grid{grid-template-columns:1fr 1fr}}
@media(max-width:768px){.footer-social-grid{grid-template-columns:1fr}.footer-social-link{padding:14px 0}.footer-social-strip{margin-top:28px;padding-top:24px}}


/* SEO landingpages & conversion updates */
.service-grid a.service-card,
.service-card[href]{
  display:block;
  color:inherit;
  text-decoration:none;
}
.service-grid a.service-card:hover,
.service-card[href]:hover{
  color:inherit;
}
.form-field select{
  width:100%;
  background:transparent;
  border:none;
  border-bottom:1px solid var(--g1);
  padding:12px 0;
  color:var(--white);
  font-family:var(--font);
  font-size:15px;
  font-weight:300;
  outline:none;
  transition:border-color .4s;
  cursor:none;
  appearance:none;
}
.form-field select:focus{
  border-color:var(--g4);
}
.form-field select option{
  color:#000;
}
.form-field select:focus~.field-line{
  width:100%;
}

.bigcta-h2--single{max-width:14ch;text-align:center}
.kontakt-intro{max-width:42ch;font-size:18px;line-height:1.95;color:var(--g5);margin-top:22px}
.kontakt-section{margin-top:108px}
.kontakt-grid{margin-top:34px}
.kontakt-section .service-accordion{margin-top:26px}
@media(max-width:768px){
  .kontakt-intro{font-size:16px;max-width:none}
  .kontakt-section{margin-top:88px}
}
