
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --c:#00e5ff;
  --m:#e040fb;
  --bg:#060809;
  --sf:#0c0f14;
  --sf2:#121620;
  --bd:rgba(255,255,255,.07);
  --tx:#edf0f8;
  --mu:#6a7a96;
  --ff:'Poppins',sans-serif;
  --fb:'Poppins',sans-serif;
  /* gradient fade helper for section bg overlays */
  --bg-rgb:6,8,9;
}

/* ── LIGHT MODE ── */
[data-theme="light"]{
  --c:#006b7a;
  --m:#7a2a9c;
  --bg:#f4f2ed;
  --sf:#ffffff;
  --sf2:#ece9e2;
  --bd:rgba(0,0,0,.1);
  --tx:#0f0e0c;
  --mu:#6a6a60;
  --bg-rgb:244,242,237;
}
/* ── LIGHT MODE COMPONENT OVERRIDES ── */
[data-theme="light"] nav.scrolled{background:rgba(244,242,237,.92);border-bottom:1px solid rgba(0,0,0,.1)}
[data-theme="light"] .btn-c{color:#fff}
[data-theme="light"] .btn-ghost{border-color:rgba(0,0,0,.18);color:var(--tx)}
[data-theme="light"] .btn-ghost:hover{background:rgba(0,0,0,.05);border-color:rgba(0,0,0,.28)}
[data-theme="light"] .mq-item{color:rgba(0,0,0,.3)}
[data-theme="light"] .mq-item:hover{color:rgba(0,0,0,.7)}
[data-theme="light"] .mq-logo img{filter:none;opacity:.55}
[data-theme="light"] .mq-logo:hover img{opacity:1;filter:none}
[data-theme="light"] .hero-sub{color:rgba(0,0,0,.5)}
[data-theme="light"] .hero-scroll{color:rgba(0,0,0,.25)}
[data-theme="light"] .scroll-chevron{border-color:rgba(0,0,0,.2)}
[data-theme="light"] .hero-reel-trigger{border-color:rgba(0,0,0,.15);background:rgba(0,0,0,.04)}
[data-theme="light"] .reel-trigger-label{color:rgba(0,0,0,.75)}
[data-theme="light"] .reel-mini-play{border-color:rgba(0,0,0,.25)}
[data-theme="light"] .faq-item{background:var(--sf);border-color:rgba(0,0,0,.08)}
[data-theme="light"] .faq-q-t{color:var(--tx)}
[data-theme="light"] .faq-a-in{color:var(--mu)}
[data-theme="light"] .price-row{background:var(--sf)}
[data-theme="light"] .price-intro-card{background:var(--sf)}
[data-theme="light"] .bafa-block{background:var(--sf2)}
[data-theme="light"] .proc-step{background:var(--sf)}
[data-theme="light"] .tmember{background:var(--sf)}
[data-theme="light"] .tmember:hover{background:var(--sf2)}
[data-theme="light"] .tcard{background:var(--sf2)}
[data-theme="light"] .port-grid .pcard{background:var(--sf2)}
[data-theme="light"] .team-section::after{background:linear-gradient(to bottom,var(--bg) 0%,transparent 22%,transparent 78%,var(--bg) 100%),linear-gradient(to right,var(--bg) 0%,transparent 18%,transparent 82%,var(--bg) 100%)}
[data-theme="light"] .pricing-section::after{background:linear-gradient(to bottom,var(--bg) 0%,transparent 20%,transparent 80%,var(--bg) 100%),linear-gradient(to right,var(--bg) 0%,transparent 18%,transparent 82%,var(--bg) 100%)}
[data-theme="light"] .faq-section::after{background:linear-gradient(to bottom,var(--bg) 0%,transparent 20%,transparent 80%,var(--bg) 100%),linear-gradient(to right,var(--bg) 0%,transparent 15%,transparent 85%,var(--bg) 100%)}
[data-theme="light"] .svc{background:var(--sf2)}
[data-theme="light"] .svc:hover{background:var(--sf)}
[data-theme="light"] .contact-section{background:var(--tx)}
[data-theme="light"] .contact-cta-top *:not(.btn-c){color:rgba(244,242,237,.9)}
[data-theme="light"] .contact-cta-sub{color:rgba(244,242,237,.55)}
[data-theme="light"] .contact-tag{color:rgba(244,242,237,.7)}
[data-theme="light"] .contact-sub{color:rgba(244,242,237,.4)}
[data-theme="light"] .contact-item{color:rgba(244,242,237,.6)}
[data-theme="light"] .contact-item:hover{color:#00e5ff}
[data-theme="light"] .contact-divider{background:rgba(244,242,237,.12)}
[data-theme="light"] .contact-item-icon{border-color:rgba(0,229,255,.25)}
[data-theme="light"] .np-theme-toggle{border-color:rgba(0,0,0,.2);color:var(--tx)}
[data-theme="light"] .np-theme-toggle:hover{border-color:var(--c);background:rgba(0,107,122,.08)}
[data-theme="light"] footer{background:var(--tx);border-top:1px solid rgba(244,242,237,.1)}
[data-theme="light"] .foot-copy,[data-theme="light"] .foot-links a,[data-theme="light"] .foot-links span{color:rgba(244,242,237,.35)}
[data-theme="light"] .foerder-section{background:var(--bg)}
[data-theme="light"] .filter-row .flt{background:transparent;border-color:rgba(0,0,0,.15);color:var(--tx)}
[data-theme="light"] .filter-row .flt.on{background:var(--tx);color:var(--bg);border-color:var(--tx)}
[data-theme="light"] .port-header .port-h,[data-theme="light"] .team-h,[data-theme="light"] .faq-h,[data-theme="light"] .price-h,[data-theme="light"] .proc-h,[data-theme="light"] .about-h2{color:var(--tx)}
[data-theme="light"] .np-word b:first-child{color:var(--c)}
[data-theme="light"] .np-word b:last-child{color:var(--m)}
[data-theme="light"] .np-mark span{background:var(--tx)}
[data-theme="light"] .m1{background:var(--c)}
[data-theme="light"] .m2{background:var(--m)}

/* Smooth theme transition – only color properties, NOT transforms/opacity (breaks animations) */
html{transition:background-color .3s ease}
body,nav,footer,.svc,.tmember,.price-row,.price-intro-card,.bafa-block,.proc-step,.tcard,.faq-item{transition:background-color .3s ease,color .3s ease,border-color .3s ease}

/* ── HERO TEXT REVEAL ANIMATION ── */
@keyframes hero-word-in {
  from { opacity: 0; transform: translateY(32px) skewY(2deg); filter: blur(4px); }
  to   { opacity: 1; transform: translateY(0)   skewY(0deg);  filter: blur(0px); }
}
@keyframes hero-fade-up {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hero-h1 .hw {
  display: inline-block;
  opacity: 0;
  animation: hero-word-in .7s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-actions { opacity: 0; animation: hero-fade-up .6s cubic-bezier(.22,1,.36,1) forwards; }

body{background:var(--bg);color:var(--tx);font-family:var(--fb);font-size:16px;line-height:1.65;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block}

/* scrollbar */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:rgba(var(--bg-rgb),0);border-radius:2px;background:var(--c);opacity:.3}

/* ── UTILITIES ── */
.con{max-width:1280px;margin:0 auto;padding:0 60px}
.tag-label{display:block;font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;background:linear-gradient(270deg,#00e5ff,var(--m),#00e5ff);background-size:200% 200%;animation:liquid-c 5s ease infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px}
.reveal{opacity:0;transform:translateY(40px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ── BUTTONS ── */
.btn-c{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;background:linear-gradient(270deg,#00e5ff,#00b8d4,#00e5c8,#40c4ff,#00e5ff);background-size:300% 300%;animation:liquid-c 5s ease infinite;color:var(--bg);font-family:var(--fb);font-weight:600;font-size:13px;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;border:none;cursor:pointer;transition:opacity .2s,transform .15s}
.btn-c:hover{opacity:.85;transform:translateY(-1px)}
.btn-m{display:inline-flex;align-items:center;gap:10px;padding:13px 30px;border:none;color:#fff;font-family:var(--fb);font-weight:600;font-size:13px;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;cursor:pointer;background:linear-gradient(270deg,#e040fb,#b000e0,#ff40c0,#c020f0,#e040fb);background-size:300% 300%;animation:liquid-m 5s ease infinite;transition:opacity .2s,transform .15s}
.btn-m:hover{opacity:.85;transform:translateY(-1px)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;padding:13px 28px;border:1px solid var(--bd);color:var(--tx);font-family:var(--fb);font-weight:500;font-size:13px;letter-spacing:.08em;text-transform:uppercase;border-radius:4px;transition:border-color .2s,background .2s;cursor:pointer}
.btn-ghost:hover{border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.04)}
.arr{display:inline-block;width:18px;height:18px;border-top:1.5px solid currentColor;border-right:1.5px solid currentColor;transform:rotate(45deg);flex-shrink:0}

/* ── NAV ── */
nav{position:fixed;inset:0 0 auto 0;z-index:300;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 60px;transition:background .3s,backdrop-filter .3s}
nav.scrolled{background:rgba(var(--bg-rgb),.9);backdrop-filter:blur(28px);border-bottom:1px solid var(--bd)}
.nav-logo{display:flex;align-items:center;gap:10px}
.np-mark{display:grid;grid-template-columns:1fr 1fr;gap:3px;width:30px;height:30px}
.np-mark span{border-radius:2px}
.m1{background:var(--c)}.m2{background:var(--m)}.m3{background:var(--m);opacity:.5}.m4{background:var(--c);opacity:.3}
.np-word{display:flex;flex-direction:column;line-height:1.1;gap:1px}
.np-word b{font-size:11px;font-weight:700;letter-spacing:.16em}
.np-word b:first-child{color:var(--c)}
.np-word b:last-child{color:var(--m)}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-links a{color:var(--mu);font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;transition:color .2s}
.nav-links a:hover{color:var(--tx)}
.nav-cta{padding:10px 22px;border:1.5px solid var(--m);color:var(--m);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;transition:background .2s,color .2s}
.nav-cta:hover{background:linear-gradient(270deg,#e040fb,#b000e0,#ff40c0);background-size:200% 200%;animation:liquid-m 4s ease infinite;color:#fff;border-color:transparent}

/* ── HERO – CINEMATIC FULLSCREEN VIDEO ── */
.hero{position:relative;height:100vh;min-height:680px;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
/* fullscreen video bg */
.hero-video-bg{position:absolute;inset:0;z-index:0;background:var(--bg)}
.hero-video-bg video{width:100%;height:100%;object-fit:cover;display:block;opacity:.7}
/* layered overlays */
.hero-video-bg::before{content:'';position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(to top, rgba(var(--bg-rgb),1) 0%, rgba(var(--bg-rgb),.75) 25%, rgba(var(--bg-rgb),.15) 60%, rgba(var(--bg-rgb),.3) 100%)}
/* subtle noise */
.hero-video-bg::after{content:'';position:absolute;inset:0;z-index:2;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");pointer-events:none}
/* content */
.hero-inner{position:relative;z-index:3;width:100%;padding:80px 60px 0}
.hero-inner .con-hero{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:flex-end}
.hero-left{max-width:780px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:16px;font-size:11px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--c)}
.h-dot{width:5px;height:5px;border-radius:50%;background:var(--c);display:inline-block;animation:pulse-dot 2s ease-in-out infinite}

@keyframes liquid-c{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
@keyframes liquid-m{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
@keyframes liquid-grad{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}
.hero-h1{font-family:var(--ff);font-weight:800;font-size:clamp(48px,7vw,108px);letter-spacing:-.025em;line-height:1.02;text-transform:uppercase;margin-bottom:28px}
.hero-h1 .grad{background:linear-gradient(270deg,#00e5ff,var(--m),#ff40c0,#00e5ff);background-size:300% 300%;animation:liquid-c 5s ease infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-bottom-row{display:flex;align-items:center;gap:32px;flex-wrap:wrap}
.hero-sub{font-size:14px;color:rgba(255,255,255,.45);line-height:1.8;font-weight:300;max-width:360px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.hero-badge{display:none}
.hero-row{display:none}
/* showreel mini trigger – bottom right */
.hero-reel-trigger{display:flex;align-items:center;gap:14px;cursor:pointer;flex-shrink:0;padding:16px 24px;border:1px solid rgba(255,255,255,.1);border-radius:4px;background:rgba(255,255,255,.04);backdrop-filter:blur(12px);transition:border-color .25s,background .25s}
.hero-reel-trigger:hover{border-color:rgba(0,229,255,.35);background:rgba(0,229,255,.06)}
.reel-mini-play{width:40px;height:40px;border-radius:50%;border:1.5px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .25s}
.hero-reel-trigger:hover .reel-mini-play{border-color:var(--c)}
.reel-mini-play svg{margin-left:3px}
.reel-trigger-text{}
.reel-trigger-label{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:2px}
.reel-trigger-sub{font-size:10px;color:var(--mu);letter-spacing:.08em}
/* scroll hint */
.hero-scroll{position:absolute;bottom:28px;right:60px;z-index:4;display:flex;align-items:center;gap:10px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.25);cursor:pointer}
.scroll-chevron{width:16px;height:16px;border-right:1px solid rgba(255,255,255,.2);border-bottom:1px solid rgba(255,255,255,.2);transform:rotate(45deg);animation:chevron-bob .9s ease-in-out infinite alternate}
@keyframes chevron-bob{from{transform:rotate(45deg) translate(0,0)}to{transform:rotate(45deg) translate(2px,2px)}}
.scroll-line{display:none}
/* lightbox */
.reel-lightbox{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s;backdrop-filter:blur(8px)}
.reel-lightbox.open{opacity:1;pointer-events:all}
.reel-lb-inner{position:relative;width:min(90vw,1200px)}
.reel-lb-inner video{width:100%;border-radius:8px;display:block;box-shadow:0 40px 100px rgba(0,0,0,.8)}
.reel-lb-close{position:absolute;top:-44px;right:0;background:none;border:none;color:rgba(255,255,255,.5);font-size:28px;cursor:pointer;line-height:1;transition:color .2s}
.reel-lb-close:hover{color:#fff}
@keyframes slide{0%{left:-100%}100%{left:100%}}

/* ── MARQUEE ── */
.marquee-wrap{overflow:hidden;padding:28px 0;border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);position:relative}
.marquee-wrap::before,.marquee-wrap::after{content:'';position:absolute;top:0;bottom:0;width:160px;z-index:2;pointer-events:none}
.marquee-wrap::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.marquee-wrap::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.mq-track{display:flex;align-items:center;width:max-content;/* animation handled by JS */}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mq-item{padding:0 48px;font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.2);white-space:nowrap;transition:color .25s;cursor:default}
.mq-item:hover{color:rgba(255,255,255,.5)}
.mq-dot{width:4px;height:4px;border-radius:50%;background:var(--m);opacity:.4;flex-shrink:0}
/* Logo image mode */
.mq-logo{padding:0 52px;display:flex;align-items:center;flex-shrink:0}
.mq-logo img{height:40px;width:auto;max-width:150px;object-fit:contain;filter:brightness(0) invert(1);opacity:.25;transition:filter .4s ease,opacity .4s ease;display:block}
.marquee-wrap:hover .mq-logo img{opacity:.45}
.mq-logo:hover img{opacity:1!important;filter:none!important}

/* ── ABOUT ── */
/* ── ABOUT ── */
.about-section{padding:120px 0;overflow:hidden;position:relative}
.about-section::before{content:'';position:absolute;inset:0;background:url("https://images.unsplash.com/photo-1492691527719-9d1e07e534b4?w=1600&h=900&fit=crop&auto=format&q=40") center/cover no-repeat;opacity:.07;pointer-events:none;z-index:0}
.about-section .con{position:relative;z-index:1}
/* top label row */
.about-eyebrow-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:64px}
.about-headline-block{}
.about-h2{font-family:var(--ff);font-weight:800;font-size:clamp(44px,5.5vw,80px);letter-spacing:-.025em;text-transform:uppercase;line-height:1;margin:0}
.moin-grad{background:linear-gradient(270deg,#00e5ff,var(--m),#ff40c0,#00e5ff);background-size:300% 300%;animation:liquid-c 6s ease infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
/* new mof badge */

.about-h2-sub{font-size:13px;font-weight:400;color:var(--mu);letter-spacing:.04em;max-width:260px;line-height:1.7;text-align:right}
/* main grid: video left big, text right compact */
.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:stretch}
/* video card */
.about-video-wrap{position:relative;border-radius:12px;overflow:hidden;min-height:480px;background:#060d18;
  box-shadow:0 32px 80px rgba(0,0,0,.5)}
.about-video-wrap video{width:100%;height:100%;object-fit:cover;display:block;opacity:.85}
.about-video-wrap::before{content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(var(--bg-rgb),.85) 0%,rgba(var(--bg-rgb),.1) 50%,transparent 100%)}
.about-video-wrap::after{content:'';position:absolute;inset:0;border-radius:12px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.07);z-index:3;pointer-events:none}
/* overlay content inside video */
.about-vid-content{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:36px}
.about-vid-stats{display:flex;gap:36px;margin-bottom:20px}
.avs-item{}
.avs-num{font-family:var(--ff);font-weight:800;font-size:42px;letter-spacing:-.02em;color:#fff;line-height:1}
.avs-label{font-size:11px;color:rgba(255,255,255,.45);letter-spacing:.1em;text-transform:uppercase;margin-top:2px}
.about-vid-play{display:inline-flex;align-items:center;gap:12px;cursor:pointer;transition:opacity .2s}
.about-vid-play:hover{opacity:.7}
.play-ring{width:48px;height:48px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);transition:border-color .2s,background .2s}
.about-vid-play:hover .play-ring{border-color:var(--c);background:rgba(0,229,255,.12)}
.play-ring svg{margin-left:3px}
.yt-label{font-size:11px;font-weight:600;color:rgba(255,255,255,.55);letter-spacing:.16em;text-transform:uppercase}
.yt-poster{display:none}
/* text column */
.about-text{display:flex;flex-direction:column;justify-content:center;gap:0}
.about-body{font-size:15px;color:var(--mu);line-height:1.9;font-weight:300;margin-bottom:0}
.about-body strong{color:var(--tx);font-weight:600}
.about-divider{width:40px;height:1px;background:linear-gradient(270deg,#00e5ff,var(--m),#ff40c0,#00e5ff);background-size:300% 300%;animation:liquid-c 4s ease infinite;margin:32px 0}
.about-tags{display:flex;flex-direction:column;gap:0;margin-bottom:36px}
.atag{padding:14px 0;border-bottom:1px solid var(--bd);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--mu);display:flex;align-items:center;justify-content:space-between;transition:color .2s}
.atag::after{content:'→';font-size:14px;opacity:0;transform:translateX(-6px);transition:opacity .2s,transform .2s}
.atag:hover{color:var(--c)}
.atag:hover::after{opacity:1;transform:translateX(0)}
.atag:first-child{border-top:1px solid var(--bd)}

/* ── TAGLINE / SERVICES ── */
.services-head{padding:0 0 56px;display:flex;align-items:flex-end;justify-content:space-between;gap:32px;border-bottom:1px solid var(--bd)}
.services-h{font-family:var(--ff);font-weight:800;font-size:clamp(40px,6vw,88px);letter-spacing:-.01em;text-transform:uppercase;line-height:1.05;max-width:700px}
.services-h span{color:var(--c)}

/* ── LEISTUNGEN SECTION WRAPPER ── */
#leistungen{padding:100px 0 120px}
.svc-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:64px}
.svc-section-hl{font-family:var(--ff);font-weight:800;font-size:clamp(44px,6vw,88px);letter-spacing:-.025em;text-transform:uppercase;line-height:1;margin:0}
.svc-section-sub{font-size:13px;color:var(--mu);letter-spacing:.04em;max-width:240px;text-align:right;line-height:1.7}

.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bd)}
.svc{background:var(--bg);padding:52px 36px 60px;position:relative;overflow:hidden;cursor:default;transition:background .3s}
.svc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(270deg,#00e5ff,var(--m),#ff40c0,#00e5ff);background-size:300% 300%;animation:liquid-c 4s ease infinite;transform:scaleX(0);transform-origin:left;transition:transform .4s}
.svc:hover{background:var(--sf)}
.svc:hover::before{transform:scaleX(1)}
.svc-num{font-family:var(--ff);font-weight:800;font-size:72px;letter-spacing:-.03em;color:rgba(255,255,255,.05);line-height:1;margin-bottom:28px;transition:color .3s}
.svc:hover .svc-num{color:rgba(0,229,255,.12)}
.svc-icon{width:64px;height:64px;border-radius:14px;margin-bottom:28px;display:flex;align-items:center;justify-content:center}
.si1{background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.2)}
.si2{background:rgba(224,64,251,.08);border:1px solid rgba(224,64,251,.2)}
.si3{background:rgba(255,100,100,.08);border:1px solid rgba(255,100,100,.2)}
.si4{background:rgba(255,180,0,.08);border:1px solid rgba(255,180,0,.2)}
.svc-title{font-family:var(--ff);font-weight:800;font-size:clamp(16px,1.6vw,22px);letter-spacing:-.02em;text-transform:uppercase;margin-bottom:16px;transition:color .2s;line-height:1.1}
.svc:hover .svc-title{color:var(--c)}
.svc-desc{font-size:14px;color:var(--mu);line-height:1.85;font-weight:300}
.svc-arrow{position:absolute;bottom:32px;right:32px;opacity:0;transition:opacity .25s,transform .25s;color:var(--c)}
.svc:hover .svc-arrow{opacity:1;transform:translate(3px,-3px)}

/* ── BTS COLLAGE SLIDER ── */
.bts-section{padding:56px 0 0;position:relative}
.bts-track-wrap{overflow:hidden;cursor:grab;user-select:none;-webkit-user-select:none}
.bts-track-wrap:active{cursor:grabbing}

/* 2-row collage grid that scrolls horizontally */
.bts-track{
  display:grid;
  grid-template-rows:260px 260px;
  grid-auto-flow:column;
  grid-auto-columns:320px;
  gap:4px;
  width:max-content;
  will-change:transform;
}

/* Every 3rd slide spans both rows (tall) */
.bts-slide{position:relative;overflow:hidden;flex-shrink:0}
.bts-slide.bts-tall{grid-row:span 2}
/* Wide slide: 2 cols, 1 row */
.bts-slide.bts-wide{grid-column:span 2}

.bts-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s cubic-bezier(.25,.46,.45,.94),filter .5s}
.bts-grayscale .bts-img{filter:brightness(.65) grayscale(100%)}
.bts-slide:hover .bts-img{transform:scale(1.05);filter:brightness(.85) grayscale(0%)}

/* Badge */
.bts-badge{
  position:absolute;
  bottom:24px;
  left:-8px;
  background:rgba(10,12,20,.82);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:4px;
  padding:10px 16px 10px 18px;
  transform:rotate(-2.5deg);
  transform-origin:bottom left;
  box-shadow:0 8px 32px rgba(0,0,0,.5);
  max-width:220px;
  pointer-events:none;
  z-index:2;
}
.bts-badge::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:2px;
  background:linear-gradient(270deg,#00e5ff,var(--m,#7b4fff),#ff40c0,#00e5ff);
  background-size:300% 300%;
  animation:liquid-c 4s ease infinite;
  border-radius:4px 4px 0 0;
}
.bts-badge-title{display:block;font-family:var(--ff);font-weight:700;font-size:13px;letter-spacing:-.01em;color:#fff;line-height:1.2;margin-bottom:4px;text-transform:uppercase}
.bts-badge-date{display:block;font-size:11px;letter-spacing:.12em;color:rgba(0,229,255,.75);font-weight:500}

/* Nav arrows */
.bts-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(10,12,20,.7);border:1px solid rgba(255,255,255,.12);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,border-color .2s;z-index:5;backdrop-filter:blur(8px)}
.bts-nav:hover{background:rgba(0,229,255,.15);border-color:rgba(0,229,255,.4)}
.bts-prev{left:16px}
.bts-next{right:16px}

/* ── SECTION SPACER ── */
.section-spacer{height:72px;background:var(--bg)}

/* ── FOERDERUNG ── */
.foerder-wrap{margin:1px 0;background:var(--bd);padding:1px}
.foerder-inner{background:var(--bg);padding:100px 0}
.foerder-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:80px;align-items:center}
.foerder-left{min-width:0;overflow:hidden}
.foerder-eyebrow{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--mu);margin-bottom:12px}
.foerder-big{font-family:var(--ff);font-weight:800;font-size:clamp(120px,18vw,220px);line-height:.88;letter-spacing:-.03em;display:block;margin-bottom:8px;font-variant-numeric:tabular-nums;width:100%;background:linear-gradient(270deg,#00e5ff,var(--m),#ff40c0,#00e5ff);background-size:300% 300%;animation:liquid-c 5s ease infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.foerder-label{font-family:var(--ff);font-weight:800;font-size:clamp(28px,3.5vw,48px);letter-spacing:.01em;text-transform:uppercase;color:var(--tx);margin-bottom:10px;line-height:1.05}
.foerder-sub{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--mu)}
.foerder-card{background:linear-gradient(270deg,#e040fb,#b000e0,#ff40c0,#c020f0,#e040fb);background-size:300% 300%;animation:liquid-m 6s ease infinite;border-radius:6px;padding:48px 44px}
.foerder-card h3{font-family:var(--ff);font-weight:800;font-size:34px;letter-spacing:-.01em;text-transform:uppercase;color:#060809;margin-bottom:18px;line-height:1.05}
.foerder-card p{font-size:15px;line-height:1.8;color:rgba(6,8,9,.7);font-weight:300;margin-bottom:32px}
.btn-dk{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:#060809;color:#fff;font-family:var(--fb);font-weight:600;font-size:13px;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;transition:opacity .2s}
.btn-dk:hover{opacity:.8}

/* stats */
.stats-bar{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--bd)}
.stat-cell{padding:56px 60px;text-align:center;position:relative}
.stat-cell+.stat-cell::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:1px;background:var(--bd)}
.stat-n{font-family:var(--ff);font-weight:800;font-size:clamp(72px,10vw,110px);letter-spacing:-.02em;color:var(--c);line-height:1}
.stat-l{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--mu);margin-top:8px}

/* ── TEAM ── */
.team-section{padding:120px 0;position:relative}
.team-section::before{content:'';position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;pointer-events:none;z-index:0;transition:opacity .3s}
.team-section::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,var(--bg) 0%,transparent 22%,transparent 78%,var(--bg) 100%),linear-gradient(to right,var(--bg) 0%,transparent 18%,transparent 82%,var(--bg) 100%);pointer-events:none;z-index:0}
.team-section .con,.team-section .team-grid,.team-section .team-header,.team-section .team-cta{position:relative;z-index:1}
.team-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:64px;gap:32px}
.team-header-left{}
.team-header-right{max-width:320px;text-align:right}
.team-layout{display:none}
.team-sticky{position:sticky;top:88px}
.team-h{font-family:var(--ff);font-weight:800;font-size:clamp(44px,5.5vw,80px);letter-spacing:-.025em;text-transform:uppercase;line-height:1.05;margin:0}
.team-intro{font-size:14px;color:var(--mu);line-height:1.8;font-weight:300}
/* 2x2 grid */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.tmember{position:relative;background:var(--sf);overflow:hidden;cursor:default;transition:background .3s}
.tmember:hover{background:var(--sf2)}
.tmember::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;transform:scaleX(0);transform-origin:left;transition:transform .4s;z-index:2}
.tmember:nth-child(1)::before{background:var(--c)}
.tmember:nth-child(2)::before{background:var(--m)}
.tmember:nth-child(3)::before{background:#00e5a0}
.tmember:nth-child(4)::before{background:#ffb400}
.tmember:hover::before{transform:scaleX(1)}
.tmember-inner{display:grid;grid-template-columns:1fr 1fr;min-height:220px}
.tmember-visual{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#0a0d12;aspect-ratio:1/1}
.tm-initial{font-family:var(--ff);font-weight:800;font-size:clamp(72px,8vw,110px);letter-spacing:-.04em;opacity:.18;user-select:none;position:absolute;bottom:-10px;left:16px;line-height:1}
.tmember:nth-child(1) .tm-initial{color:var(--c)}
.tmember:nth-child(2) .tm-initial{color:var(--m)}
.tmember:nth-child(3) .tm-initial{color:#00e5a0}
.tmember:nth-child(4) .tm-initial{color:#ffb400}
.tm-av{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff);font-weight:800;font-size:22px;letter-spacing:-.01em;position:relative;z-index:1}
.tmember:nth-child(1) .tm-av{background:rgba(0,229,255,.12);color:var(--c);border:1.5px solid rgba(0,229,255,.25)}
.tmember:nth-child(2) .tm-av{background:rgba(224,64,251,.12);color:var(--m);border:1.5px solid rgba(224,64,251,.25)}
.tmember:nth-child(3) .tm-av{background:rgba(0,229,160,.12);color:#00e5a0;border:1.5px solid rgba(0,229,160,.25)}
.tmember:nth-child(4) .tm-av{background:rgba(255,180,0,.12);color:#ffb400;border:1.5px solid rgba(255,180,0,.25)}
.tmember-info{padding:36px 32px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid var(--bd)}
.tm-name{font-family:var(--ff);font-weight:800;font-size:32px;letter-spacing:-.01em;margin-bottom:4px}
.tmember:nth-child(1) .tm-name{color:var(--c)}
.tmember:nth-child(2) .tm-name{color:var(--m)}
.tmember:nth-child(3) .tm-name{color:#00e5a0}
.tmember:nth-child(4) .tm-name{color:#ffb400}
.tm-role{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--mu);margin-bottom:16px}
.tm-bio{font-size:13px;color:rgba(237,240,248,.45);line-height:1.75;font-weight:300}
.team-cta{margin-top:40px;display:flex;justify-content:center}
.team-body{font-size:15px;color:var(--mu);line-height:1.85;font-weight:300;margin-bottom:40px}
.team-cards{display:flex;flex-direction:column;gap:2px}
.tcard{display:grid;grid-template-columns:200px 1fr;background:var(--sf);overflow:hidden;border-radius:4px;transition:background .25s}
.tcard:hover{background:var(--sf2)}
.tcard-img{aspect-ratio:1;overflow:hidden;position:relative}
.timg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--ff);font-weight:800;font-size:56px;letter-spacing:-.01em;position:relative}
.t1{background:linear-gradient(145deg,#07193a,#0a2260)}
.t2{background:linear-gradient(145deg,#200840,#380a70)}
.t3{background:linear-gradient(145deg,#072820,#0a4030)}
.tcard-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent 60%,var(--sf))}
.tcard:hover .tcard-img::after{background:linear-gradient(to right,transparent 60%,var(--sf2))}
.tcard-body{padding:32px 36px;display:flex;flex-direction:column;justify-content:center}
.tcard-name{font-family:var(--ff);font-weight:800;font-size:38px;letter-spacing:.01em;margin-bottom:4px}
.tc1{color:var(--c)}.tc2{color:var(--m)}.tc3{color:#00e5a0}.tc4{color:#ffb400}
.t4{background:linear-gradient(145deg,#2a1a00,#402800)}
.tcard-role{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--mu);margin-bottom:16px}
.tcard-bio{font-size:13px;color:var(--mu);line-height:1.75;font-weight:300}

/* ── PORTFOLIO ── */
.portfolio-section{padding:120px 0}
.port-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px;gap:32px}
.port-header-left{}
.port-h{font-family:var(--ff);font-weight:800;font-size:clamp(44px,5.5vw,80px);letter-spacing:-.025em;text-transform:uppercase;line-height:1.05;margin:0}
.filter-row{display:flex;gap:4px;align-items:center;padding-bottom:4px}
.flt{padding:8px 20px;border:1px solid var(--bd);border-radius:4px;background:transparent;color:var(--mu);font-family:var(--fb);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:border-color .2s,color .2s,background .2s}
.flt:hover{border-color:rgba(255,255,255,.15);color:var(--tx)}
.flt.on{border-color:var(--c);color:var(--c);background:rgba(0,229,255,.06)}

/* editorial grid */
.port-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:3px
}
/* pcard-1/2/3/4 are VISUAL variants only – layout is nth-child based */
.pcard{position:relative;overflow:hidden;cursor:pointer;background:var(--sf);min-height:280px}
/* Every 4th+1 card: big, spans 2 cols, taller */
.port-grid .pcard:nth-child(4n+1){grid-column:span 2;min-height:320px}
/* Every 4th+2 card: right column, spans 2 rows */
.port-grid .pcard:nth-child(4n+2){grid-row:span 2}

/* card visuals */
.pcard-visual{width:100%;height:100%;position:relative;overflow:hidden;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.pcard:hover .pcard-visual{transform:scale(1.04)}
.pcard-gradient{position:absolute;inset:0;transition:opacity .4s}
/* overlay */
.pcard-visual::after{content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(6,8,9,.92) 0%,rgba(6,8,9,.3) 45%,rgba(6,8,9,.05) 100%);
  z-index:1}
/* subtle grid lines decoration */
.pcard-deco{position:absolute;inset:0;z-index:0;opacity:.06;
  background-image:linear-gradient(rgba(255,255,255,.6) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.6) 1px,transparent 1px);
  background-size:40px 40px;
  transition:opacity .4s}
.pcard:hover .pcard-deco{opacity:.1}
/* project name watermark */
.pcard-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-8deg);
  font-family:var(--ff);font-weight:800;font-size:clamp(60px,8vw,120px);letter-spacing:-.03em;
  text-transform:uppercase;opacity:.04;white-space:nowrap;pointer-events:none;z-index:0;
  transition:opacity .4s}
.pcard:hover .pcard-watermark{opacity:.07}
/* info */
.pcard-info{position:absolute;bottom:0;left:0;right:0;padding:28px 32px;z-index:2}
.pcard-cat{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--c);margin-bottom:8px;opacity:0;transform:translateY(6px);transition:opacity .35s,transform .35s}
.pcard:hover .pcard-cat{opacity:1;transform:translateY(0)}
.pcard-name{font-family:var(--ff);font-weight:800;font-size:clamp(22px,2.5vw,36px);letter-spacing:-.01em;text-transform:uppercase;line-height:1;color:#fff;transform:translateY(4px);transition:transform .35s}
.pcard:hover .pcard-name{transform:translateY(0)}
.pcard-arrow{display:inline-flex;align-items:center;gap:8px;margin-top:10px;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);opacity:0;transform:translateX(-8px);transition:opacity .3s .05s,transform .3s .05s}
.pcard:hover .pcard-arrow{opacity:1;transform:translateX(0)}
/* always-visible subtle bottom info for non-hover state */
.pcard-label{position:absolute;bottom:28px;left:32px;z-index:2;opacity:1;transition:opacity .3s}
.pcard:hover .pcard-label{opacity:0}
.pcard-label-cat{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.3)}
.pcard-label-name{font-family:var(--ff);font-weight:800;font-size:clamp(18px,2vw,26px);letter-spacing:-.01em;text-transform:uppercase;color:rgba(255,255,255,.7);line-height:1.1}
/* inset glow border on hover */
.pcard::after{content:'';position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(0,229,255,.3);opacity:0;transition:opacity .35s;z-index:3;pointer-events:none}
.pcard:hover::after{opacity:1}
/* port footer */
.port-footer{display:flex;align-items:center;justify-content:center;margin-top:56px}

/* ── PROCESS ── */
.process-section{background:var(--sf);padding:80px 0}
.proc-head{text-align:right;margin-bottom:56px}
.proc-h{font-family:var(--ff);font-weight:800;font-size:clamp(32px,4vw,54px);letter-spacing:-.01em;text-transform:uppercase;line-height:1}
.proc-timeline{position:relative;padding-left:0}
.proc-vline{position:absolute;left:50%;top:0;bottom:0;width:1px;transform:translateX(-50%)}
.proc-vline-fill{width:100%;height:100%;background:linear-gradient(to bottom,transparent,rgba(0,229,255,.35) 20%,rgba(224,64,251,.35) 80%,transparent)}
.proc-step{display:grid;grid-template-columns:1fr 48px 1fr;gap:28px;align-items:center;padding:20px 0}
.proc-card{background:var(--bg);border:1px solid var(--bd);border-radius:4px;padding:22px 28px;transition:border-color .25s}
.proc-step:hover .proc-card{border-color:rgba(0,229,255,.2)}
.proc-node{width:48px;height:48px;flex-shrink:0;border-radius:50%;border:1px solid var(--bd);background:var(--sf);display:flex;align-items:center;justify-content:center;position:relative;z-index:1;transition:border-color .25s,background .25s}
.proc-step:hover .proc-node{border-color:var(--c);background:rgba(0,229,255,.06)}
.proc-num{font-family:var(--ff);font-weight:800;font-size:22px;letter-spacing:-.01em;color:var(--c)}
.proc-title{font-family:var(--ff);font-weight:800;font-size:18px;letter-spacing:.01em;text-transform:uppercase;margin-bottom:6px}
.proc-desc{font-size:13px;color:var(--mu);line-height:1.7;font-weight:300}
.proc-empty{opacity:0}

/* ── PRICING ── */
.pricing-section{padding:120px 0;position:relative}
.pricing-section::before{content:'';position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;pointer-events:none;z-index:0}
.pricing-section::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,var(--bg) 0%,transparent 20%,transparent 80%,var(--bg) 100%),linear-gradient(to right,var(--bg) 0%,transparent 18%,transparent 82%,var(--bg) 100%);pointer-events:none;z-index:0}
.pricing-section .con{position:relative;z-index:1}
.pricing-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:80px;gap:32px}
.price-h{font-family:var(--ff);font-weight:800;font-size:clamp(44px,5.5vw,80px);letter-spacing:-.025em;text-transform:uppercase;line-height:1.05;margin:0}
.pricing-intro{font-size:14px;color:var(--mu);line-height:1.85;font-weight:300;max-width:320px;text-align:right}
.price-intro-card{background:linear-gradient(270deg,var(--sf),rgba(0,229,255,.07),rgba(224,64,251,.05),var(--sf));background-size:300% 300%;animation:liquid-c 8s ease infinite;border:1px solid rgba(0,229,255,.15);border-radius:4px;padding:40px 48px;margin-bottom:3px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:48px}
.pic-left{}
.pic-tag{font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--c);margin-bottom:14px}
.pic-headline{font-family:var(--ff);font-weight:800;font-size:clamp(22px,2.5vw,34px);letter-spacing:-.02em;text-transform:uppercase;line-height:1.1;color:var(--tx);margin-bottom:12px}
.pic-headline em{font-style:normal;background:linear-gradient(270deg,#00e5ff,var(--m),#ff40c0,#00e5ff);background-size:300% 300%;animation:liquid-c 5s ease infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pic-body{font-size:14px;color:var(--mu);line-height:1.8;font-weight:300;max-width:520px}
.pic-right{flex-shrink:0;text-align:center}
.pic-icon{font-size:52px;line-height:1}

/* ── price list: full width, 4 large rows ── */
.price-list{margin-bottom:4px}
.price-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:40px;padding:36px 48px;background:var(--sf);margin-bottom:2px;position:relative;overflow:hidden;cursor:default;transition:background .3s}
.price-row:hover{background:var(--sf2)}
.price-row::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--c),var(--m));transform:scaleY(0);transform-origin:top;transition:transform .35s}
.price-row:hover::before{transform:scaleY(1)}
.price-row-index{font-family:var(--ff);font-weight:800;font-size:48px;letter-spacing:-.03em;color:rgba(255,255,255,.05);line-height:1;flex-shrink:0;transition:color .3s;min-width:48px}
.price-row:hover .price-row-index{color:rgba(0,229,255,.08)}
.price-row-center{}
.price-row-cat{font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--mu);margin-bottom:6px;transition:color .25s}
.price-row:hover .price-row-cat{color:var(--c)}
.price-row-name{font-family:var(--ff);font-weight:800;font-size:clamp(26px,3vw,42px);letter-spacing:-.02em;text-transform:uppercase;line-height:1;color:var(--tx)}
.price-row-desc{font-size:13px;color:rgba(106,122,150,.8);font-weight:300;margin-top:8px;line-height:1.6;max-width:500px}
.price-row-right{text-align:right;flex-shrink:0}
.price-from{font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--mu);margin-bottom:6px}
.price-num{font-family:var(--ff);font-weight:800;font-size:clamp(32px,3.5vw,48px);letter-spacing:-.025em;color:var(--tx);white-space:nowrap;transition:color .3s;line-height:1}
.price-row:hover .price-num{color:var(--c)}
.price-badge{display:inline-block;margin-top:6px;padding:3px 10px;border:1px solid rgba(224,64,251,.3);border-radius:4px;font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--m)}

/* ── BAFA full-width block ── */
.bafa-block{display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--sf);border:1px solid var(--bd);border-radius:0;overflow:hidden;margin-top:2px}
.bafa-left{background:linear-gradient(270deg,#e040fb,#b000e0,#ff40c0,#c020f0,#e040fb);background-size:300% 300%;animation:liquid-m 7s ease infinite;padding:64px 60px;display:flex;flex-direction:column;justify-content:space-between}
.bafa-eyebrow{font-size:10px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:rgba(6,8,9,.45);margin-bottom:20px}
.bafa-big{font-family:var(--ff);font-weight:800;font-size:clamp(100px,15vw,180px);letter-spacing:-.04em;line-height:.85;color:#060809;display:block;margin-bottom:12px}
.bafa-label{font-family:var(--ff);font-weight:800;font-size:clamp(20px,2.5vw,32px);letter-spacing:-.01em;text-transform:uppercase;color:#060809;line-height:1.1}
.bafa-sub{font-size:13px;color:rgba(6,8,9,.5);margin-top:12px;line-height:1.7;font-weight:300;max-width:280px}
.bafa-right{padding:60px;display:flex;flex-direction:column;justify-content:space-between;gap:40px}
.bafa-calc{display:flex;flex-direction:column;gap:0;background:var(--bg);border-radius:4px;overflow:hidden;border:1px solid var(--bd)}
.bafa-calc-row{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--bd);font-size:14px}
.bafa-calc-row:last-child{border-bottom:none;background:rgba(0,229,255,.05)}
.bafa-calc-label{color:var(--mu);font-weight:400}
.bafa-calc-val{font-family:var(--ff);font-weight:800;font-size:20px;letter-spacing:-.01em;line-height:1}
.bafa-calc-row:nth-child(1) .bafa-calc-val{color:rgba(255,255,255,.5)}
.bafa-calc-row:nth-child(2) .bafa-calc-val{color:var(--m)}
.bafa-calc-row:nth-child(3) .bafa-calc-val{color:var(--c);font-size:26px}
.bafa-steps{display:flex;flex-direction:column;gap:16px}
.bafa-step{display:flex;align-items:flex-start;gap:16px}
.bafa-step-n{width:26px;height:26px;border-radius:50%;background:rgba(224,64,251,.1);border:1px solid rgba(224,64,251,.2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--m);flex-shrink:0;margin-top:2px}
.bafa-step-t{font-size:13px;color:var(--mu);line-height:1.65;font-weight:300}
.bafa-step-t strong{color:var(--tx);font-weight:600}

/* ── FAQ ── */
.faq-section{padding:80px 0 140px;position:relative}
.faq-section::before{content:'';position:absolute;inset:0;background:url("https://images.unsplash.com/photo-1551818255-e6e10975bc17?w=1600&h=900&fit=crop&auto=format&q=30") center/cover no-repeat;opacity:.065;pointer-events:none;z-index:0}
.faq-section::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,var(--bg) 0%,transparent 20%,transparent 80%,var(--bg) 100%),linear-gradient(to right,var(--bg) 0%,transparent 15%,transparent 85%,var(--bg) 100%);pointer-events:none;z-index:0}
.faq-section .con{position:relative;z-index:1}
.faq-h{font-family:var(--ff);font-weight:800;font-size:clamp(52px,7vw,100px);letter-spacing:-.01em;text-transform:uppercase;text-align:center;margin-bottom:72px;line-height:1.05}
.faq-list{max-width:920px;margin:0 auto;display:flex;flex-direction:column;gap:2px}
.faq-item{background:var(--sf);border:1px solid transparent;transition:border-color .25s}
.faq-item.open{border-color:rgba(224,64,251,.25)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:24px 32px;cursor:pointer;gap:20px}
.faq-q-t{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tx);transition:color .2s}
.faq-item.open .faq-q-t{color:var(--m)}
.faq-ico{width:32px;height:32px;flex-shrink:0;border-radius:50%;border:1px solid var(--bd);background:transparent;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--mu);transition:transform .3s,border-color .25s,color .2s}
.faq-item.open .faq-ico{transform:rotate(45deg);border-color:var(--m);color:var(--m)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a-in{padding:0 32px 28px;font-size:15px;color:var(--mu);line-height:1.8;font-weight:300}
.faq-cta{text-align:center;margin-top:56px}

/* ── FOOTER ── */
/* ── CONTACT SECTION ── */
.contact-section{padding:120px 0 80px;position:relative;overflow:hidden;border-top:1px solid var(--bd)}
.contact-bg-glow{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:800px;height:500px;background:radial-gradient(ellipse at center,rgba(0,229,255,.05) 0%,rgba(224,64,251,.04) 55%,transparent 70%);pointer-events:none;z-index:0}

/* Top CTA block */
.contact-cta-top{position:relative;z-index:1;margin-bottom:64px}
.contact-h{font-family:var(--ff);font-weight:800;font-size:clamp(52px,8vw,110px);letter-spacing:-.03em;line-height:.96;text-transform:uppercase;margin-bottom:36px;background:linear-gradient(270deg,#00e5ff,var(--m),#ff40c0,#00e5ff);background-size:300% 300%;animation:liquid-c 5s ease infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.contact-cta-row{display:flex;align-items:center;gap:48px;flex-wrap:wrap}
.contact-cta-sub{font-size:15px;color:var(--mu);line-height:1.65;max-width:380px}

/* Divider */
.contact-divider{height:1px;background:var(--bd);margin-bottom:56px;position:relative;z-index:1}

/* Bottom info row */
.contact-bottom{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-tag{font-size:14px;font-weight:600;color:var(--tx);margin-bottom:4px}
.contact-sub{font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--mu)}
.contact-items{display:flex;flex-direction:column;gap:16px}
.contact-item{display:flex;align-items:center;gap:14px;font-size:14px;color:rgba(237,240,248,.65);text-decoration:none;transition:color .2s}
.contact-item:hover{color:var(--c)}
.contact-item-icon{width:30px;height:30px;border:1px solid rgba(0,229,255,.18);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(0,229,255,.03)}

footer{border-top:1px solid var(--bd);padding:40px 60px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.foot-left{display:flex;align-items:center;gap:14px}
.foot-copy{font-size:12px;color:var(--mu);letter-spacing:.04em}
.foot-links{display:flex;gap:28px}
.foot-links a{font-size:12px;color:var(--mu);letter-spacing:.06em;text-transform:uppercase;transition:color .2s}
.foot-links a:hover{color:var(--tx)}

/* gallery strip */
.gallery-strip{overflow:hidden;height:180px;position:relative}
.gallery-strip::before,.gallery-strip::after{content:'';position:absolute;top:0;bottom:0;width:180px;z-index:2;pointer-events:none}
.gallery-strip::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.gallery-strip::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.gtrack{display:flex;gap:8px;height:100%;animation:gs 38s linear infinite;width:max-content}
@keyframes gs{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.gi{height:100%;aspect-ratio:16/9;border-radius:3px;overflow:hidden;flex-shrink:0}
.gi1{background:linear-gradient(145deg,#0a1020,#14203a)}
.gi2{background:linear-gradient(145deg,#101a10,#203020)}
.gi3{background:linear-gradient(145deg,#1a1010,#2a1820)}
.gi4{background:linear-gradient(145deg,#0a1828,#102030)}
.gi5{background:linear-gradient(145deg,#201020,#301828)}
.gi6{background:linear-gradient(145deg,#181820,#222030)}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */

/* ── Tablet: 1024px ── */
@media(max-width:1024px){
  .con{padding:0 40px}
  nav{padding:0 40px}
  .hero-inner{padding:80px 40px 0}
  .hero-inner .con-hero{grid-template-columns:1fr;gap:32px}
  .hero-reel-trigger{display:none}
  .hero-h1{font-size:clamp(40px,7vw,80px)}
  .hero-scroll{display:none}

  .about-eyebrow-row{flex-direction:column;gap:12px;margin-bottom:48px;align-items:flex-start}
  .about-h2-sub{text-align:left;max-width:100%;font-size:14px}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .about-video-wrap{min-height:340px}

  .team-header{flex-direction:column;gap:20px;margin-bottom:48px}
  .team-header-right{text-align:left;max-width:100%}
  .team-grid{grid-template-columns:1fr}

  .foerder-grid{grid-template-columns:1fr;gap:40px}

  .port-grid{
    grid-template-columns:1fr 1fr;
    gap:3px;
  }
  .port-grid .pcard:nth-child(4n+1){grid-column:span 2;min-height:280px}
  .port-grid .pcard:nth-child(4n+2){grid-column:1;grid-row:span 2;min-height:280px}
  .port-grid .pcard:nth-child(4n+3){grid-column:2;min-height:220px}
  .port-grid .pcard:nth-child(4n+4){grid-column:2;min-height:220px}

  .contact-bottom{gap:40px}
  .contact-cta-row{gap:32px}  .pricing-header{flex-direction:column;gap:16px;margin-bottom:48px}
  .pricing-intro{text-align:left;max-width:100%}
  .pricing-body{grid-template-columns:1fr}
  .price-row{padding:28px 32px;gap:24px}
  .price-row-index{font-size:36px;min-width:36px}

  .bafa-block{grid-template-columns:1fr}
  .bafa-left{padding:48px 40px}
  .bafa-right{padding:40px}

  .proc-head{flex-direction:column;gap:16px}
  .bts-track{grid-template-rows:200px 200px;grid-auto-columns:260px}
  #leistungen{padding:72px 0 88px}
  .svc-section-head{flex-direction:column;gap:12px;margin-bottom:48px}
  .svc-section-sub{text-align:left;max-width:100%}
  .svc-grid{grid-template-columns:1fr 1fr}
  .svc-title{font-size:clamp(16px,2.5vw,22px)}

  footer{padding:32px 40px}
}

/* ── Mobile: 768px ── */
@media(max-width:768px){
  .con{padding:0 24px}
  nav{padding:0 24px;height:56px}
  .nav-links a{display:none}
  .nav-cta{display:flex}

  .hero{min-height:100svh}
  .hero-inner{padding:72px 24px 0}
  .hero-h1{font-size:clamp(36px,9vw,64px);margin-bottom:20px}
  .hero-sub{font-size:14px}
  .hero-actions{gap:10px}
  .btn-c{font-size:12px;padding:12px 22px}
  .btn-ghost{font-size:12px;padding:12px 22px}

  .about-section{padding:80px 0}
  .about-eyebrow-row{margin-bottom:36px;align-items:flex-start}
  .about-h2{font-size:clamp(36px,8vw,56px)}
  .about-h2-sub{font-size:14px;max-width:100%;text-align:left;margin-top:4px}
  .about-video-wrap{min-height:260px}
  .about-vid-stats{gap:20px}
  .avs-num{font-size:32px}
  .about-divider{margin:24px 0}

  .team-section{padding:80px 0}
  .team-h{font-size:clamp(36px,8vw,56px)}
  .tmember-inner{grid-template-columns:100px 1fr;min-height:160px}
  .tm-initial{font-size:clamp(48px,10vw,72px)}
  .tm-av{width:52px;height:52px;font-size:16px}
  .tmember-info{padding:20px}
  .tm-name{font-size:24px}

  .portfolio-section{padding:80px 0}
  .port-h{font-size:clamp(36px,8vw,56px)}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .contact-section{padding:80px 0}
  .contact-h{font-size:clamp(28px,7vw,44px)}
  .port-header{flex-direction:column;gap:20px;margin-bottom:36px}
  .filter-row{flex-wrap:wrap;gap:6px}
  .port-grid{
    grid-template-columns:1fr;
    gap:3px;
  }
  .port-grid .pcard:nth-child(n){grid-column:1;grid-row:auto;min-height:220px}
  .port-grid .pcard:nth-child(4n+1){grid-column:1;min-height:240px}
  .port-grid .pcard:nth-child(4n+2){grid-row:auto}
  .pcard-label-name{font-size:20px}

  .pricing-section{padding:80px 0}
  .price-h{font-size:clamp(36px,8vw,56px)}
  .price-row{padding:22px 20px;gap:16px;grid-template-columns:auto 1fr auto}
  .price-row-index{display:none}
  .price-row-name{font-size:clamp(20px,5vw,28px)}
  .price-num{font-size:clamp(22px,5vw,32px)}
  .price-badge{display:none}
  .bafa-big{font-size:clamp(80px,18vw,140px)}
  .bafa-label{font-size:clamp(18px,4vw,26px)}
  .bafa-left{padding:36px 28px}
  .bafa-right{padding:28px}
  .bafa-calc-row{padding:12px 16px}
  .bafa-calc-val{font-size:17px}
  .bafa-calc-row:nth-child(3) .bafa-calc-val{font-size:22px}

  .foerder-wrap{padding:1px 0}
  .foerder-inner{padding:64px 0}
  .foerder-big{font-size:clamp(80px,22vw,140px)}
  .foerder-card{padding:32px 28px}
  .foerder-card h3{font-size:26px}

  .bts-track{grid-template-rows:180px 180px;grid-auto-columns:220px}
  #leistungen{padding:56px 0 72px}
  .svc-grid{grid-template-columns:1fr}
  .svc-section-head{margin-bottom:36px}
  .svc-title{font-size:20px}

  .proc-timeline{padding:0 8px}
  .proc-step{grid-template-columns:1fr 40px 1fr}

  .faq-section{padding:60px 0 80px}
  .faq-h{font-size:clamp(36px,8vw,60px);margin-bottom:40px}
  .faq-q{padding:18px 20px}
  .faq-a-in{padding:0 20px 20px}

  .team-cta{margin-top:32px}
  .port-footer{margin-top:40px}

  footer{flex-direction:column;align-items:flex-start;gap:20px;padding:28px 24px}
  .foot-links{flex-wrap:wrap;gap:16px}

  .marquee-wrap::before,.marquee-wrap::after{width:60px}

  .about-grid{grid-template-columns:1fr}

  .stats-bar{grid-template-columns:1fr 1fr}
  .stat-cell{padding:36px 24px}

  .reel-lightbox .reel-lb-inner{width:95vw}
}

/* ── Small Mobile: 480px ── */
@media(max-width:480px){
  .hero-h1{font-size:clamp(32px,9vw,52px)}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .btn-c,.btn-ghost,.btn-m{width:100%;justify-content:center}
  .team-grid{grid-template-columns:1fr}
  .tmember-inner{grid-template-columns:80px 1fr;min-height:140px}
  .price-row{grid-template-columns:1fr auto}
  .price-row-desc{display:none}
  .proc-step{display:flex;flex-direction:column;gap:12px;align-items:flex-start;padding-left:20px}
  .proc-empty{display:none}
  .proc-vline{display:none}
  .about-vid-stats{flex-wrap:wrap;gap:16px}
}

/* ══════════════════════════════════════
   COOKIE BANNER – DSGVO
══════════════════════════════════════ */
#cookie-wall{position:fixed;inset:0;z-index:9000;background:rgba(6,8,9,.7);backdrop-filter:blur(6px);display:none;align-items:flex-end;justify-content:center;padding:24px;opacity:0;transition:opacity .4s;pointer-events:none}
#cookie-wall.visible{opacity:1;pointer-events:all}
.ck-box{width:100%;max-width:780px;background:var(--sf2);border:1px solid rgba(255,255,255,.08);border-radius:4px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.7)}
.ck-main{padding:36px 40px}
.ck-logo{display:flex;align-items:center;gap:10px;margin-bottom:20px}
.ck-logo-mark{display:grid;grid-template-columns:1fr 1fr;gap:2px;width:16px;height:16px}
.ck-logo-mark span{border-radius:1px}
.ck-logo-mark span:nth-child(1){background:var(--c)}
.ck-logo-mark span:nth-child(2){background:var(--m)}
.ck-logo-mark span:nth-child(3){background:var(--m);opacity:.5}
.ck-logo-mark span:nth-child(4){background:var(--c);opacity:.3}
.ck-logo-name{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.ck-title{font-family:var(--ff);font-weight:800;font-size:clamp(22px,3vw,32px);letter-spacing:-.02em;text-transform:uppercase;color:var(--tx);margin-bottom:10px;line-height:1.1}
.ck-text{font-size:13px;color:var(--mu);line-height:1.75;font-weight:300;margin-bottom:24px;max-width:580px}
.ck-text a{color:var(--c);text-decoration:underline;text-decoration-color:rgba(0,229,255,.3)}
.ck-text a:hover{text-decoration-color:var(--c)}
.ck-btns{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.ck-btn-accept{display:inline-flex;align-items:center;padding:12px 28px;background:linear-gradient(270deg,#00e5ff,#00b8d4,#00e5c8,#40c4ff,#00e5ff);background-size:300% 300%;animation:liquid-c 5s ease infinite;color:var(--bg);font-family:var(--fb);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;border:none;cursor:pointer;transition:opacity .2s}
.ck-btn-accept:hover{opacity:.85}
.ck-btn-reject{display:inline-flex;align-items:center;padding:11px 24px;border:1px solid var(--bd);color:var(--mu);font-family:var(--fb);font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;background:transparent;cursor:pointer;transition:border-color .2s,color .2s}
.ck-btn-reject:hover{border-color:rgba(255,255,255,.2);color:var(--tx)}
.ck-btn-settings{display:inline-flex;align-items:center;gap:6px;padding:11px 20px;color:rgba(255,255,255,.35);font-family:var(--fb);font-weight:500;font-size:12px;letter-spacing:.06em;background:transparent;border:none;cursor:pointer;transition:color .2s;margin-left:4px}
.ck-btn-settings:hover{color:rgba(255,255,255,.6)}
.ck-footer{padding:14px 40px;border-top:1px solid var(--bd);display:flex;align-items:center;gap:24px;background:rgba(0,0,0,.2)}
.ck-footer-link{font-size:11px;color:rgba(255,255,255,.25);letter-spacing:.06em;text-decoration:none;transition:color .2s}
.ck-footer-link:hover{color:rgba(255,255,255,.5)}

/* settings panel */
.ck-settings{display:none;padding:0 40px 32px;border-top:1px solid var(--bd);margin-top:8px}
.ck-settings.open{display:block}
.ck-settings-title{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--mu);margin:24px 0 16px}
.ck-toggle-row{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.ck-toggle-row:last-child{border-bottom:none}
.ck-toggle-info{}
.ck-toggle-name{font-size:13px;font-weight:600;color:var(--tx);margin-bottom:4px}
.ck-toggle-desc{font-size:12px;color:var(--mu);font-weight:300;line-height:1.6;max-width:440px}
/* toggle switch */
.ck-switch{position:relative;width:44px;height:24px;flex-shrink:0;margin-top:2px}
.ck-switch input{opacity:0;width:0;height:0;position:absolute}
.ck-slider{position:absolute;inset:0;background:var(--bg);border:1px solid var(--bd);border-radius:24px;cursor:pointer;transition:background .25s,border-color .25s}
.ck-slider::after{content:'';position:absolute;left:3px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;background:rgba(255,255,255,.3);transition:transform .25s,background .25s}
.ck-switch input:checked+.ck-slider{background:rgba(0,229,255,.15);border-color:rgba(0,229,255,.4)}
.ck-switch input:checked+.ck-slider::after{transform:translate(20px,-50%);background:var(--c)}
.ck-switch input:disabled+.ck-slider{opacity:.5;cursor:not-allowed}
.ck-save-btn{display:inline-flex;align-items:center;padding:11px 24px;border:1px solid var(--bd);color:var(--tx);font-family:var(--fb);font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;background:transparent;cursor:pointer;transition:border-color .2s;margin-top:20px}
.ck-save-btn:hover{border-color:var(--c);color:var(--c)}
