/* ============================================================
   implec — zentrales Design-System (Komponenten-Layer)
   Alle im Design-Manual definierten Elemente sind hier als
   wiederverwendbare Klassen umgesetzt. HTML-Seiten enthalten
   nur noch Struktur + Text. Design-Änderungen = hier, einmal.
   ============================================================ */

/* ——— Hausschrift: Radikal (Nootype) ——— */
@font-face { font-family:'Radikal'; src:url('assets/fonts/radikal-light.woff2') format('woff2'),url('assets/fonts/radikal-light.woff') format('woff'); font-weight:300; font-style:normal; font-display:swap; }
@font-face { font-family:'Radikal'; src:url('assets/fonts/radikal-regular.woff2') format('woff2'),url('assets/fonts/radikal-regular.woff') format('woff'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Radikal'; src:url('assets/fonts/radikal-bold.woff2') format('woff2'),url('assets/fonts/radikal-bold.woff') format('woff'); font-weight:500 700; font-style:normal; font-display:swap; }

/* ——— Tokens ——— */
:root {
  /* Farben */
  --purple:#3C005F; --purple-deep:#25003B; --purple-soft:#51187a;
  --red:#E6002D; --red-deep:#B80024;
  --ink:#2A0040; --ink-soft:#6e6e73; --ink-faint:#b0a8bb;
  --paper:#fbfbfd; --white:#ffffff; --cream:#f5f5f7; --panel:#f3eef7;
  --line:rgba(60,0,95,0.08); --line-2:rgba(0,0,0,0.08); --line-3:rgba(60,0,95,0.1);
  --pink:#ff8da3; --gold:#FBBC05;
  /* Schrift */
  --sans:"Radikal","Helvetica Neue",Helvetica,Arial,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",Menlo,monospace;
  /* Radius / Maße */
  --r-card:24px; --r-card-sm:16px; --r-pill:980px; --r-tag:6px;
  --maxw:1280px;
  /* Akzent (pro Seite überschreibbar) */
  --accent:var(--purple);
  --accent-cta:var(--red);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-size:15px; line-height:1.5;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap{ max-width:var(--maxw); margin:0 auto; }
.wrap--1200{ max-width:1200px; margin:0 auto; }
.wrap--1100{ max-width:1100px; margin:0 auto; }

.section{ padding:88px 22px; }
.section--lg{ padding:120px 22px; }
.section--flush-top{ padding-top:0; }
.section--white{ background:var(--white); }
.section--cream{ background:var(--cream); }
.section--panel{ background:var(--panel); }
.section--dark{ background:linear-gradient(165deg,#2A0040 0%,#14001f 100%); color:#fff; }
.section--dark-flat{ background:var(--purple-deep); color:#fff; }
.center{ text-align:center; }

.section-head{ text-align:center; max-width:720px; margin:0 auto 48px; }
.section-head .lead{ margin-left:auto; margin-right:auto; }

/* Grids */
.grid{ display:grid; gap:14px; }
.grid--2{ grid-template-columns:1fr 1fr; }
.grid--3{ grid-template-columns:repeat(3,1fr); }
.grid--4{ grid-template-columns:repeat(4,1fr); }
.gap-24{ gap:24px; }

/* ============================================================
   TYPOGRAFIE
   ============================================================ */
.eyebrow{ font-size:14px; font-weight:600; color:var(--accent-cta); margin:0 0 12px; letter-spacing:-0.01em; }
.eyebrow--accent{ color:var(--accent); }
.eyebrow--pink{ color:var(--pink); }
.eyebrow--mono{ font-family:var(--mono); font-size:11px; font-weight:500; letter-spacing:0.18em; text-transform:uppercase; }

.h1{ font-size:clamp(40px,6.5vw,84px); font-weight:600; line-height:1.02; letter-spacing:-0.025em; margin:0 0 16px; }
.h2{ font-size:clamp(30px,5vw,48px); font-weight:600; line-height:1.05; letter-spacing:-0.025em; margin:0 0 14px; }
.h2--xl{ font-size:clamp(34px,6vw,72px); }
.h2--dark{ font-weight:700; letter-spacing:-0.03em; }
.h3{ font-size:21px; font-weight:600; line-height:1.25; letter-spacing:-0.015em; margin:0; }
.lead{ font-size:clamp(17px,2vw,21px); color:var(--ink-soft); letter-spacing:-0.01em; margin:0; }
.muted{ color:var(--ink-soft); }
.text{ font-size:15px; color:var(--ink-soft); line-height:1.5; }

/* ============================================================
   BUTTONS / LINKS
   ============================================================ */
.btn{ display:inline-flex; align-items:center; gap:10px; padding:14px 26px; border-radius:var(--r-pill);
  font-weight:600; font-size:15px; text-decoration:none; cursor:pointer; border:1px solid transparent;
  transition:background .18s ease, transform .18s ease, box-shadow .18s ease; }
.btn--sm{ padding:10px 22px; font-size:14px; }
.btn--lg{ padding:15px 32px; font-size:17px; }
.btn--block{ width:100%; justify-content:center; }
.btn--primary{ background:var(--red); color:#fff; }
.btn--primary:hover{ background:var(--red-deep); transform:translateY(-1px); }
.btn--purple{ background:var(--accent); color:#fff; }
.btn--purple:hover{ background:var(--purple-soft); transform:translateY(-1px); }
.btn--ghost{ border-color:rgba(255,255,255,0.4); color:#fff; background:rgba(255,255,255,0.12); backdrop-filter:blur(8px); }
.btn--ghost:hover{ background:rgba(255,255,255,0.2); }
.btn .arrow::after,.arr::after{ content:"→"; }

.link{ text-decoration:none; color:var(--accent); font-size:14px; font-weight:500; transition:opacity .15s ease; }
.link:hover{ opacity:.7; }
.link::after{ content:" ›"; }
.link--red{ color:var(--red); }
.link--soft{ color:var(--ink-soft); }

/* ============================================================
   EYEBROW / TAGS / CHIPS
   ============================================================ */
.tag{ display:inline-flex; align-items:center; gap:6px; padding:4px 10px; border-radius:var(--r-tag);
  background:rgba(60,0,95,0.08); color:var(--purple); font-family:var(--mono); font-size:11px;
  letter-spacing:0.08em; text-transform:uppercase; }
.tag--red{ background:rgba(230,0,45,0.10); color:var(--red); }
.chip{ padding:6px 14px; border-radius:var(--r-pill); background:var(--panel); color:var(--accent); font-size:13px; font-weight:500; }
.chip--ghost{ padding:5px 12px; background:rgba(255,255,255,0.08); color:#fff; font-size:11.5px; }
.chip--city{ padding:5px 12px; background:#f0edf3; color:var(--purple); font-size:11.5px; font-weight:500; }

/* Pills-Filter */
.pills{ display:inline-flex; gap:6px; padding:6px; background:var(--cream); border-radius:var(--r-pill); flex-wrap:wrap; }
.pills--bordered{ background:#fff; border:1px solid var(--line); }
.pill{ padding:7px 16px; border-radius:var(--r-pill); color:var(--ink); font-size:13px; font-weight:500; }
.pill--active{ background:var(--ink); color:#fff; }
.pill--active-accent{ background:var(--accent); color:#fff; }

/* ============================================================
   FOTO-PLATZHALTER  (.ph — bis echte Bilder vorliegen)
   ============================================================ */
.ph{ background:repeating-linear-gradient(135deg,rgba(60,0,95,0.06) 0 2px,transparent 2px 14px),linear-gradient(135deg,rgba(60,0,95,0.16),rgba(230,0,45,0.10)); background-color:#ece6f1; }
.ph.dark{ background:repeating-linear-gradient(135deg,rgba(255,255,255,0.06) 0 2px,transparent 2px 14px),linear-gradient(135deg,rgba(230,0,45,0.30),rgba(60,0,95,0.55)); background-color:#1a0030; }
.ph.cover{ position:absolute; inset:0; width:100%; height:100%; }
/* Echte Bilder: object-fit-cover als Fläche / Hintergrund */
.img-cover{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.media{ width:100%; height:100%; object-fit:cover; display:block; }

/* ============================================================
   MOTION
   ============================================================ */
@keyframes kenburns{ 0%{transform:scale(1) translate(0,0);} 100%{transform:scale(1.12) translate(-1.5%,-1.5%);} }
.kenburns{ animation:kenburns 18s ease-out infinite alternate; }
@keyframes pulsering{ 0%{box-shadow:0 0 0 0 rgba(230,0,45,0.45);} 70%{box-shadow:0 0 0 16px rgba(230,0,45,0);} 100%{box-shadow:0 0 0 0 rgba(230,0,45,0);} }
.playring{ animation:pulsering 2.4s ease-out infinite; }
.lift{ transition:transform .2s ease, box-shadow .2s ease; }
.lift:hover{ transform:translateY(-2px); box-shadow:0 18px 40px rgba(60,0,95,0.10); }

/* ============================================================
   NAV  (Haupt-Website)
   ============================================================ */
.sticky{ position:sticky; top:0; z-index:40; }
.utility{ background:var(--ink); color:rgba(255,255,255,0.8); font-size:12.5px; padding:7px 40px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.utility__group{ display:flex; gap:22px; flex-wrap:wrap; align-items:center; }
.utility b{ color:#fff; }
.utility .gold{ color:var(--gold); }

.nav{ background:rgba(251,251,253,0.92); backdrop-filter:saturate(180%) blur(20px); -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--line); height:60px; display:flex; align-items:center; justify-content:space-between; padding:0 40px; }
.nav__logo{ height:24px; }
.nav__links{ display:flex; gap:24px; list-style:none; margin:0; padding:0; font-size:14.5px; font-weight:500; align-items:center; height:60px; }
.nav__links > li{ color:var(--ink); cursor:pointer; }
.nav__actions{ display:flex; align-items:center; gap:16px; }

/* Mega-Menü (CSS-only, Hover) */
.has-mega{ height:100%; display:flex; align-items:center; position:static; }
.nav-mega-trigger{ display:flex; align-items:center; gap:5px; cursor:pointer; color:var(--ink); height:60px; border-bottom:2px solid transparent; }
.mega{ position:absolute; left:0; right:0; top:100%; background:#fff; border-bottom:1px solid var(--line);
  box-shadow:0 40px 80px rgba(60,0,95,0.10); padding:36px 40px 28px;
  opacity:0; visibility:hidden; transform:translateY(-6px); transition:opacity .18s ease, transform .18s ease, visibility .18s; z-index:50; }
.has-mega:hover .mega, .mega:hover{ opacity:1; visibility:visible; transform:translateY(0); }
.has-mega:hover .nav-mega-trigger{ color:var(--purple); border-bottom-color:var(--red); font-weight:700; }
.mega__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:40px 48px; }
.mega-col__title{ margin-bottom:12px; padding-bottom:10px; border-bottom:1px solid rgba(60,0,95,0.09); font-size:11.5px; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-soft); }
.mega-link{ display:block; padding:9px 10px; border-radius:11px; text-decoration:none; color:var(--ink); margin-bottom:1px; transition:background .15s ease; }
.mega-link:hover{ background:rgba(60,0,95,0.07); }
.mega-link b{ font-size:15px; font-weight:600; display:block; line-height:1.25; }
.mega-link span{ font-size:12px; color:var(--ink-soft); }
.mega__tools{ border-top:1px solid var(--line); padding-top:20px; margin-top:8px; display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.mega__tools-label{ font-size:11px; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-soft); margin-right:6px; }
.tool-chip{ display:flex; align-items:center; gap:8px; padding:7px 14px; background:rgba(60,0,95,0.07); border-radius:var(--r-pill); text-decoration:none; color:var(--ink); }
.tool-chip b{ font-size:14px; font-weight:600; } .tool-chip span{ font-size:12px; color:var(--ink-soft); }

.burger{ display:none; font-size:24px; cursor:pointer; color:var(--ink); }

/* ============================================================
   HERO  (fullbleed)
   ============================================================ */
.hero{ position:relative; height:92vh; min-height:780px; background:#0a0410; overflow:hidden; color:#fff; }
.hero--sister{ height:90vh; min-height:760px; background:#1a0030; }
.hero__scrim{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(10,4,16,0.4) 0%,rgba(10,4,16,0) 30%,rgba(10,4,16,0) 50%,rgba(10,4,16,0.85) 100%); }
.hero--sister .hero__scrim{ background:linear-gradient(180deg,rgba(26,0,48,0.55) 0%,rgba(26,0,48,0.1) 30%,rgba(26,0,48,0.2) 55%,rgba(26,0,48,0.9) 100%); }
.hero__glow{ position:absolute; top:-10%; right:-5%; width:520px; height:520px; border-radius:50%; background:radial-gradient(circle,rgba(230,0,45,0.35),transparent 70%); filter:blur(20px); }
.hero__content{ position:absolute; left:5%; bottom:9%; max-width:760px; }
.hero__kicker{ font-size:21px; font-weight:500; color:#fff; margin:0 0 18px; letter-spacing:-0.01em; }
.hero__kicker--mono{ font-size:14px; font-weight:600; color:var(--red); letter-spacing:0.04em; text-transform:uppercase; }
.hero__title{ font-size:clamp(40px,8vw,84px); font-weight:600; line-height:1.02; letter-spacing:-0.03em; margin:0 0 14px; }
.hero__title--gradient{ background:linear-gradient(180deg,#fff 0%,#c8b8d6 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero__sub{ font-size:clamp(18px,2.2vw,24px); font-weight:400; color:rgba(255,255,255,0.86); margin:0; max-width:600px; line-height:1.25; letter-spacing:-0.01em; }
.hero__actions{ display:flex; gap:12px; margin-top:30px; flex-wrap:wrap; }
.hero__top{ position:absolute; top:32px; left:50%; transform:translateX(-50%); font-size:13px; font-weight:500; color:rgba(255,255,255,0.5); letter-spacing:0.02em; text-transform:uppercase; }
.showreel{ position:absolute; top:8%; right:4%; display:flex; align-items:center; gap:12px; padding:8px 18px 8px 8px;
  background:rgba(255,255,255,0.12); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border-radius:var(--r-pill); border:1px solid rgba(255,255,255,0.18); cursor:pointer; color:#fff; font-size:14px; font-weight:500; }
.showreel__play{ width:34px; height:34px; border-radius:50%; background:var(--red); display:flex; align-items:center; justify-content:center; font-size:13px; }
.price-pill{ position:absolute; right:4%; bottom:9%; display:flex; align-items:center; gap:6px; padding:6px 6px 6px 22px;
  background:rgba(40,28,56,0.75); backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px); border-radius:var(--r-pill); border:1px solid rgba(255,255,255,0.08); color:#fff; font-size:15px; }
.price-pill a{ padding:10px 24px; background:var(--red); color:#fff; border-radius:var(--r-pill); text-decoration:none; font-weight:500; }

/* ============================================================
   TRUST-BAR
   ============================================================ */
.trust{ padding:28px 22px; background:#fff; border-bottom:1px solid rgba(60,0,95,0.06); }
.trust__inner{ max-width:var(--maxw); margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.trust__points{ display:flex; gap:28px; flex-wrap:wrap; font-size:14.5px; color:var(--ink-soft); }
.trust__logos{ display:flex; gap:30px; align-items:center; font-weight:700; font-size:18px; color:rgba(37,0,59,0.4); letter-spacing:-0.01em; }
.stars{ color:var(--gold); letter-spacing:1px; }

/* ============================================================
   BENTO / TILES
   ============================================================ */
.bento{ display:grid; grid-template-columns:2fr 1fr; gap:14px; }
.bento__col{ display:grid; grid-template-rows:1fr 1fr; gap:14px; }
.tile{ position:relative; overflow:hidden; border-radius:var(--r-card); padding:36px; background:#fff; border:1px solid rgba(0,0,0,0.06); min-height:280px; }
.tile--big{ padding:56px 48px; min-height:580px; }
.tile--md{ min-height:340px; }
.tile--dark{ background:#2A0040; color:#fff; border:none; }
.tile--purple-grad{ background:linear-gradient(135deg,#3C005F 0%,#25003B 100%); color:#fff; border:none; }
.tile--red-grad{ background:linear-gradient(135deg,#E6002D 0%,#B80024 100%); color:#fff; border:none; }
.tile--cream{ background:var(--cream); border:none; }
.tile__rel{ position:relative; }
.tile__eyebrow{ font-size:13px; font-weight:600; margin:0; }
.tile__title{ font-weight:600; line-height:1.05; letter-spacing:-0.02em; margin:8px 0 14px; font-size:32px; }
.tile__title--xl{ font-size:64px; max-width:560px; }
.tile__title--lg{ font-size:44px; }
.tile__text{ font-size:15px; margin:0; }
.tile__link{ position:absolute; bottom:32px; left:36px; text-decoration:none; font-size:15px; }
.tile__links{ display:flex; gap:20px; margin-top:28px; font-size:17px; }
.tile__links a{ text-decoration:none; }
.on-dark, .on-dark .tile__text{ color:rgba(255,255,255,0.85); }
.t-pink{ color:var(--pink); } .t-purple{ color:var(--purple); } .t-red{ color:var(--red); }
/* Uptime-Visual */
.uptime{ position:absolute; right:48px; bottom:48px; display:flex; gap:14px; align-items:flex-end; }
.uptime__bar{ width:42px; border-radius:8px; background:linear-gradient(180deg,rgba(255,255,255,0.7) 0%,rgba(255,255,255,0.2) 100%); }
.uptime__num{ font-size:48px; font-weight:600; letter-spacing:-0.025em; line-height:1; }
.uptime__cap{ font-size:13px; color:rgba(255,255,255,0.6); margin-top:4px; }

/* ============================================================
   DISZIPLINEN (dunkle Karten)
   ============================================================ */
.disc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.disc{ background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.12); border-radius:20px; padding:34px 32px; display:flex; flex-direction:column; min-height:280px; }
.disc__head{ display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:22px; }
.disc__icon{ width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:24px; background:rgba(60,0,95,0.55); }
.disc__icon--red{ background:rgba(230,0,45,0.22); }
.disc__num{ font-size:13px; font-weight:700; color:rgba(255,255,255,0.4); }
.disc h3{ font-size:26px; font-weight:700; letter-spacing:-0.02em; color:#fff; margin:0 0 10px; }
.disc p{ font-size:15px; color:rgba(255,255,255,0.68); line-height:1.5; margin:0 0 24px; }
.disc__tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:auto; }

/* ============================================================
   STATS
   ============================================================ */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); max-width:1100px; margin:0 auto; border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2); }
.stat{ padding:48px 24px; border-right:1px solid var(--line-2); text-align:center; }
.stat:last-child{ border-right:none; }
.stat__num{ font-size:clamp(48px,8vw,88px); font-weight:600; letter-spacing:-0.04em; line-height:1; color:var(--ink); }
.stat__label{ font-size:15px; color:var(--ink-soft); margin-top:14px; }
/* Spec-Band (Schwester-Seiten, kleiner, Akzentfarbe) */
.spec{ max-width:1100px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--line-3); border-bottom:1px solid var(--line-3); }
.spec__item{ padding:38px 22px; border-right:1px solid var(--line-3); text-align:center; }
.spec__item:last-child{ border-right:none; }
.spec__num{ font-size:52px; font-weight:700; letter-spacing:-0.03em; line-height:1; color:var(--accent); }
.spec__label{ font-size:13.5px; color:var(--ink-soft); margin-top:10px; }

/* ============================================================
   KARTEN (Cases / Posts / Use-Cases)
   ============================================================ */
.card{ background:#fff; border-radius:var(--r-card); overflow:hidden; border:1px solid rgba(0,0,0,0.06); }
.card--soft{ background:var(--paper); }
.card--panel{ background:var(--panel); border:none; }
.card__media{ position:relative; aspect-ratio:4/3; }
.card__media--wide{ aspect-ratio:16/10; }
.card__badge{ position:absolute; bottom:16px; left:16px; padding:5px 12px; border-radius:var(--r-pill); background:rgba(40,4,64,0.7); color:#fff; font-size:11px; font-weight:500; }
.card__badge--accent{ background:rgba(60,0,95,0.85); font-weight:600; }
.card__badge--light{ background:rgba(255,255,255,0.95); color:var(--ink); border-radius:var(--r-tag); font-weight:600; }
.card__body{ padding:24px 26px 28px; }
.card__foot{ display:flex; justify-content:space-between; align-items:center; padding-top:16px; margin-top:18px; border-top:1px solid var(--line-2); }
.card__stat{ font-size:18px; font-weight:600; color:var(--red); letter-spacing:-0.02em; }

/* ============================================================
   PREIS-PAKETE
   ============================================================ */
.plans{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; max-width:1200px; margin:0 auto; }
.plan{ background:var(--paper); color:var(--ink); border-radius:var(--r-card); padding:40px 32px; border:1px solid var(--line-2); position:relative; }
.plan--featured{ background:#2A0040; color:#fff; border:none; }
.plan__badge{ position:absolute; top:24px; right:24px; font-size:11px; font-weight:600; color:var(--pink); text-transform:uppercase; letter-spacing:0.08em; }
.plan__name{ font-size:14px; font-weight:600; letter-spacing:-0.01em; }
.plan__price{ font-size:64px; font-weight:600; letter-spacing:-0.03em; margin-top:12px; line-height:1; }
.plan__per{ font-size:13px; color:var(--ink-soft); margin-top:6px; }
.plan--featured .plan__per{ color:rgba(255,255,255,0.6); }
.plan__list{ list-style:none; padding:0; margin:32px 0 0; display:grid; gap:12px; font-size:15px; }
.plan__list li{ display:flex; gap:10px; }
.plan__list li::before{ content:"✓"; color:var(--purple); }
.plan--featured .plan__list li::before{ color:var(--red); }

/* ============================================================
   STANDORTE / GEO
   ============================================================ */
.geo-grid{ display:grid; grid-template-columns:1.5fr 1fr; gap:14px; }
.map{ border-radius:var(--r-card); overflow:hidden; position:relative; aspect-ratio:4/3; border:1px solid rgba(0,0,0,0.06); min-height:300px; }
.map__label{ position:absolute; top:18px; left:20px; font-size:11px; font-weight:500; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-soft); }
.map__pin{ position:absolute; left:30%; top:62%; display:flex; align-items:center; gap:10px; }
.map__pin .dot{ width:16px; height:16px; border-radius:50%; background:var(--red); box-shadow:0 0 0 8px rgba(230,0,45,0.12); }
/* SVG-Karte: implec-Standorte Deutschland + Niederrhein-Inset (self-hosted, kein externer Karten-Dienst -> DSGVO-konform) */
.map--geo{ background:#fff; }
.map--geo .map__label{ z-index:2; }
.geo-svg{ position:absolute; inset:0; width:100%; height:100%; display:block; }
.geo-de{ fill:url(#geoGlow); stroke:rgba(60,0,95,0.35); stroke-width:1.5; stroke-linejoin:round; }
.geo-link{ fill:none; stroke:rgba(230,0,45,0.45); stroke-width:1.2; stroke-dasharray:3 4; }
.geo-lens{ fill:none; stroke:rgba(60,0,95,0.16); stroke-width:1; stroke-dasharray:2 4; }
.geo-inset{ fill:#faf8fc; stroke:rgba(60,0,95,0.18); }
.geo-ititle{ fill:var(--ink-soft); font-family:var(--mono); font-size:9px; letter-spacing:0.06em; }
.geo-ispoke{ fill:none; stroke:rgba(60,0,95,0.20); stroke-width:0.8; stroke-dasharray:1 4; }
.geo-idot{ fill:var(--purple); stroke:#fff; stroke-width:1; }
.geo-ilabel{ fill:var(--ink-soft); font-family:var(--mono); font-size:6.5px; }
.geo-icore{ fill:var(--red); stroke:#fff; stroke-width:1.5; }
.geo-pin2{ fill:var(--red-deep); stroke:#fff; stroke-width:2; }
.geo-sub{ fill:var(--ink-soft); font-family:var(--mono); font-size:9px; letter-spacing:0.05em; }
.geo-label--main{ fill:var(--red); font-family:var(--sans); font-size:12.5px; font-weight:700; letter-spacing:-0.01em; }
.geo-label--main2{ fill:var(--red-deep); font-family:var(--sans); font-size:12.5px; font-weight:700; letter-spacing:-0.01em; }
.geo-pin__halo{ fill:none; stroke:rgba(230,0,45,0.30); stroke-width:1.5; }
.geo-pin__pulse{ fill:rgba(230,0,45,0.22); }
.geo-pin__core{ fill:var(--red); stroke:#fff; stroke-width:2; }
@media (prefers-reduced-motion:no-preference){ .geo-pin__pulse{ transform-box:fill-box; transform-origin:center; animation:geo-pulse 2.6s ease-out infinite; } }
@keyframes geo-pulse{ 0%{ transform:scale(.5); opacity:.55; } 70%{ transform:scale(2.4); opacity:0; } 100%{ transform:scale(2.4); opacity:0; } }
.loc-stack{ display:grid; gap:14px; }
.loc-card{ background:#fff; border-radius:20px; padding:24px 26px; border:1px solid rgba(0,0,0,0.06); }
.loc-card__head{ display:flex; justify-content:space-between; align-items:baseline; }
.loc-card h3{ font-size:24px; font-weight:600; letter-spacing:-0.02em; margin:8px 0; }
.loc-card p{ font-size:14px; color:var(--ink-soft); margin:0; line-height:1.5; }

/* ============================================================
   ZITAT (großes Testimonial)
   ============================================================ */
.quote{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; border-radius:28px; overflow:hidden; background:var(--paper); border:1px solid rgba(0,0,0,0.06); }
.quote__media{ min-height:480px; position:relative; }
.quote__body{ padding:56px 48px; display:flex; flex-direction:column; justify-content:center; }
.quote__text{ font-size:28px; font-weight:500; line-height:1.3; letter-spacing:-0.02em; color:var(--ink); margin:0; }
.avatar{ width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--purple),var(--red)); display:inline-flex; align-items:center; justify-content:center; color:#fff; font-size:14px; font-weight:600; }
.who{ display:flex; gap:12px; align-items:center; margin-top:28px; }
.who b{ font-size:16px; font-weight:600; color:var(--ink); display:block; }
.who span{ font-size:13px; color:var(--ink-soft); }
.metrics{ display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:32px; padding-top:28px; border-top:1px solid var(--line-2); }
.metrics .m-num{ font-size:40px; font-weight:600; letter-spacing:-0.03em; color:var(--ink); line-height:1; }
.metrics .m-cap{ font-size:13px; color:var(--ink-soft); margin-top:6px; }

/* ============================================================
   VERGLEICHSTABELLE
   ============================================================ */
.compare{ border-radius:var(--r-card); overflow:hidden; border:1px solid var(--line-3); background:#fff; }
.compare__row{ display:grid; grid-template-columns:1fr 1fr 1.1fr; font-size:15px; }
.compare__row--head{ background:#2A0040; color:#fff; }
.compare__row:nth-child(even){ background:var(--paper); }
.compare__cell{ padding:16px 24px; }
.compare__cell--head{ font-weight:600; font-size:14px; }
.compare__cell--key{ font-weight:600; color:var(--ink); }
.compare__cell--other{ color:var(--ink-soft); }
.compare__cell--win{ color:var(--ink); background:rgba(60,0,95,0.03); display:flex; gap:8px; }
.compare__cell--win::before{ content:"✓"; color:var(--red); font-weight:700; }
.compare__cell--implec{ background:var(--purple); display:flex; align-items:center; gap:8px; }

/* ============================================================
   BEWERTUNGEN (Masonry)
   ============================================================ */
.reviews{ columns:3 320px; column-gap:16px; }
.review{ break-inside:avoid; margin-bottom:16px; background:var(--paper); border-radius:18px; padding:26px 28px; border:1px solid rgba(60,0,95,0.07); }
.review__stars{ color:var(--gold); font-size:15px; margin-bottom:12px; }
.review p{ font-size:15.5px; line-height:1.55; color:var(--ink); margin:0 0 18px; }
.review__who{ display:flex; align-items:center; gap:11px; }
.review__ava{ width:38px; height:38px; border-radius:50%; background:var(--purple); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:600; font-size:14px; }
.review__who b{ font-size:15px; font-weight:600; color:var(--ink); }

/* ============================================================
   FAQ
   ============================================================ */
.faq-cat{ font-size:15px; font-weight:700; color:var(--accent); letter-spacing:0.02em; margin:40px 0 6px; text-transform:uppercase; }
.faq-cat:first-of-type{ margin-top:32px; }
details.faq{ border-top:1px solid var(--line-3); }
details.faq > summary{ list-style:none; padding:18px 0; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:20px; font-size:18px; font-weight:600; color:var(--ink); }
details.faq > summary::-webkit-details-marker{ display:none; }
.faq-plus{ color:var(--red); font-size:22px; flex-shrink:0; transition:transform .2s ease; }
details.faq[open] .faq-plus{ transform:rotate(45deg); }
details.faq p{ font-size:16px; line-height:1.6; color:var(--ink-soft); margin:0 0 20px; max-width:780px; }

/* ============================================================
   KONTAKT (Formular + Kontaktwege)
   ============================================================ */
.form{ background:#fff; border-radius:var(--r-card); padding:36px; border:1px solid var(--line); }
.form label{ display:block; font-size:13px; font-weight:600; color:var(--ink); margin-bottom:6px; }
.input{ width:100%; padding:13px 14px; border-radius:12px; border:1px solid rgba(60,0,95,0.15); font-size:15px; font-family:inherit; background:var(--paper); }
.field{ margin-bottom:16px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form__hint{ font-size:12px; color:var(--ink-faint); margin:14px 0 0; text-align:center; }
.form__success{ text-align:center; padding:40px 10px; }
.form__check{ width:64px; height:64px; border-radius:50%; background:rgba(230,0,45,0.1); color:var(--red); display:flex; align-items:center; justify-content:center; font-size:30px; margin:0 auto 18px; }
.ways{ display:grid; gap:16px; }
.way{ display:flex; gap:18px; align-items:center; background:#fff; color:var(--ink); border-radius:18px; padding:24px 26px; border:1px solid var(--line); }
.way--hot{ background:#2A0040; color:#fff; border:none; }
.way__icon{ font-size:30px; flex-shrink:0; }
.way__body{ flex:1; }
.way__body h3{ font-size:19px; font-weight:700; letter-spacing:-0.015em; margin:0 0 4px; }
.way__body p{ font-size:13.5px; margin:0; line-height:1.4; color:var(--ink-soft); }
.way--hot .way__body p{ color:rgba(255,255,255,0.7); }
.way__cta{ padding:10px 18px; background:var(--panel); color:var(--purple); border-radius:var(--r-pill); font-size:13.5px; font-weight:600; white-space:nowrap; text-decoration:none; }
.way--hot .way__cta{ background:var(--red); color:#fff; }

/* ============================================================
   GLOSSAR / WHITEPAPER
   ============================================================ */
.gloss-row{ display:flex; justify-content:space-between; align-items:center; padding:14px 0; border-top:1px solid var(--line-2); text-decoration:none; color:var(--ink); transition:opacity .15s ease; }
.gloss-row:hover{ opacity:.65; }
.gloss-row b{ font-size:17px; font-weight:500; }
.gloss-row span{ font-size:12px; color:var(--ink-faint); font-weight:500; }

/* ============================================================
   FOOTER  (Haupt-Website, hell)
   ============================================================ */
.site-footer{ background:var(--cream); padding:24px 22px 44px; font-size:12px; color:var(--ink-soft); letter-spacing:-0.01em; }
.site-footer__top{ margin:0 0 24px; border-bottom:1px solid var(--line-2); padding-bottom:18px; }
.foot-cols{ display:grid; grid-template-columns:repeat(5,1fr); gap:32px; padding-bottom:24px; border-bottom:1px solid var(--line-2); }
.foot-cols h4{ margin:0 0 12px; font-size:12px; font-weight:600; color:var(--ink); }
.foot-cols ul{ list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.foot-cols a{ color:var(--ink-soft); text-decoration:none; }
.foot-legal{ margin-top:18px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.foot-legal__links{ display:flex; gap:18px; flex-wrap:wrap; }
.foot-legal a{ color:var(--ink-soft); text-decoration:none; }

/* ============================================================
   FOOTER  (Schwester-Seiten, dunkel)
   ============================================================ */
.dfooter{ background:var(--purple-deep); color:#fff; padding:64px 26px 36px; }
.dfooter__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,0.14); }
.dfooter__brand{ font-size:24px; font-weight:700; letter-spacing:-0.03em; }
.dfooter p{ font-size:15px; color:rgba(255,255,255,0.7); line-height:1.5; max-width:320px; margin-top:14px; }
.dfooter h4{ font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:rgba(255,255,255,0.55); margin:0 0 14px; font-weight:600; }
.dfooter ul{ list-style:none; padding:0; margin:0; display:grid; gap:9px; font-size:14px; }
.dfooter ul a{ color:rgba(255,255,255,0.85); text-decoration:none; }
.dfooter__by{ display:flex; align-items:center; gap:9px; margin-top:20px; font-size:13px; color:rgba(255,255,255,0.6); }
.dfooter__partner{ margin-top:16px; }
.dfooter__partner span{ padding:5px 12px; border-radius:var(--r-pill); background:rgba(255,255,255,0.1); font-size:12px; }
.dfooter__legal{ padding-top:24px; display:flex; justify-content:space-between; font-size:12px; color:rgba(255,255,255,0.55); flex-wrap:wrap; gap:12px; }
.dfooter__legal a{ color:inherit; text-decoration:none; margin-left:0; }
.dfooter__legal-links{ display:flex; gap:18px; }

/* ============================================================
   SCHWESTER-NAV
   ============================================================ */
.snav{ background:rgba(251,252,254,0.85); backdrop-filter:saturate(180%) blur(20px); -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--line); padding:0 26px; height:56px; display:flex; align-items:center; justify-content:space-between; }
.snav__brand{ display:flex; align-items:center; gap:11px; text-decoration:none; }
.snav__name{ font-size:21px; font-weight:700; letter-spacing:-0.03em; color:var(--purple-deep); }
.snav__name span{ color:var(--accent); }
.snav__by{ display:flex; align-items:center; gap:6px; border-left:1px solid rgba(60,0,95,0.15); padding-left:11px; font-size:12px; color:var(--ink-soft); }
.snav__links{ display:flex; gap:30px; list-style:none; padding:0; margin:0; font-size:14px; font-weight:500; }
.snav__links li{ color:var(--purple-deep); opacity:.8; }
.snav__links li.active{ color:var(--accent); opacity:1; }
.snav__actions{ display:flex; align-items:center; gap:14px; }

/* Capability-Grid (Schwester) */
.caps{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.cap{ background:#fff; border-radius:var(--r-card-sm); padding:28px 26px; min-height:160px; display:flex; flex-direction:column; box-shadow:0 1px 3px rgba(60,0,95,0.05); }
.cap__icon{ font-size:26px; }
.cap h3{ font-size:20px; font-weight:600; color:var(--purple-deep); line-height:1.15; margin:auto 0 0; }
.cap--wide{ grid-column:span 2; flex-direction:row; align-items:stretch; padding:0; overflow:hidden; display:grid; grid-template-columns:1fr 1.1fr; }
.cap--wide .cap__txt{ padding:28px 26px; }
.cap--wide h3{ margin:0 0 10px; font-size:21px; }
.cap--wide p{ font-size:13.5px; color:var(--ink-soft); line-height:1.5; margin:0; max-width:240px; }
.cap--wide .cap__media{ position:relative; min-height:160px; }

/* Bento (Schwester, 6-Spalten-Optik → 3) */
.sbento{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.sbento__tile{ border-radius:20px; overflow:hidden; position:relative; min-height:300px; background:#fff; color:var(--purple-deep); border:1px solid var(--line); }
.sbento__tile--dark{ background:#1a0030; color:#fff; border:none; }
.sbento__tile--wide{ grid-column:span 2; }
.sbento__tile .inner{ position:relative; padding:32px; }
.sbento__tile .inner p{ font-size:13px; font-weight:600; margin:0; }
.sbento__tile .inner h3{ font-size:26px; font-weight:700; letter-spacing:-0.02em; line-height:1.1; margin:8px 0 0; max-width:300px; }

/* CTA-Band (Schwester) */
.cta-band{ padding:100px 26px; background:linear-gradient(135deg,#25003B 0%,#1a0030 100%); color:#fff; text-align:center; position:relative; overflow:hidden; }
.cta-band__glow{ position:absolute; bottom:-30%; left:50%; transform:translateX(-50%); width:700px; height:700px; border-radius:50%; background:radial-gradient(circle,rgba(230,0,45,0.24),transparent 70%); }
.cta-band__inner{ position:relative; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1040px){
  .nav__links, .snav__links{ display:none; }
  .burger{ display:inline-flex; }
  .bento, .bento__col, .grid--2, .grid--3, .grid--4, .disc-grid, .plans, .geo-grid, .quote, .sbento, .caps, .dfooter__grid, .foot-cols, .field-row, .mega__grid{ grid-template-columns:1fr; }
  .tile--big{ min-height:auto; }
  .sbento__tile--wide, .cap--wide{ grid-column:span 1; }
  .cap--wide{ grid-template-columns:1fr; }
  .utility{ padding:7px 20px; }
  .nav, .snav{ padding:0 20px; }
}
@media (max-width:760px){
  .section, .section--lg{ padding-left:18px; padding-right:18px; }
  .stats, .spec{ grid-template-columns:1fr 1fr; }
  .stat, .spec__item{ border-right:none; border-bottom:1px solid var(--line-2); }
  .reviews{ columns:1; }
  .compare__row{ grid-template-columns:1fr; }
  .hero__content{ left:6%; right:6%; }
  .showreel, .price-pill{ display:none; }
}

/* ============================================================
   UNTERSEITEN-KOMPONENTEN
   ============================================================ */
/* aktiver Nav-Link */
.nav__links > li.active{ border-bottom:2px solid var(--red); height:60px; display:flex; align-items:center; }
.nav__links > li a{ text-decoration:none; color:inherit; }

/* Sub-Hero (heller Seitenkopf) */
.subhero{ padding:80px 22px 48px; text-align:center; }
.subhero .eyebrow{ display:block; }
.subhero .lead{ max-width:680px; margin:0 auto; }
.subhero--left{ text-align:left; }
.subhero--left .lead{ margin:0; }
.breadcrumb{ font-family:var(--mono); font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:18px; }
.breadcrumb a{ color:var(--ink-soft); text-decoration:none; }

/* Feature-Karte (Icon + Titel + Text) */
.feat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.feat{ background:#fff; border:1px solid var(--rule, rgba(60,0,95,0.1)); border-radius:20px; padding:30px 28px; }
.feat__icon{ width:48px; height:48px; border-radius:12px; background:rgba(60,0,95,0.08); display:flex; align-items:center; justify-content:center; margin-bottom:18px; color:var(--purple); }
.feat h3{ font-size:21px; font-weight:600; letter-spacing:-0.015em; margin:0 0 8px; color:var(--ink); }
.feat p{ font-size:15px; color:var(--ink-soft); line-height:1.55; margin:0; }

/* Team-Grid */
.team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.member{ text-align:center; }
.member__photo{ aspect-ratio:1; border-radius:20px; overflow:hidden; position:relative; margin-bottom:14px; }
.member h3{ font-size:17px; font-weight:600; margin:0; color:var(--ink); }
.member p{ font-size:13px; color:var(--ink-soft); margin:2px 0 0; }

/* Werte / Icon-Liste */
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.value h3{ font-size:20px; font-weight:600; margin:0 0 8px; color:var(--ink); }
.value p{ font-size:15px; color:var(--ink-soft); line-height:1.55; margin:0; }

/* Jobs-Liste */
.jobs{ display:grid; gap:12px; }
.job{ display:flex; justify-content:space-between; align-items:center; gap:20px; background:#fff; border:1px solid var(--rule, rgba(60,0,95,0.1)); border-radius:16px; padding:22px 26px; text-decoration:none; color:var(--ink); transition:box-shadow .2s ease, transform .2s ease; flex-wrap:wrap; }
.job:hover{ box-shadow:0 12px 30px rgba(60,0,95,0.10); transform:translateY(-2px); }
.job h3{ font-size:19px; font-weight:600; margin:0; }
.job__meta{ font-size:13px; color:var(--ink-soft); margin-top:4px; }

/* Artikel-Layout (Blog) */
.answer-box{ background:#f0edf3; border-radius:16px; padding:26px 30px; max-width:760px; margin:0 auto; }
.answer-box .label{ font-family:var(--mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--implec-red,#E6002D); }
.answer-box p{ font-size:19px; font-weight:600; line-height:1.5; color:var(--ink); margin:8px 0 0; }
.article{ max-width:720px; margin:0 auto; }
.article p{ font-size:17px; line-height:1.75; color:var(--ink-2,#2A2530); margin:0 0 22px; }
.article h2{ font-size:28px; font-weight:600; letter-spacing:-0.02em; margin:40px 0 14px; color:var(--ink); }
.article ul{ font-size:17px; line-height:1.7; color:var(--ink-2,#2A2530); padding-left:22px; margin:0 0 22px; }
.article li{ margin-bottom:8px; }
.byline{ display:flex; align-items:center; gap:12px; justify-content:center; margin-top:24px; font-size:14px; color:var(--ink-soft); }
.author-box{ display:flex; gap:18px; align-items:center; background:var(--paper); border:1px solid var(--rule, rgba(60,0,95,0.1)); border-radius:20px; padding:26px 28px; max-width:720px; margin:40px auto 0; }
.fullbleed-img{ aspect-ratio:21/9; position:relative; overflow:hidden; border-radius:24px; }

/* Prozess-Schritte (Case-Detail) */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.step__num{ font-family:var(--mono); font-size:13px; color:var(--implec-red,#E6002D); letter-spacing:0.08em; }
.step h3{ font-size:20px; font-weight:600; margin:8px 0 8px; color:var(--ink); }
.step p{ font-size:15px; color:var(--ink-soft); line-height:1.6; margin:0; }

@media (max-width:1040px){
  .feat-grid, .team-grid, .values, .steps{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  .feat-grid, .team-grid, .values, .steps{ grid-template-columns:1fr; }
}

/* Split-Layout (Bild/Text nebeneinander, bricht mobil um) */
.split{ display:grid; grid-template-columns:3fr 2fr; }
.split--even{ grid-template-columns:1fr 1fr; }
@media (max-width:1040px){ .split, .split--even{ grid-template-columns:1fr; } }

/* ============================================================
   LEXIKON
   ============================================================ */
.lex-search{ max-width:560px; margin:0 auto 22px; position:relative; }
.lex-search input{ width:100%; padding:15px 18px; border-radius:var(--r-pill); border:1px solid var(--line-3); font-size:16px; font-family:inherit; background:#fff; }
.lex-search input:focus{ outline:none; border-color:var(--purple); box-shadow:0 0 0 3px rgba(60,0,95,0.10); }
.az{ display:flex; flex-wrap:wrap; gap:6px; justify-content:center; max-width:760px; margin:0 auto 16px; }
.az button{ min-width:34px; height:34px; padding:0 8px; border-radius:9px; border:1px solid var(--line-3); background:#fff; color:var(--ink); font-family:var(--mono); font-size:13px; cursor:pointer; transition:background .15s ease,color .15s ease; }
.az button:hover{ background:var(--panel); }
.az button.active{ background:var(--ink); color:#fff; border-color:var(--ink); }
.az button:disabled{ opacity:.3; cursor:default; }
.lex-count{ text-align:center; font-family:var(--mono); font-size:12px; color:var(--ink-soft); margin-bottom:28px; }
.lex-group{ margin-bottom:18px; }
.lex-group__letter{ font-family:var(--mono); font-size:13px; letter-spacing:0.1em; color:var(--red); border-bottom:1px solid var(--line-3); padding-bottom:8px; margin:0 0 6px; }
.lex-item{ display:block; padding:16px 4px; border-bottom:1px solid var(--line-2); text-decoration:none; color:var(--ink); transition:background .12s ease; }
.lex-item:hover{ background:var(--paper); }
.lex-item b{ font-size:18px; font-weight:600; }
.lex-item .lex-cat{ font-family:var(--mono); font-size:10px; letter-spacing:0.08em; text-transform:uppercase; color:var(--purple); background:rgba(60,0,95,0.07); padding:2px 8px; border-radius:4px; margin-left:8px; }
.lex-item p{ margin:6px 0 0; font-size:14.5px; color:var(--ink-soft); line-height:1.5; }
.lex-empty{ text-align:center; color:var(--ink-soft); padding:40px 0; display:none; }
/* Begriffsseite */
.term-def{ font-size:21px; line-height:1.6; color:var(--ink-2,#2A2530); max-width:720px; }
.seealso{ display:flex; flex-wrap:wrap; gap:8px; }
.seealso a{ padding:8px 16px; border-radius:var(--r-pill); background:var(--panel); color:var(--purple); font-size:14px; text-decoration:none; }
.seealso a:hover{ background:rgba(60,0,95,0.12); }
