/* ============================================================
   DeenDigitalMedia — "Aurora Glass" · Premium 2026
   Brand kept: cyan #04F5FF + blue on dark · Poppins + Roboto
   ============================================================ */
:root{
  --bg:#04060A; --bg-soft:#070A12; --panel:#080C14;
  --cyan:#04F5FF; --cyan-2:#6CFCFF; --blue:#1863DC; --blue-2:#2E8BFF;
  --white:#F2F8FF; --text:#9DB0C4; --text-2:#C6D4E4; --dim:#5C6B7E;
  --stroke:rgba(255,255,255,.08); --stroke-2:rgba(255,255,255,.14);
  --stroke-cy:rgba(4,245,255,.28);
  --glass:rgba(255,255,255,.045); --glass-2:rgba(255,255,255,.08);
  --grad:linear-gradient(135deg,#6CFCFF 0%,#04F5FF 42%,#1863DC 100%);
  --glow-cy:0 0 24px rgba(4,245,255,.45);
  --f-head:'Poppins',system-ui,sans-serif; --f-body:'Roboto',system-ui,sans-serif;
  --maxw:1280px; --pad:clamp(1.1rem,4vw,3rem);
  --r:22px; --r-lg:30px;
  --e:cubic-bezier(.22,.7,.25,1); --e-out:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;overflow-x:clip}
html.js{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html.js{scroll-behavior:auto}}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--f-body); font-size:clamp(1rem,.97rem + .2vw,1.12rem);
  line-height:1.75; letter-spacing:.005em; overflow-x:clip; -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--cyan);color:#03121a}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:8px}

/* ---------- AURORA / MESH BACKGROUND ---------- */
.aurora{position:fixed;inset:0;z-index:-4;overflow:hidden;pointer-events:none}
.aurora span{position:absolute;border-radius:50%;filter:blur(60px);opacity:.45;mix-blend-mode:screen}
.aurora .b1{width:60vw;height:60vw;left:-10vw;top:-18vw;background:radial-gradient(circle,#04f5ff,transparent 65%);opacity:.32;animation:drift1 22s ease-in-out infinite}
.aurora .b2{width:55vw;height:55vw;right:-14vw;top:2vw;background:radial-gradient(circle,#1863dc,transparent 65%);opacity:.38;animation:drift2 26s ease-in-out infinite}
.aurora .b3{width:50vw;height:50vw;left:24vw;bottom:-22vw;background:radial-gradient(circle,#04f5ff,transparent 60%);opacity:.18;animation:drift3 30s ease-in-out infinite}
@keyframes drift1{50%{transform:translate(14vw,10vh) scale(1.15)}}
@keyframes drift2{50%{transform:translate(-12vw,8vh) scale(1.1)}}
@keyframes drift3{50%{transform:translate(8vw,-10vh) scale(1.18)}}
.grid-lines{position:fixed;inset:-2px;z-index:-3;pointer-events:none;opacity:.6;
  background-image:linear-gradient(rgba(110,205,255,.10) 1px,transparent 1px),linear-gradient(90deg,rgba(110,205,255,.10) 1px,transparent 1px);
  background-size:62px 62px;-webkit-mask-image:radial-gradient(circle at 50% 12%,#000,transparent 92%);mask-image:radial-gradient(circle at 50% 12%,#000,transparent 92%);animation:gridDrift 45s linear infinite}
@keyframes gridDrift{to{background-position:62px 62px,62px 62px}}
.noise{position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
#particles{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.6}

.cursor{position:fixed;left:0;top:0;width:11px;height:11px;border-radius:50%;background:var(--cyan);box-shadow:0 0 20px 5px rgba(4,245,255,.55);transform:translate(-50%,-50%);pointer-events:none;z-index:9999;mix-blend-mode:screen;transition:width .25s,height .25s,opacity .25s;opacity:0}
.cursor.big{width:54px;height:54px;background:rgba(4,245,255,.14);box-shadow:0 0 28px 6px rgba(4,245,255,.2)}
.scroll-prog{position:fixed;top:0;left:0;height:2px;width:0;z-index:9500;background:var(--grad);box-shadow:0 0 10px rgba(4,245,255,.7)}
.skip{position:absolute;left:-999px;top:0;z-index:200;background:var(--cyan);color:#03121a;padding:.7rem 1.1rem;font-weight:700;border-radius:0 0 10px 0}
.skip:focus{left:0}

/* ---------- PRELOADER ---------- */
.pre{position:fixed;inset:0;z-index:10000;display:grid;place-items:center;background:var(--bg);animation:preOut .7s var(--e) 1.4s forwards}
.pre.done{animation:preOut .6s var(--e) forwards}
@keyframes preOut{to{opacity:0;visibility:hidden}}
.pre img{width:72px;filter:drop-shadow(0 0 24px rgba(4,245,255,.7));animation:pp 1.3s ease-in-out infinite}
@keyframes pp{50%{transform:scale(1.1);opacity:.8}}

/* ---------- FLOATING GLASS PILL NAV ---------- */
.nav{position:fixed;top:clamp(.8rem,2vw,1.5rem);left:50%;transform:translateX(-50%);z-index:200;
  width:min(1100px,calc(100vw - 1.4rem));
  transition:transform .5s var(--e-out),opacity .4s var(--e),box-shadow .4s}
.nav.hidden{transform:translateX(-50%) translateY(-160%);opacity:0}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.55rem .65rem .55rem 1.1rem;border-radius:999px;
  background:rgba(8,12,20,.55);backdrop-filter:blur(13px) saturate(135%);-webkit-backdrop-filter:blur(13px) saturate(135%);
  border:1px solid var(--stroke-2);box-shadow:0 18px 50px -18px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.1)}
.nav__brand img{height:26px;filter:drop-shadow(0 0 8px rgba(4,245,255,.4))}
.nav__links{display:flex;gap:.4rem}
.nav__links a{font-family:var(--f-head);font-weight:500;font-size:.9rem;color:var(--text-2);padding:.5rem .9rem;border-radius:999px;transition:color .25s,background .25s}
.nav__links a:hover{color:var(--white);background:rgba(255,255,255,.06)}
.nav__cta{display:flex;align-items:center;gap:.5rem}
.nav__burger{display:none;width:42px;height:42px;border-radius:50%;border:1px solid var(--stroke-2);background:rgba(255,255,255,.05);cursor:pointer;padding:0;place-items:center}
.nav__burger span{display:block;width:18px;height:2px;margin:3px auto;background:var(--white);transition:.3s}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(2.5px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){transform:translateY(-2.5px) rotate(-45deg)}
.sheet{position:fixed;inset:0;z-index:190;background:rgba(4,6,10,.96);backdrop-filter:blur(16px);display:flex;flex-direction:column;justify-content:center;gap:.3rem;padding:var(--pad);transform:translateY(-100%);transition:transform .55s var(--e-out)}
.sheet.open{transform:none}
.sheet a{font-family:var(--f-head);font-weight:700;font-size:clamp(1.8rem,9vw,2.6rem);color:var(--white);padding:.55rem 0;border-bottom:1px solid var(--stroke);display:flex;align-items:baseline;gap:1rem}
.sheet a i{font-size:.85rem;color:var(--cyan);font-style:normal;font-family:var(--f-body)}
.sheet .btn{margin-top:1.4rem;justify-content:center}

/* ---------- BUTTONS ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.55rem;padding:.85rem 1.5rem;border-radius:999px;font-family:var(--f-head);font-weight:600;font-size:.95rem;cursor:pointer;border:1px solid transparent;white-space:nowrap;transition:transform .3s var(--e),box-shadow .3s,background .3s,color .3s,border-color .3s;will-change:transform}
.btn--primary{background:var(--grad);color:#02121b;box-shadow:0 10px 30px -8px rgba(4,245,255,.55)}
.btn--primary:hover{box-shadow:0 16px 44px -8px rgba(4,245,255,.8)}
.btn--ghost{background:var(--glass);color:var(--white);border-color:var(--stroke-2);backdrop-filter:blur(10px)}
.btn--ghost:hover{border-color:var(--cyan);background:rgba(4,245,255,.08)}
.btn--lg{padding:1.05rem 1.9rem;font-size:1.02rem}
.btn .arr{font-style:normal;transition:transform .3s var(--e)}
.btn:hover .arr{transform:translateX(5px)}

/* ---------- PRIMITIVES ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--f-head);font-weight:500;font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);margin:0}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px 2px rgba(4,245,255,.8)}
.num{font-family:var(--f-head);font-weight:600;font-size:.78rem;letter-spacing:.2em;color:var(--dim)}
h1,h2,h3,h4{font-family:var(--f-head);color:var(--white);margin:0;letter-spacing:-.025em;line-height:1.04;font-weight:700}
.display{font-weight:800;font-size:clamp(2.9rem,1.4rem + 7.5vw,7.5rem);letter-spacing:-.04em;line-height:.98}
.h2{font-size:clamp(2.1rem,1.2rem + 4vw,4.6rem);font-weight:700}
.lead{font-size:clamp(1.08rem,1rem + .5vw,1.4rem);color:var(--text-2);line-height:1.6;font-weight:300}
.glow{color:var(--cyan);text-shadow:0 0 26px rgba(4,245,255,.55),0 0 60px rgba(4,245,255,.25)}
.it{font-family:var(--f-body);font-style:italic;font-weight:300;color:var(--text-2)}
.thin{font-weight:300;color:var(--text-2)}

.glass{background:linear-gradient(160deg,var(--glass-2),var(--glass));backdrop-filter:blur(13px) saturate(135%);-webkit-backdrop-filter:blur(13px) saturate(135%);border:1px solid var(--stroke);border-radius:var(--r);box-shadow:inset 0 1px 0 rgba(255,255,255,.09),0 30px 60px -34px rgba(0,0,0,.9)}
.glass-hover{position:relative;overflow:hidden;transition:border-color .4s,transform .35s var(--e)}
.glass-hover::after{content:"";position:absolute;width:340px;height:340px;border-radius:50%;left:var(--mx,50%);top:var(--my,0%);transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(4,245,255,.16),transparent 70%);opacity:0;transition:opacity .4s;pointer-events:none}
.glass-hover:hover{border-color:var(--stroke-cy)}
.glass-hover:hover::after{opacity:1}

/* section rhythm — generous whitespace */
.section{padding-block:clamp(5.5rem,11vw,11rem);position:relative}
.shead{max-width:62ch;margin-bottom:clamp(2.6rem,5vw,4.5rem)}
.shead--c{margin-inline:auto;text-align:center}
.shead__top{display:flex;align-items:center;gap:1rem;margin-bottom:1.4rem}
.shead--c .shead__top{justify-content:center}
.shead h2{margin:0}
.shead .lead{margin:1.3rem 0 0;max-width:58ch}
.shead--c .lead{margin-inline:auto}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding:clamp(8rem,16vh,12rem) 0 clamp(4rem,8vh,7rem);overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:-1;background-color:#04060a;background-size:cover;background-position:72% center;opacity:.62;filter:saturate(115%) contrast(106%);will-change:transform}
.hero__scrim{position:absolute;inset:0;z-index:-1;background:
  radial-gradient(60% 50% at 50% 0%,rgba(4,245,255,.10),transparent 60%),
  linear-gradient(180deg,rgba(4,6,10,.55) 0%,rgba(4,6,10,.2) 35%,rgba(4,6,10,.7) 80%,var(--bg) 100%)}
.hero__grid{display:grid;grid-template-columns:1fr;gap:clamp(2.5rem,5vw,4rem);align-items:center}
.hero__title{margin:1.6rem 0 0}
.hero__title .l{display:block;overflow:hidden}
.hero__lead{margin:1.8rem 0 0;max-width:44ch}
.hero__cta{margin-top:2.3rem;display:flex;flex-wrap:wrap;gap:.9rem}
.hero__stage{position:relative;display:grid;place-items:center;min-height:300px}
.hero__halo{position:absolute;width:78%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(4,245,255,.4),transparent 62%);filter:blur(10px);animation:halo 6s ease-in-out infinite}
@keyframes halo{50%{transform:scale(1.08);opacity:.85}}
.hero__logo{position:relative;width:min(70%,360px);filter:drop-shadow(0 0 50px rgba(4,245,255,.6)) drop-shadow(0 24px 50px rgba(0,0,0,.5));animation:float 7s ease-in-out infinite}
@keyframes float{50%{transform:translateY(-20px)}}
/* hero KPI widgets */
.hero__kpis{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:2.4rem}
.kpi-chip{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;border-radius:16px}
.kpi-chip b{font-family:var(--f-head);color:var(--white);font-weight:700;font-size:1.05rem}
.kpi-chip span{font-size:.82rem;color:var(--dim)}
.kpi-chip .st{color:var(--cyan);letter-spacing:.06em}
.cue{position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);z-index:3;width:24px;height:40px;border:1.5px solid var(--stroke-2);border-radius:13px;display:grid;justify-items:center;padding-top:7px}
.cue span{width:4px;height:8px;border-radius:3px;background:var(--cyan);box-shadow:0 0 10px var(--cyan);animation:cue 1.6s ease-in-out infinite}
@keyframes cue{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}100%{opacity:0;transform:translateY(12px)}}

/* ---------- MARQUEE ---------- */
.trust{padding:2.6rem 0;border-block:1px solid var(--stroke)}
.trust__l{text-align:center;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--dim);margin:0 0 1.5rem}
.marq{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.marq__t{display:flex;align-items:center;gap:3.6rem;width:max-content;animation:scrollx 38s linear infinite}
.marq:hover .marq__t{animation-play-state:paused}
.marq__t img{height:30px;filter:brightness(0) invert(1);opacity:.45;transition:opacity .3s}
.marq__t img:hover{opacity:.95}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- BENTO (Kernkompetenzen) ---------- */
.bento{display:grid;grid-template-columns:1fr;gap:1.1rem}
.bento__card{padding:clamp(1.6rem,3vw,2.5rem);position:relative;min-height:230px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.bento__ico{position:absolute;top:1.6rem;left:1.6rem;width:46px;height:46px;display:grid;place-items:center;border-radius:14px;border:1px solid var(--stroke-cy);background:rgba(4,245,255,.06)}
.bento__ico svg{width:24px;height:24px;fill:none;stroke:var(--cyan);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 6px rgba(4,245,255,.5))}
.bento__n{position:absolute;top:1.8rem;right:1.8rem;font-family:var(--f-head);font-weight:700;color:var(--dim);font-size:.85rem}
.bento__card h3{font-size:clamp(1.4rem,1.1rem + 1.2vw,2rem);margin:0 0 .5rem}
.bento__card p{margin:0;color:var(--text)}

/* ---------- SERVICES (alternating) ---------- */
.svc{display:flex;flex-direction:column;gap:clamp(4rem,9vw,9rem)}
.svc__row{display:grid;grid-template-columns:1fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.svc__media{position:relative;border-radius:var(--r-lg);padding:clamp(1.2rem,2.5vw,2rem);overflow:hidden}
.svc__media::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 60% at 50% 0%,rgba(4,245,255,.14),transparent 70%);pointer-events:none}
.svc__media img{width:100%;border-radius:16px;position:relative}
.svc__badge{position:absolute;top:1.1rem;left:1.1rem;z-index:2;font-family:var(--f-head);font-weight:700;color:var(--cyan);background:rgba(4,6,10,.6);border:1px solid var(--stroke-cy);border-radius:999px;padding:.3rem .8rem;font-size:.78rem}
.svc__text .num{display:block;margin-bottom:1rem}
.svc__text h3{font-size:clamp(2rem,1.3rem + 3vw,3.4rem);font-weight:800;letter-spacing:-.03em}
.svc__text p{margin:1.2rem 0 0;max-width:46ch;color:var(--text)}
.svc__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.6rem}
.svc__tags span{font-size:.8rem;color:var(--cyan-2);border:1px solid var(--stroke-cy);border-radius:999px;padding:.4rem .85rem;background:rgba(4,245,255,.05)}

/* ---------- KPI WIDGETS (Ergebnisse) ---------- */
.kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem}
.kpi{padding:clamp(1.5rem,3vw,2.4rem);display:flex;flex-direction:column;gap:.5rem;position:relative;overflow:hidden}
.kpi__n{font-family:var(--f-head);font-weight:800;font-size:clamp(2.6rem,1.6rem + 5vw,4.8rem);line-height:1;letter-spacing:-.03em;color:var(--white);display:flex;align-items:baseline;gap:.06em}
.kpi__n i{font-style:normal;color:var(--cyan);font-size:.45em;text-shadow:var(--glow-cy)}
.kpi__l{color:var(--text)}
.kpi__spark{position:absolute;right:0;bottom:0;width:60%;height:40%;background:radial-gradient(circle at 100% 100%,rgba(4,245,255,.12),transparent 70%)}
.note{margin-top:2.2rem;font-size:.84rem;color:var(--dim);border-left:2px solid var(--cyan);padding-left:.9rem;max-width:60ch}

/* ---------- REVIEWS ---------- */
.reviews{columns:3 300px;column-gap:1.1rem}
.rev{break-inside:avoid;margin-bottom:1.1rem;padding:1.6rem}
.rev__h{display:flex;align-items:center;gap:.7rem;margin-bottom:.9rem}
.rev__av{width:40px;height:40px;flex:none;border-radius:50%;display:grid;place-items:center;font-family:var(--f-head);font-weight:800;color:#02121b;background:var(--grad)}
.rev__h b{display:block;color:var(--white);font-family:var(--f-head);font-weight:600;font-size:.95rem}
.rev__h small{color:var(--cyan);font-size:.78rem}
.rev p{margin:0;font-size:.93rem;color:var(--text)}
.rev--badge{display:grid;place-items:center;text-align:center;gap:.3rem}
.rev--badge .big{font-family:var(--f-head);font-weight:800;font-size:3rem;color:var(--white);line-height:1}
.rev--badge .st{color:var(--cyan);letter-spacing:.14em}

/* ---------- CASES (bento) ---------- */
.cases{display:grid;grid-template-columns:1fr;gap:1.2rem}
.case{overflow:hidden;display:flex;flex-direction:column}
.case__img{aspect-ratio:16/10;overflow:hidden;display:grid;place-items:center;padding:1.2rem;background:radial-gradient(80% 90% at 50% 120%,rgba(4,245,255,.12),transparent 60%)}
.case__img img{width:100%;height:100%;object-fit:contain;transition:transform .6s var(--e)}
.case:hover .case__img img{transform:scale(1.06)}
.case__b{padding:1.4rem 1.6rem 1.7rem}
.case__b h3{font-size:1.5rem;font-weight:700}
.case__city{color:var(--cyan);font-size:.85rem;margin:.3rem 0 0;font-weight:500}
.case__tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:1rem}
.case__tags span{font-size:.73rem;color:var(--text);border:1px solid var(--stroke-2);border-radius:999px;padding:.3rem .7rem}

/* ---------- STEPS ---------- */
.steps{position:relative;display:grid;grid-template-columns:1fr;gap:1rem}
.steps__line{display:none}
.step{padding:1.6rem;border-radius:var(--r);position:relative}
.step__n{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-family:var(--f-head);font-weight:800;font-size:1.2rem;color:var(--cyan);border:1px solid var(--stroke-cy);background:rgba(4,245,255,.05);margin-bottom:1.1rem;box-shadow:0 0 24px -6px rgba(4,245,255,.5)}
.step h3{font-size:1.25rem;font-weight:700;margin:0 0 .4rem}
.step p{margin:0;color:var(--text);font-size:.95rem}

/* ---------- CTA ---------- */
.cta{position:relative;overflow:hidden;text-align:center;padding:clamp(2.8rem,7vw,6rem);border-radius:var(--r-lg)}
.cta__glow{position:absolute;inset:0;background:radial-gradient(60% 120% at 50% 0%,rgba(4,245,255,.22),transparent 60%)}
.cta>*{position:relative}
.cta h2{font-size:clamp(2.4rem,1.4rem + 4.6vw,5rem);font-weight:800}
.cta .lead{max-width:48ch;margin:1.2rem auto 0}
.cta__row{margin-top:2.3rem;display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center}
.cta__meta{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.6rem 1.7rem;justify-content:center;color:var(--dim);font-size:.92rem}
.cta__meta a{color:var(--white);border-bottom:1px solid var(--stroke-2);transition:border-color .3s}
.cta__meta a:hover{border-color:var(--cyan)}

/* ---------- FOOTER ---------- */
.footer{border-top:1px solid var(--stroke);padding-block:clamp(3rem,5vw,4.5rem) 2rem;margin-top:clamp(2rem,5vw,4rem)}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.4rem 1.4rem}
.footer__brand img{height:30px;margin-bottom:1rem}
.footer__brand p{margin:0;color:var(--dim);max-width:34ch;font-size:.92rem}
.footer h4{font-family:var(--f-head);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);margin:0 0 1rem;font-weight:600}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.footer li,.footer ul a{color:var(--text);font-size:.93rem;transition:color .25s}
.footer ul a:hover{color:var(--cyan)}
.footer__bot{margin-top:clamp(2.4rem,4vw,3.4rem);padding-top:1.5rem;border-top:1px solid var(--stroke);display:flex;flex-wrap:wrap;gap:.8rem 1.5rem;justify-content:space-between;color:var(--dim);font-size:.84rem}
.footer__bot .tg{color:var(--cyan)}

/* ---------- REVEAL ANIMATIONS ---------- */
.js [data-reveal]{opacity:0;will-change:opacity,transform;transition:opacity .9s var(--e-out),transform .9s var(--e-out)}
.js [data-reveal="up"]{transform:translateY(42px)}
.js [data-reveal="scale"]{transform:scale(.94)}
.js [data-reveal="left"]{transform:translateX(-46px)}
.js [data-reveal="right"]{transform:translateX(46px)}
.js [data-reveal].in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(min-width:600px){.kpis{grid-template-columns:repeat(4,1fr)}}
@media(min-width:860px){
  .nav__burger{display:none!important}
  .bento{grid-template-columns:repeat(6,1fr)}
  .bento__card{grid-column:span 2;min-height:280px}
  .bento__card--wide{grid-column:span 3}
  .bento__card--tall{grid-column:span 3}
  .cases{grid-template-columns:repeat(6,1fr)}
  .case--feat{grid-column:span 6}
  .case--feat{flex-direction:row}
  .case--feat .case__img{flex:1.2;aspect-ratio:auto}
  .case--feat .case__b{flex:1;align-self:center}
  .case--half{grid-column:span 3}
  .svc__row{grid-template-columns:1.05fr .95fr}
  .svc__row--rev .svc__media{order:2}
  .steps{grid-template-columns:repeat(4,1fr);gap:1.2rem}
  .steps__line{display:block;position:absolute;top:26px;left:8%;right:8%;height:2px;background:var(--stroke);z-index:0}
  .steps__line span{display:block;height:100%;width:0;background:var(--grad);box-shadow:0 0 10px rgba(4,245,255,.7)}
  .hero__grid{grid-template-columns:1.1fr .9fr}
}
@media(max-width:859px){
  .nav__links,.nav__cta .btn--primary{display:none}
  .nav__burger{display:grid}
  .reviews{columns:1}
  .footer__grid{grid-template-columns:1fr 1fr}.footer__brand{grid-column:1/-1}
  .hero__stage{order:-1;min-height:auto}
  .hero__logo{width:min(44%,168px)}
  .hero__bg{opacity:.15}
  .display{font-size:clamp(2rem,8.6vw,3.2rem);letter-spacing:-.03em}
  .hero__title{margin-top:1rem}
}
/* reveals handled by IntersectionObserver (see script.js) — never left stuck */

/* ===== Hero: stronger dark scrim toward text (left) ===== */
.hero__scrim{background:
  radial-gradient(55% 50% at 78% 45%,rgba(4,245,255,.10),transparent 60%),
  linear-gradient(90deg,rgba(4,6,10,.92) 0%,rgba(4,6,10,.7) 34%,rgba(4,6,10,.25) 62%,rgba(4,6,10,.55) 100%),
  linear-gradient(180deg,transparent 40%,rgba(4,6,10,.55) 82%,var(--bg) 100%)}

/* ===== Hero floating "software" widgets ===== */
.hero__widgets{position:relative;width:100%;height:100%;min-height:360px}
.fw{position:absolute;padding:1rem 1.15rem;border-radius:18px;min-width:166px;will-change:transform;cursor:default}
.fw__top{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}
.fw__top .d{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan);animation:blink 2.4s ease-in-out infinite}
@keyframes blink{50%{opacity:.35}}
.fw__top span{font-family:var(--f-head);font-size:.72rem;color:var(--text-2);font-weight:500}
.fw__n{font-family:var(--f-head);font-weight:800;font-size:1.55rem;color:var(--white);line-height:1;display:flex;align-items:baseline;gap:.12rem}
.fw__n em{font-style:normal;font-size:.58em;color:var(--cyan)}
.fw__s{font-size:.7rem;color:var(--dim);margin-top:.28rem}
.fw__stars{color:var(--cyan);font-size:.82rem;letter-spacing:.1em;margin-bottom:.3rem}
.fw__bars{display:flex;align-items:flex-end;gap:4px;height:30px;margin-top:.7rem}
.fw__bars i{flex:1;background:var(--grad);border-radius:2px;transform-origin:bottom}
.fw--1{top:1%;right:7%}
.fw--2{top:39%;right:31%}
.fw--3{bottom:3%;right:3%}

/* ===== subtle ambient section divider (light gradient) ===== */
.section::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:min(620px,76%);height:1px;background:linear-gradient(90deg,transparent,rgba(4,245,255,.32),transparent);opacity:.45;pointer-events:none}

/* ===== responsive nav fix ===== */
@media(max-width:859px){
  .nav__inner{padding:.5rem .55rem .5rem .95rem}
  .nav__brand img{height:23px}
  .hero__stage{display:none}
}
@media(max-width:560px){ .fw--2{display:none} }

/* ===== ÜBER UNS ===== */
.about__grid{display:grid;grid-template-columns:1fr;gap:clamp(2rem,4vw,4rem)}
.about__story h2{margin:1.1rem 0 0}
.about__story .lead{margin:1.4rem 0 0}
.about__story p{margin:1.1rem 0 0;color:var(--text)}
.about__sign{display:flex;align-items:center;gap:.9rem;margin-top:2.1rem}
.about__ava{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-family:var(--f-head);font-weight:800;color:#02121b;background:var(--grad);flex:none;box-shadow:0 0 22px -4px rgba(4,245,255,.6)}
.about__sign b{display:block;color:var(--white);font-family:var(--f-head);font-weight:600}
.about__sign span{font-size:.85rem;color:var(--dim)}
.about__values{display:grid;gap:1rem}
.value{padding:1.4rem 1.5rem}
.value h3{font-size:1.14rem;font-weight:600;color:var(--white);margin:0 0 .35rem}
.value p{margin:0;color:var(--text);font-size:.94rem}
@media(min-width:860px){
  .about__grid{grid-template-columns:1.05fr .95fr;align-items:center}
  .about__values{grid-template-columns:1fr 1fr}
}

/* ===== ABLAUF — storytelling (pinned scroll) ===== */
.story{position:relative}
.story::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:min(620px,76%);height:1px;background:linear-gradient(90deg,transparent,rgba(4,245,255,.32),transparent);opacity:.45}
.story__scroll{height:340vh;position:relative}
.story__sticky{position:sticky;top:0;height:100svh;display:flex;align-items:center;overflow:hidden}
.story__head{max-width:60ch;margin-bottom:clamp(2rem,4vw,3.4rem)}
.story__head h2{margin:1rem 0 0}
.story__head .lead{margin:1rem 0 0}
.story__stage{display:grid;grid-template-columns:1fr;gap:2.2rem}
.story__panels{position:relative;min-height:300px}
.sp{position:absolute;inset:0;opacity:0;transform:translateY(30px);transition:opacity .55s var(--e-out),transform .55s var(--e-out);pointer-events:none}
.sp.active{opacity:1;transform:none;pointer-events:auto}
.sp__n{font-family:var(--f-head);font-weight:800;font-size:clamp(3.6rem,3rem + 5vw,7rem);line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:block}
.sp h3{font-size:clamp(1.9rem,1.3rem + 2.2vw,3rem);font-weight:800;margin:.5rem 0 0;color:var(--white)}
.sp p{margin:1.1rem 0 0;max-width:46ch;color:var(--text);font-size:1.06rem;line-height:1.7}
.story__rail{display:flex;flex-direction:column;position:relative;padding-left:1.5rem}
.rail__line{position:absolute;left:0;top:14px;bottom:14px;width:2px;background:var(--stroke-2);border-radius:2px;overflow:hidden}
.rail__line span{position:absolute;top:0;left:0;width:100%;height:0;background:var(--grad);box-shadow:0 0 10px rgba(4,245,255,.7)}
.rail__item{display:flex;align-items:baseline;gap:.7rem;background:none;border:0;cursor:pointer;text-align:left;padding:.85rem 0;opacity:.38;transition:opacity .4s,transform .4s var(--e);font-family:var(--f-head)}
.rail__item.active{opacity:1;transform:translateX(4px)}
.rail__item .rn{color:var(--cyan);font-weight:700;font-size:.82rem}
.rail__item .rt{color:var(--white);font-weight:500;font-size:1.05rem}
@media(min-width:860px){ .story__stage{grid-template-columns:1.25fr .75fr;gap:clamp(2.5rem,5vw,5rem);align-items:center} }
@media(max-width:859px){
  .story__sticky{padding-block:5.5rem 3rem}
  .story__panels{min-height:54vh}
  .sp__n{font-size:clamp(3.4rem,17vw,5rem)}
  .sp h3{font-size:clamp(1.7rem,7.5vw,2.4rem)}
  .sp p{font-size:1rem;max-width:42ch}
  .story__rail{display:none}
}
/* no-GSAP / reduced-motion fallback: show all steps stacked */
/* storytelling works with or without GSAP (CSS sticky + vanilla JS) */

/* ===== ÜBER UNS — scroll storytelling (sticky scenes + emblem) ===== */
.saga{position:relative}
.saga__scroll{height:380vh;position:relative}
.saga__sticky{position:sticky;top:0;height:100svh;display:flex;align-items:center;overflow:hidden;--p:0}
.saga__inner{position:relative;z-index:2;width:100%}
.saga__eye{margin-bottom:clamp(1.4rem,3vw,2.4rem)}
.saga__scenes{position:relative;min-height:48vh;max-width:100%}
.scene{position:absolute;inset:0;opacity:0;transform:translateY(38px);transition:opacity .6s var(--e-out),transform .6s var(--e-out);pointer-events:none}
.scene.is-active{opacity:1;transform:none;pointer-events:auto}
.saga__big{font-family:var(--f-head);font-weight:800;font-size:clamp(2rem,1rem + 4vw,4.8rem);line-height:1.04;letter-spacing:-.035em;color:var(--white);margin:0;overflow-wrap:break-word}
.saga__sub{margin:1.6rem 0 0;max-width:44ch;font-size:clamp(1.05rem,1rem + .4vw,1.3rem);color:var(--text-2);font-weight:300}
.saga__values{display:flex;flex-wrap:wrap;gap:.55rem;margin:1.8rem 0 0}
.saga__values span{font-size:.88rem;color:var(--cyan-2);border:1px solid var(--stroke-cy);border-radius:999px;padding:.5rem 1rem;background:rgba(4,245,255,.05)}
.saga__bar{margin-top:clamp(1.8rem,4vw,2.8rem);width:min(420px,70%);height:3px;border-radius:3px;background:var(--stroke-2);overflow:hidden}
.saga__bar span{display:block;height:100%;width:0;background:var(--grad);box-shadow:0 0 10px rgba(4,245,255,.7)}
.saga__ill{position:absolute;right:5%;top:50%;transform:translateY(-50%);width:min(36vw,400px);aspect-ratio:1;z-index:1;pointer-events:none;opacity:calc(.4 + var(--p)*.6)}
.ill{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transform:scale(.9);transition:opacity .6s var(--e-out),transform .6s var(--e-out)}
.ill.is-active{opacity:1;transform:none}
@keyframes spin{to{transform:rotate(360deg)}}
.ig{width:78%;height:78%;overflow:visible}
/* 0 · Geschichte — roter Faden */
.thr{stroke:var(--cyan);stroke-width:2.5;stroke-linecap:round;stroke-dasharray:100;stroke-dashoffset:100;filter:drop-shadow(0 0 6px rgba(4,245,255,.6));animation:draw 3.6s ease-in-out infinite}
@keyframes draw{0%{stroke-dashoffset:100}55%{stroke-dashoffset:0}90%{stroke-dashoffset:0}100%{stroke-dashoffset:0;opacity:.35}}
.thr-dot{fill:var(--cyan);filter:drop-shadow(0 0 9px var(--cyan))}
/* 1 · austauschbar — identische Balken */
.bars{display:flex;align-items:center;gap:11px;height:44%}
.bars i{width:13px;height:100%;background:rgba(150,170,195,.3);border-radius:3px;animation:same 2.2s ease-in-out infinite}
@keyframes same{50%{opacity:.45}}
/* 2 · unverwechselbar — klares Logo */
.u-ring{position:absolute;width:78%;height:78%;border-radius:50%;border:1px solid rgba(4,245,255,.4);animation:spin 22s linear infinite}
.u-ring::after{content:"";position:absolute;top:-4px;left:50%;width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 12px var(--cyan);transform:translateX(-50%)}
.u-logo{width:46%;z-index:2}.u-logo img{width:100%;filter:drop-shadow(0 0 34px rgba(4,245,255,.85));animation:pulseG 2.6s ease-in-out infinite}
@keyframes pulseG{50%{filter:drop-shadow(0 0 50px rgba(4,245,255,1))}}
/* 3 · System */
.i3-svg{width:84%;height:84%;overflow:visible}
.i3-svg line{stroke:rgba(4,245,255,.45);stroke-width:1.5;stroke-dasharray:4 5;animation:dash 1.4s linear infinite}
@keyframes dash{to{stroke-dashoffset:-18}}
.i3-svg .hub{fill:rgba(4,245,255,.2);stroke:var(--cyan);stroke-width:2;filter:drop-shadow(0 0 12px rgba(4,245,255,.8))}
.i3-svg .node{fill:#04060a;stroke:var(--cyan);stroke-width:2;animation:nodeP 2.6s ease-in-out infinite}
.i3-svg .n2{animation-delay:.65s}.i3-svg .n3{animation-delay:1.3s}.i3-svg .n4{animation-delay:1.95s}
@keyframes nodeP{50%{fill:rgba(4,245,255,.35)}}
@media(min-width:860px){ .saga__scenes{max-width:58%} }
@media(max-width:859px){
  .saga__sticky{flex-direction:column;justify-content:center;padding-block:5rem 2rem;gap:1.2rem}
  .saga__ill{position:relative;right:auto;top:auto;transform:none;width:min(38vw,128px);margin:0 auto;flex:none;opacity:calc(.6 + var(--p)*.4)}
  .saga__inner{width:100%}
  .saga__scenes{min-height:40vh}
  .saga__big{font-size:clamp(1.9rem,8vw,2.8rem)}
  .saga__sub{font-size:1rem}
  .saga__values{gap:.4rem}
  .saga__values span{font-size:.8rem;padding:.4rem .8rem}
  .saga__bar{margin-top:1.1rem;width:100%}
}
.about__who{display:flex;flex-direction:column}
.about__sign{margin-top:2rem}

/* ===== REVIEWS — horizontal scroller ===== */
.reviews{display:flex;gap:1.1rem;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;padding:.4rem 0 1.6rem;-webkit-overflow-scrolling:touch;cursor:grab;scrollbar-width:thin;scrollbar-color:var(--stroke-2) transparent}
.reviews.dragging{cursor:grabbing;scroll-snap-type:none}
.reviews .rev{flex:0 0 clamp(270px,78vw,350px);margin:0;scroll-snap-align:start}
.reviews::-webkit-scrollbar{height:6px}
.reviews::-webkit-scrollbar-thumb{background:var(--stroke-2);border-radius:6px}
.reviews::-webkit-scrollbar-thumb:hover{background:var(--stroke-cy)}
.reviews::-webkit-scrollbar-track{background:transparent}
.reviews__hint{display:flex;align-items:center;gap:.5rem;color:var(--dim);font-size:.82rem;margin-top:.4rem}
.reviews__hint::before{content:"";width:24px;height:1px;background:var(--cyan)}

/* ===== perf: lighter section rendering offscreen ===== */
.section,.story,.saga{contain:layout style}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .js [data-reveal]{opacity:1!important;transform:none!important}
  .cursor,#particles{display:none}
  .aurora span{animation:none}
}
