/* ============================================================
   FLOWAGENTEN COMPONENT LIBRARY v3.0
   Flowagenten Corporate Design System
   Raster: 12-Column / 1088px Content / 40px Gutter
   ============================================================ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img, video { display: block; max-width: 100%; height: auto; }

:root {
  /* Hintergründe — #151539 Grundton */
  --bg-deep: #151539;
  --bg-primary: #151539;
  --bg-secondary: #1A1A42;
  --bg-card: #1F1F4A;
  --bg-card-hover: #262652;
  --bg-elevated: #22224E;
  --white: #ffffff;
  --off-white: #f5f8ff;
  --warm-gray: #f0ede8;        /* Warm Gray */

  /* Akzent — Cyan/Mint (Content, Links, Buttons, Tags) */
  --accent: #67DEE3;
  --accent-hover: #8FFBBD;
  --accent-light: #8FFBBD;
  --accent-glow: rgba(103, 222, 227, 0.12);
  --accent-gradient: linear-gradient(135deg, #67DEE3, #8FFBBD);

  /* Sekundär-Akzent — Pink/Magenta (Highlights, CTAs, Badges) */
  --pink: #FF2B84;
  --pink-hover: #FF4D9A;
  --pink-deep: #AC0A4D;
  --pink-glow: rgba(255, 43, 132, 0.15);
  --pink-gradient: linear-gradient(30deg, #AC0A4D 18%, #FF2B84);

  /* Blau-Verlauf (Hintergrund-Akzente, Glow) */
  --blue-deep: #110BB9;
  --blue-bright: #0058FF;
  --blue-gradient: linear-gradient(135deg, #110BB9, #0058FF);

  /* Text Dark BG */
  --t1: #eef0f6;
  --t2: #c2c7d6;
  --t3: #5c6380;

  /* Text Light BG */
  --tl1: #051c2c;
  --tl2: #2d3748;
  --tl3: #9098b0;

  /* Borders */
  --border: rgba(255,255,255,0.06);
  --border-accent: #AC0A4D;
  --border-light: #e2e8f0;

  /* Glass */
  --glass: rgba(255,255,255,0.04);
  --glass-border: rgba(255,255,255,0.08);

  /* Type */
  --heading: 'Wix Madefor Display', system-ui, sans-serif;
  --body: 'Wix Madefor Text', system-ui, sans-serif;
  --display: 'Wix Madefor Display', system-ui, sans-serif;
  --display-num: 'Wix Madefor Display', system-ui, sans-serif;

  /* Aurora Atmosphere — Blau (#0058FF) + Pink (#FF2B84) als atmosphärische Farblichter */
  --aurora-blue: rgba(0, 88, 255, 0.35);
  --aurora-cyan: rgba(0, 88, 255, 0.14);
  --aurora-red: rgba(255, 43, 132, 0.35);
  --aurora-pink: rgba(255, 43, 132, 0.18);
  --aurora-purple: rgba(0, 55, 180, 0.15);

  /* Grid: 12 cols × 50.7px + 11 gutters × 40px = 1088px */
  --content: 1088px;
  --content-wide: 1360px;       /* Wide Container */
  --content-narrow: 720px;
  --gutter: 40px;
  --section-gap: 120px;         /* Section Spacing */

  /* Radii — 22px als Standard für Bilder + Boxen */
  --r-container: 22px;          /* Große Flächen, Bilder */
  --r-button: 999px;            /* Buttons — Pill */
  --r-card: 22px;               /* Cards + Boxen */
  --r-input: 12px;              /* Eingabefelder */
  --r-tag: 100px;               /* Service-Tags: Pill */

  /* Transitions */
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --t-smooth: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  --t-fast: all 0.2s ease;
}

/* ============================================================
   PRODUKTWELT — Light Mode CSS Variables Override
   Activated by [data-world="produkt"]
   ============================================================ */
[data-world="produkt"] {
  /* Hintergründe — Light */
  --bg-deep: #ffffff;
  --bg-primary: #ffffff;
  --bg-secondary: #f8f9fc;
  --bg-card: #f8f9fc;
  --bg-card-hover: #eef0f7;
  --bg-elevated: #ffffff;

  /* Text — Dark */
  --t1: #051c2c;
  --t2: #2d3748;
  --t3: #9098b0;

  /* Akzent — Blau für Light BG Kontrast */
  --accent: #0058FF;
  --accent-hover: #0047cc;
  --accent-light: #3378FF;
  --accent-glow: rgba(0, 88, 255, 0.08);
  --accent-gradient: linear-gradient(135deg, #0058FF, #3378FF);

  /* Pink auf Light */
  --pink: #AC0A4D;
  --pink-hover: #D01060;
  --pink-glow: rgba(172, 10, 77, 0.10);

  /* Borders — Light */
  --border: rgba(0,0,0,0.08);
  --border-accent: rgba(0, 88, 255, 0.20);

  /* Glass — Light */
  --glass: rgba(0,0,0,0.02);
  --glass-border: rgba(0,0,0,0.08);

  /* Text Light BG — expliziter Reset (nötig wenn parent data-world="marke" hat) */
  --tl1: #051c2c;
  --tl2: #2d3748;
  --tl3: #9098b0;

  /* Aurora hidden in Produktwelt */
}

body {
  font-family: var(--body);
  font-size: 16px;
  font-weight: 450;
  line-height: 1.6;
  color: var(--t1);
  background: var(--bg-primary);
  -webkit-font-smoothing: antialiased;
  transition: background 0.5s var(--ease), color 0.3s var(--ease);
}
img { max-width: 100%; display: block; border-radius: 22px; }
a { text-decoration: none; color: inherit; }

/* === AURORA ATMOSPHERE — Sanftes, flächiges Farbfließen === */
@keyframes atmo-drift-1 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 1; }
  25% { transform: translate(120px, -80px) scale(1.08); opacity: 0.85; }
  50% { transform: translate(-60px, 60px) scale(0.95); opacity: 1; }
  75% { transform: translate(80px, 100px) scale(1.05); opacity: 0.9; }
}
@keyframes atmo-drift-2 {
  0%, 100% { transform: translate(0, 0) scale(1.05); opacity: 0.9; }
  30% { transform: translate(-140px, 70px) scale(0.92); opacity: 1; }
  60% { transform: translate(80px, -100px) scale(1.1); opacity: 0.85; }
  85% { transform: translate(-60px, -40px) scale(0.98); opacity: 0.95; }
}
@keyframes atmo-drift-3 {
  0%, 100% { transform: translate(0, 0) scale(0.98); opacity: 0.85; }
  35% { transform: translate(100px, 80px) scale(1.06); opacity: 1; }
  70% { transform: translate(-110px, -50px) scale(1.02); opacity: 0.9; }
}
@keyframes atmo-drift-4 {
  0%, 100% { transform: translate(0, 0) scale(1.02); opacity: 0.9; }
  20% { transform: translate(-80px, -90px) scale(0.95); opacity: 1; }
  45% { transform: translate(100px, 30px) scale(1.08); opacity: 0.8; }
  70% { transform: translate(-40px, 70px) scale(0.98); opacity: 0.95; }
}
@keyframes atmo-drift-5 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.8; }
  40% { transform: translate(60px, -60px) scale(1.1); opacity: 1; }
  75% { transform: translate(-90px, 40px) scale(0.94); opacity: 0.85; }
}

.aurora {
  position: relative;
  overflow: clip;
}

/* Atmosphären-Container — nimmt vollen Raum ein, reicht weit nach unten */
.aurora-atmosphere {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  /* Erstreckt sich 40% über die Section hinaus nach unten */
  height: 140%;
}

/* Gemeinsame Blob-Basis */
.aurora-atmosphere span {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  will-change: transform, opacity;
}

/* Blob 1 — Deep Blue (#110BB9), groß, oben links */
.aurora-atmosphere .atmo-blob-1 {
  width: 1000px; height: 1000px;
  background: radial-gradient(ellipse at center, var(--aurora-blue) 0%, transparent 60%);
  filter: blur(160px);
  top: -20%; left: -15%;
  animation: atmo-drift-1 35s ease-in-out infinite;
}

/* Blob 2 — Deep Red (#AC0A4D), groß, rechts oben */
.aurora-atmosphere .atmo-blob-2 {
  width: 900px; height: 900px;
  background: radial-gradient(ellipse at center, var(--aurora-red) 0%, transparent 60%);
  filter: blur(170px);
  top: -10%; right: -12%;
  animation: atmo-drift-2 40s ease-in-out infinite;
}

/* Blob 3 — Purple (Mischton aus Blau+Rot), Mitte */
.aurora-atmosphere .atmo-blob-3 {
  width: 800px; height: 800px;
  background: radial-gradient(ellipse at center, var(--aurora-purple) 0%, transparent 60%);
  filter: blur(160px);
  top: 25%; left: 30%;
  animation: atmo-drift-3 45s ease-in-out infinite;
}

/* Blob 4 — Blau-Hauch (#110BB9), unten links */
.aurora-atmosphere .atmo-blob-4 {
  width: 700px; height: 700px;
  background: radial-gradient(ellipse at center, var(--aurora-cyan) 0%, transparent 60%);
  filter: blur(180px);
  bottom: 5%; left: 10%;
  animation: atmo-drift-4 38s ease-in-out infinite;
}

/* Blob 5 — Soft Pink (#AC0A4D heller), unten rechts */
.aurora-atmosphere .atmo-blob-5 {
  width: 750px; height: 750px;
  background: radial-gradient(ellipse at center, var(--aurora-pink) 0%, transparent 60%);
  filter: blur(190px);
  bottom: -5%; right: 20%;
  animation: atmo-drift-5 42s ease-in-out infinite;
}

/* Fallback: alte .aurora-glow weiterhin unterstützen */
.aurora-glow {
  position: absolute;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--aurora-purple) 0%, transparent 70%);
  filter: blur(160px);
  pointer-events: none;
  z-index: 0;
  top: 30%; left: 40%;
  animation: atmo-drift-3 45s ease-in-out infinite;
}

/* Alte ::before / ::after Blobs bleiben für Sektionen ohne neues Markup */
.aurora::before,
.aurora::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  filter: blur(180px);
  pointer-events: none;
  z-index: 0;
  will-change: transform;
}
.aurora::before {
  width: 800px; height: 800px;
  background: radial-gradient(ellipse at center, var(--aurora-red) 0%, transparent 65%);
  top: -15%; left: -10%;
  animation: atmo-drift-1 35s ease-in-out infinite;
}
.aurora::after {
  width: 900px; height: 900px;
  background: radial-gradient(ellipse at center, var(--aurora-blue) 0%, transparent 65%);
  bottom: -20%; right: -10%;
  animation: atmo-drift-2 40s ease-in-out infinite;
}

/* Content muss über der Aurora liegen */
.aurora > .content,
.aurora > .content-wide,
.aurora > .aurora-inner {
  position: relative;
  z-index: 1;
}

/* Aurora hidden in Produktwelt — AUSSER in Hero-Sections */
[data-world="produkt"] .aurora::before,
[data-world="produkt"] .aurora::after,
[data-world="produkt"] .aurora-glow,
[data-world="produkt"] .aurora-atmosphere {
  display: none;
}
/* Hero behält Aurora + Video in Produktwelt */
[data-world="produkt"] .hero .aurora-atmosphere,
[data-world="produkt"] .hero.aurora::before,
[data-world="produkt"] .hero.aurora::after,
[data-world="produkt"] .hero .hero-video-bg,
[data-world="produkt"] .hero-video-bg {
  display: block;
}

/* === GRID SYSTEM === */
.content { max-width: var(--content); margin: 0 auto; padding: 0 2rem; }
.content-wide { max-width: var(--content-wide); margin: 0 auto; padding: 0 2rem; }

/* ============================================================
   1. SECTION LABEL
   Klein, UPPERCASE, Linie darunter. KEINE Pill-Badges.
   ============================================================ */
.section-label {
  font-family: var(--body);
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  margin-bottom: 40px;
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-label--light {
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-label--dark {
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ============================================================
   1b. GRADIENT TEXT — Cyan/Mint-Verlauf für Headlines auf hellem BG
   ============================================================ */
.text-gradient {
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
/* H1 Display — immer weiß in beiden Welten (Hero bleibt dunkel) */
.h-display {
  color: var(--white);
  -webkit-text-fill-color: var(--white);
  background: none;
}
/* Light-Heros: H1 immer Gradient */
.hero--light .h-display {
  color: var(--white) !important;
  -webkit-text-fill-color: var(--white) !important;
  background: none !important;
}

/* ============================================================
   2. HEADLINES — Leicht (300–500), groß, eng
   ============================================================ */
.h-display {
  font-family: var(--display);
  font-size: clamp(28px, 4vw, 56px);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: normal;
}

/* ============================================================
   SCROLL REVEAL — GPU-Accelerated Transition System
   ============================================================
   Approach:
   - Elements start at opacity:0 + translate3d (GPU layer)
   - IntersectionObserver adds .is-visible
   - CSS transitions handle the animation (more reliable than
     keyframes — transitions fire even on background tabs)
   - Stagger via --stagger-i CSS custom property → transition-delay
   - GPU-composited: only opacity + transform are animated
   - will-change hints removed on .is-visible to free GPU memory
   ============================================================ */

/* --- Base reveal: hidden by default, GPU-promoted --- */
.reveal {
  opacity: 0;
  transform: translate3d(0, 28px, 0);
  transition: opacity 0.65s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.65s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
  backface-visibility: hidden;
}
.reveal.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  will-change: auto;
}

/* Variant: bigger slide for images/media */
.reveal--up {
  transform: translate3d(0, 48px, 0);
}
.reveal--up.is-visible {
  transition-duration: 0.8s;
}

/* --- Headline: fade + subtle rise (no clip-path for reliability) --- */
.reveal-headline {
  opacity: 0;
  transform: translate3d(0, 20px, 0);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}
.reveal-headline.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  will-change: auto;
}

/* --- Stagger delay via CSS custom property (set by JS) --- */
.reveal-stagger > .reveal,
.reveal-stagger > * > .reveal {
  transition-delay: calc(var(--stagger-i, 0) * 0.08s);
}

/* ============================================================
   INTEGRATION ORBIT — Floating Bubbles mit echten Logos
   Split-Layout: Text links, Bubble-Cluster rechts
   ============================================================ */
.section-orbit {
  position: relative;
  padding: 80px 0;
  overflow: hidden;
  background: var(--bg-deep);
}
.orbit-layout {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 48px;
  align-items: center;
}
.orbit-text {
  position: relative;
  z-index: 2;
}
.orbit-text .checklist {
  color: var(--t2);
  margin-top: 20px;
}
/* Bubble-Feld */
.orbit-field {
  position: relative;
  width: 100%;
  height: 520px;
}
/* Einzelne Bubble */
.orbit-bubble {
  position: absolute;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: #ffffff;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 16px rgba(0,0,0,0.18), 0 0 0 1px rgba(255,255,255,0.06);
  transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1);
  will-change: transform;
  cursor: default;
  z-index: 2;
}
.orbit-bubble img {
  width: 28px; height: 28px;
  object-fit: contain;
  border-radius: 0;
}
.orbit-bubble--lg {
  width: 68px; height: 68px;
}
.orbit-bubble--lg img {
  width: 34px; height: 34px;
}
.orbit-bubble--sm {
  width: 46px; height: 46px;
}
.orbit-bubble--sm img {
  width: 22px; height: 22px;
}
/* Zentrales Element */
.orbit-center {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 100px; height: 100px;
  background: linear-gradient(135deg, #110BB9, #0058FF);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--heading);
  font-size: 13px; font-weight: 600;
  color: #ffffff;
  text-align: center;
  line-height: 1.25;
  letter-spacing: 0.02em;
  z-index: 5;
  box-shadow:
    0 0 40px rgba(0, 88, 255, 0.4),
    0 0 80px rgba(17, 11, 185, 0.2),
    0 0 0 1px rgba(255,255,255,0.1);
}
/* Konzentrisches Glow-Licht unter der gesamten Grafik */
.orbit-glow {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 480px; height: 480px;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(172, 10, 77, 0.22) 0%, transparent 50%),
    radial-gradient(circle at 40% 45%, rgba(17, 11, 185, 0.25) 0%, transparent 55%),
    radial-gradient(circle at 60% 55%, rgba(0, 88, 255, 0.18) 0%, transparent 50%);
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
}
/* Netzwerk-Canvas für Verbindungslinien */
.orbit-network {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 1;
}

.h-section {
  font-family: var(--heading);
  font-size: clamp(21px, 3.2vw, 37px);
  font-weight: 500;
  line-height: 1.15;
  letter-spacing: -0.02em;
}
.h-card {
  font-family: var(--heading);
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: -0.01em;
}
.h-small {
  font-family: var(--heading);
  font-size: 18px;
  font-weight: 600;
  line-height: 1.35;
}

/* ============================================================
   3. NAVIGATION — 90px, clean
   ============================================================ */
/* ---- Navigation — Sticky + Mega Dropdown ---- */
.nav-wrap {
  position: sticky;
  top: 0;
  z-index: 1000;
  width: 100%;
  background: #151539;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  transition: box-shadow 0.4s ease;
}
.nav-wrap--scrolled {
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
}

.nav {
  height: 72px;
  max-width: 1360px;
  margin: 0 auto;
  padding: 0 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.nav__logo {
  font-family: var(--heading);
  font-size: 20px;
  font-weight: 600;
  color: #ffffff;
  letter-spacing: -0.02em;
  flex-shrink: 0;
  text-decoration: none;
}
.nav__logo:hover {
  color: #ffffff;
  opacity: 0.85;
}

/* Primary links */
.nav__menu {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  height: 100%;
}
.nav__item {
  position: static;
  height: 100%;
  display: flex;
  align-items: center;
}
.nav__item > a {
  font-family: var(--heading);
  font-size: 16px;
  font-weight: 600;
  color: #ffffff;
  padding: 6px 16px;
  height: auto;
  display: flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  transition: color 0.25s ease, background-color 0.25s ease;
  white-space: nowrap;
}
.nav__item > a:hover,
.nav__item.is-open > a {
  color: #ffffff;
  background-color: rgba(255, 255, 255, 0.12);
}
.nav__item.is-active > a {
  color: #ffffff;
  background-color: rgba(255, 255, 255, 0.12);
}
.nav__item > a .nav__chevron {
  width: 10px;
  height: 10px;
  stroke: currentColor;
  transition: transform 0.3s ease;
}
.nav__item.is-open > a .nav__chevron {
  transform: rotate(180deg);
}

/* CTA button in nav */
.nav__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 14px 32px;
  background: linear-gradient(30deg, #AC0A4D 18%, #FF2B84);
  color: var(--white);
  font-family: var(--heading);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.02em;
  border: none;
  cursor: pointer;
  border-radius: 999px;
  transition: gap 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.2s ease;
  flex-shrink: 0;
  margin-left: 16px;
  /* Feste Breite für Hover-Zustand reservieren, damit Menü nicht springt */
  min-width: 210px;
  overflow: hidden;
}
.nav__cta .nav__cta-arrow {
  display: inline-flex;
  width: 0;
  opacity: 0;
  transition: width 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              opacity 0.25s ease;
  overflow: hidden;
  flex-shrink: 0;
}
.nav__cta .nav__cta-arrow svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.nav__cta:hover {
  gap: 8px;
  background: linear-gradient(30deg, #C01060 18%, #FF4D9A);
  box-shadow: 0 4px 20px rgba(255, 43, 132, 0.3);
}
.nav__cta:hover .nav__cta-arrow {
  width: 18px;
  opacity: 1;
}

/* ---- Mega Dropdown Panel — Full Width ---- */
/* ── Dropdown Panel (Full-width slide) ── */
.nav__dropdown {
  position: absolute;
  top: 72px;
  left: 0;
  right: 0;
  width: 100%;
  background: #ffffff;
  border-radius: 0;
  padding: 0;
  max-height: 0;
  opacity: 0;
  visibility: hidden;
  overflow: hidden;
  transition: max-height 0.45s cubic-bezier(0.4, 0, 0.2, 1),
              opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1),
              visibility 0.35s;
  pointer-events: none;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.08);
}
.nav__item.is-open .nav__dropdown {
  max-height: 800px;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Inner content constrained */
.nav__dd-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 48px 2rem;
  display: flex;
  gap: 64px;
}

/* ── Leistungen: Icon-Link Items ── */
.nav__dd-services {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 48px;
}
.nav__dd-col {
  display: flex;
  flex-direction: column;
}
.nav__dd-group-title {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--accent);
  margin-bottom: 8px;
  padding-bottom: 0;
  border-bottom: none;
}
.nav__dd-slink {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 12px;
  border-radius: 12px;
  transition: background 0.2s ease;
}
.nav__dd-slink:hover {
  background: rgba(0, 88, 255, 0.04);
}
.nav__dd-slink-icon {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(0, 88, 255, 0.06);
  color: #0058FF;
}
.nav__dd-slink-icon svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  stroke-width: 1.8;
  fill: none;
}
.nav__dd-slink-text {
  display: flex;
  flex-direction: column;
}
.nav__dd-slink-name {
  font-size: 15px;
  font-weight: 500;
  color: #0a0a27;
  line-height: 1.2;
}
.nav__dd-slink-desc {
  font-size: 12px;
  color: rgba(10, 10, 39, 0.45);
  margin-top: 2px;
  line-height: 1.4;
}

/* Category headers inside service columns */
.nav__dd-cat {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #0058FF;
  padding: 8px 12px 4px;
}

/* ── Branchen: Image Tile Cards (Responsive Grid Layout) ── */
.nav__dd-tiles {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.nav__dd-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  border-radius: 14px;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  cursor: pointer;
  text-decoration: none;
}
.nav__dd-tile:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}
.nav__dd-tile-img {
  width: 100%;
  aspect-ratio: 5 / 3;
  overflow: hidden;
  border-radius: 14px;
  background: #f0f2f5;
  display: flex;
  align-items: center;
  justify-content: center;
}
.nav__dd-tile-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.nav__dd-tile:hover .nav__dd-tile-img img {
  transform: scale(1.05);
}
.nav__dd-tile-name {
  font-size: 14px;
  font-weight: 500;
  color: #0a0a27;
  padding: 12px 4px 4px;
}
.nav__dd-tile-sub {
  font-size: 12px;
  color: #0058FF;
  font-weight: 500;
}

/* Right-side quicklinks (Sidebar Navigation) */
.nav__dd-aside {
  width: 200px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 4px;
}
.nav__dd-aside a {
  display: block;
  font-size: 14px;
  font-weight: 400;
  color: rgba(10, 10, 39, 0.6);
  padding: 10px 0;
  transition: color 0.2s;
  border-bottom: 1px solid rgba(0,0,0,0.04);
}
.nav__dd-aside a:last-child { border-bottom: none; }
.nav__dd-aside a:hover {
  color: #0a0a27;
}

/* Legacy support — keep old classes from breaking */
.nav__dd-grid { display: grid; gap: 16px 56px; }
.nav__dd-link { display: block; padding: 12px 0; font-size: 18px; font-weight: 400; color: rgba(10,10,39,0.55); transition: color 0.2s; }
.nav__dd-link:hover { color: #0a0a27; }
.nav__dd-desc { font-size: 13px; color: rgba(10,10,39,0.35); margin-top: 2px; }

/* Overlay behind dropdown */
.nav__overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 26, 0.35);
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.35s ease, visibility 0.35s;
  pointer-events: none;
}
.nav__overlay.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Responsive nav — handled in main responsive section at 768px */

/* ============================================================
   4. HERO — Groß, leicht, links oder zentriert
   ============================================================ */
.hero {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 80px 0 var(--section-gap);
  background: var(--bg-deep);
  position: relative;
  overflow: hidden;
}
/* Video-Hintergrund mit Blur-Overlay */
.hero-video-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.hero-video-bg video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: blur(14px);
  transform: scale(1.08); /* Blur-Ränder ausblenden */
}
.hero-video-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(10, 10, 39, 0.55);
  z-index: 1;
}
/* Content über Video */
.hero > .content {
  position: relative;
  z-index: 2;
}
.hero > .aurora-atmosphere {
  z-index: 1;
}
.hero .content {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: var(--gutter);
  align-items: end;
}
.hero h1 { color: var(--t1); margin-bottom: 24px; }
.hero__sub {
  font-size: 20px; line-height: 1.6; color: var(--t2);
  max-width: 540px; margin-bottom: 32px;
}
.hero__actions { display: flex; gap: 16px; }
.hero__media {
  border-radius: var(--r-container);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--bg-card);
}

/* Hero Center (Startseite) */
.hero--center {
  text-align: center;
  padding: 100px 0 80px;
}
.hero--center .content {
  display: block;
}
.hero--center h1 { max-width: 900px; margin: 0 auto 24px; }
.hero--center .hero__sub { max-width: 640px; margin: 0 auto 40px; }
.hero--center .hero__actions { justify-content: center; }

/* Hero Metrics */
.hero-metrics {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 32px; max-width: 720px; margin: 48px auto 0;
  padding-top: 40px; border-top: 1px solid var(--border);
}
.hero-metrics__item { text-align: center; }
.hero-metrics__num {
  font-family: var(--display-num); font-size: clamp(36px, 4vw, 52px); font-weight: 600;
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 8px;
  line-height: 1;
}
.hero-metrics__num .num-suffix {
  font-size: 0.5em; font-weight: 600; opacity: 0.75;
}
.hero-metrics__label { font-size: 14px; color: var(--t2); }

/* Hero Light (Produkt-Seiten) — mit Hintergrundbild */
.hero--light {
  background: var(--bg-deep);
  position: relative;
  overflow: hidden;
}
.hero--light .hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero--light .hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.35;
}
.hero--light .hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(10, 10, 39, 0.5) 0%,
    rgba(10, 10, 39, 0.35) 40%,
    rgba(10, 10, 39, 0.6) 100%
  );
}
.hero--light .content { position: relative; z-index: 2; }
.hero--light h1 { color: var(--white); -webkit-text-fill-color: var(--white); }
.hero--light .hero__sub { color: rgba(255,255,255,0.8); }
.hero--light .hero-metrics { border-color: rgba(255,255,255,0.1); }
.hero--light .hero-metrics__label { color: rgba(255,255,255,0.65); }
.hero--light .hero-metrics__num { color: var(--white); }
.hero--light .section-label { color: var(--accent) !important; }
.hero--light .btn--outline {
  color: var(--white); border-color: rgba(255,255,255,0.3);
}
.hero--light .btn--outline:hover {
  border-color: rgba(255,255,255,0.6); background: rgba(255,255,255,0.06);
}

/* ============================================================
   HERO IMMERSIVE — Fullscreen mit Scroll-Overlay
   1) Fullscreen-Bild mit Text links + UI-Screenshot rechts
   2) Beim Scrollen gleitet ein Frosted-Glass-Panel von unten
      nach oben über die gesamte Fläche
   ============================================================ */
.hero-immersive {
  position: relative;
  /* Gesamthöhe: 100vh Bild-Bereich + 100vh Overlay-Scroll-Raum */
}

/* Sticky Container — hält Bild + Content fixiert im Viewport */
.hero-immersive__sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  width: 100%;
  z-index: 1;
}

/* Hintergrundbild — füllt den gesamten Viewport */
.hero-immersive__bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
}
.hero-immersive__bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Gradient Overlay über dem Bild */
.hero-immersive__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(10, 10, 39, 0.3) 0%,
    rgba(10, 10, 39, 0.1) 30%,
    rgba(10, 10, 39, 0.4) 70%,
    rgba(10, 10, 39, 0.8) 100%
  );
  pointer-events: none;
}

/* Text + CTA links, UI-Screenshot rechts — über dem Bild */
.hero-immersive__content {
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex;
  align-items: center;
}
.hero-immersive__content .content {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--gutter);
  align-items: center;
}
.hero-immersive__text {
  max-width: 480px;
}
.hero-immersive__text .section-label {
  display: inline-block;
  border: none;
  padding: 0;
  margin-bottom: 20px;
  color: rgba(255,255,255,0.7);
  font-size: 14px;
}
.hero-immersive__text h1 {
  color: var(--white);
  margin-bottom: 20px;
}
.hero-immersive__text .hero__sub {
  color: rgba(255,255,255,0.75);
  font-size: 18px;
  line-height: 1.6;
  margin-bottom: 28px;
}

/* UI-Screenshot rechts — schwebt über dem Hintergrund */
.hero-immersive__ui {
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  box-shadow:
    0 24px 80px rgba(0,0,0,0.4),
    0 0 0 1px rgba(255,255,255,0.08);
  transform: translateY(-20px);
}
.hero-immersive__ui img {
  width: 100%;
  display: block;
}

/* Frosted Glass Overlay — gleitet von unten über alles drüber.
   Kein margin-top-Hack! Das Overlay ist im normalen Flow
   NACH dem sticky Container. Da der sticky Container im
   Viewport bleibt, scrollt das Overlay natürlich darüber. */
.hero-immersive__overlay {
  position: relative;
  z-index: 2;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  /* CD Blau-Verlauf (--blue-deep → --blue-bright) bei 65% Deckkraft + Blur */
  background: linear-gradient(135deg, rgba(17, 11, 185, 0.65), rgba(0, 88, 255, 0.65));
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
}
.hero-immersive__overlay::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,0.08) 20%,
    rgba(255,255,255,0.15) 50%,
    rgba(255,255,255,0.08) 80%,
    transparent 100%
  );
}

/* --- Metrics — zentriert, 3 Spalten --- */
.hero-immersive__metrics-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: var(--content);
  padding: 0 2rem;
}
.hero-immersive__metrics-headline {
  font-family: var(--heading);
  font-size: clamp(24px, 3vw, 38px);
  font-weight: 300;
  color: var(--white);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin-bottom: 64px;
  text-align: center;
  max-width: 680px;
}
.hero-immersive__metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 56px 64px;
  width: 100%;
  text-align: center;
}
.hero-immersive__metric {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.hero-immersive__metric-num {
  font-family: var(--display-num);
  font-size: clamp(52px, 7vw, 88px);
  font-weight: 600;
  line-height: 1;
  color: var(--white);
  -webkit-text-fill-color: var(--white);
  background: none;
  letter-spacing: normal;
  margin-bottom: 16px;
  display: flex;
  align-items: baseline;
  justify-content: center;
}
.hero-immersive__metric-num .num-suffix {
  font-size: 0.5em;
  font-weight: 600;
  opacity: 0.75;
  margin-left: 2px;
}
.hero-immersive__metric-label {
  font-family: var(--body);
  font-size: 15px;
  font-weight: 400;
  color: rgba(255,255,255,0.40);
  line-height: 1.5;
  text-align: center;
}

/* Produktwelt-Anpassung */
[data-world="produkt"] .hero-immersive__bg::after {
  background: linear-gradient(
    180deg,
    rgba(5, 28, 44, 0.25) 0%,
    rgba(5, 28, 44, 0.1) 30%,
    rgba(5, 28, 44, 0.35) 70%,
    rgba(5, 28, 44, 0.75) 100%
  );
}
[data-world="produkt"] .hero-immersive__overlay {
  background: rgba(248, 249, 252, 0.68);
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
}
[data-world="produkt"] .hero-immersive__overlay::before {
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(0,0,0,0.04) 20%,
    rgba(0,0,0,0.08) 50%,
    rgba(0,0,0,0.04) 80%,
    transparent 100%
  );
}
[data-world="produkt"] .hero-immersive__text .section-label {
  color: rgba(255,255,255,0.7) !important;
}
[data-world="produkt"] .hero-immersive__text h1 {
  color: var(--white) !important;
  -webkit-text-fill-color: var(--white) !important;
}
[data-world="produkt"] .hero-immersive__text .hero__sub {
  color: rgba(255,255,255,0.75) !important;
}
[data-world="produkt"] .hero-immersive__text .btn--outline {
  color: var(--white) !important;
  border-color: rgba(255,255,255,0.3) !important;
}
[data-world="produkt"] .hero-immersive__text .btn--outline:hover {
  border-color: rgba(255,255,255,0.6) !important;
  background: rgba(255,255,255,0.06) !important;
}
[data-world="produkt"] .hero-immersive__metrics-headline {
  color: var(--tl1);
}
[data-world="produkt"] .hero-immersive__metric-num {
  background: none;
}
[data-world="produkt"] .hero-immersive__metric-num .num-suffix {
  background: linear-gradient(135deg, #8FFBBD, #67DEE3);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
[data-world="produkt"] .hero-immersive__metric-label {
  color: var(--tl2);
}

/* ============================================================
   5. BUTTONS — Kein Radius, clean
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--body); font-size: 15px; font-weight: 500;
  padding: 14px 28px; border: none; cursor: pointer;
  border-radius: var(--r-button); transition: var(--t-fast);
  transform: scale(1);
}
.btn:hover {
  transform: scale(1.04);
}
.btn--fill {
  background: linear-gradient(30deg, #AC0A4D 18%, #FF2B84);
  color: var(--white); font-weight: 600;
  border: none;
}
.btn--fill:hover {
  background: linear-gradient(30deg, #C01060 18%, #FF4D9A);
  box-shadow: 0 4px 20px rgba(255, 43, 132, 0.3);
}
.btn--mint {
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  color: #051c2c; font-weight: 600;
}
.btn--mint:hover {
  background: linear-gradient(135deg, #A0FFCC, #7EEAF0);
  box-shadow: 0 4px 20px rgba(0, 88, 255, 0.3);
}
.btn--outline {
  background: transparent; color: var(--t1);
  border: 1px solid #AC0A4D;
}
.btn--outline:hover { border-color: #FF2B84; }
.btn--outline-light {
  background: transparent; color: var(--tl1);
  border: 1px solid #AC0A4D;
}
.btn--outline-light:hover { border-color: #FF2B84; }
.btn--ghost { background: none; color: var(--accent); padding: 0; border: none; }
.btn--ghost:hover { text-decoration: underline; }
.btn--white { background: var(--white); color: #0058FF; font-weight: 600; }
.btn--white:hover { background: var(--off-white); color: #0047cc; }
.btn__arrow { transition: transform .2s; }
.btn--ghost:hover .btn__arrow { transform: translateX(4px); }

/* ============================================================
   6. ASYMMETRIC GRID (7/5, 5/7, 8/4)
   ============================================================ */
.grid-75 { display: grid; grid-template-columns: 7fr 5fr; gap: var(--gutter); align-items: start; }
.grid-57 { display: grid; grid-template-columns: 5fr 7fr; gap: var(--gutter); align-items: start; }
.grid-84 { display: grid; grid-template-columns: 2fr 1fr; gap: var(--gutter); align-items: start; }
.grid-48 { display: grid; grid-template-columns: 1fr 2fr; gap: var(--gutter); align-items: start; }
.grid-50 { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: start; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }

/* ============================================================
   7. CARD — Flat, kein Radius, kein Border
   ============================================================ */
.card-flat {
  background: var(--bg-card); padding: 40px;
  border-radius: var(--r-card);
  transition: background .3s;
}
.card-flat:hover { background: var(--bg-card-hover); }
.card-flat__label {
  font-size: 14px; font-weight: 500; color: var(--accent-light);
  text-transform: uppercase; letter-spacing: 0.08em;
  margin-bottom: 16px;
}
.card-flat__title {
  font-family: var(--heading); font-size: 24px; font-weight: 400;
  color: var(--t1); line-height: 1.25; margin-bottom: 12px;
}
.card-flat__body { font-size: 15px; color: var(--t2); line-height: 1.6; }
.card-flat__link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: 500; color: var(--accent-light);
  margin-top: 20px; transition: gap .2s;
}
.card-flat__link:hover { gap: 10px; }

/* Light variant */
.card-flat--light { background: var(--white); }
.card-flat--light:hover { background: var(--off-white); }
.card-flat--light .card-flat__label { color: var(--accent); }
.card-flat--light .card-flat__title { color: var(--tl1); }
.card-flat--light .card-flat__body { color: var(--tl2); }
.card-flat--light .card-flat__link { color: var(--accent); }

/* ============================================================
   7b. CARD — Pricing (Flat-Variante für Preismodule)
   Weiße Cards auf dunklem Aurora-Background mit Spotlights
   ============================================================ */
.pricing-section {
  position: relative;
  padding: 100px 0;
  overflow: hidden;
}
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  position: relative;
  z-index: 1;
}
.card-pricing {
  background: #ffffff;
  border-radius: 20px;
  padding: 40px 32px;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.card-pricing:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.18);
}
.card-pricing__icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.card-pricing__icon svg {
  width: 24px;
  height: 24px;
}
.card-pricing__name {
  font-family: var(--heading);
  font-size: 1.25rem;
  font-weight: 500;
  color: #051c2c;
  margin-bottom: 8px;
}
.card-pricing__desc {
  font-size: 0.92rem;
  color: #4a5568;
  line-height: 1.6;
  margin-bottom: 24px;
  flex: 1;
}
.card-pricing__divider {
  height: 1px;
  background: rgba(0, 0, 0, 0.08);
  margin: 0 0 24px;
}
.card-pricing__price-row {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: 4px;
}
.card-pricing__price {
  font-family: var(--heading);
  font-size: 2rem;
  font-weight: 600;
  line-height: 1;
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.card-pricing__period {
  font-size: 0.88rem;
  color: #9098b0;
}
.card-pricing__roi {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  padding: 12px 16px;
  background: rgba(143, 251, 189, 0.10);
  border-radius: 12px;
  font-size: 0.85rem;
  color: #0B8A4B;
  line-height: 1.4;
}
.card-pricing__roi svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  stroke: #0B8A4B;
}
.card-pricing__integration {
  font-size: 0.82rem;
  color: #9098b0;
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
}
.card-pricing .btn {
  margin-top: 24px;
}

/* Pricing Responsive */
@media (max-width: 1024px) {
  .pricing-grid {
    grid-template-columns: 1fr;
    max-width: 480px;
    margin: 0 auto;
  }
}
@media (max-width: 768px) {
  .pricing-grid {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    max-width: none;
    padding-bottom: 12px;
  }
  .pricing-grid::-webkit-scrollbar { display: none; }
  .card-pricing {
    min-width: 78vw;
    max-width: 340px;
    scroll-snap-align: start;
    flex-shrink: 0;
  }
}

/* Card with image */
.card-img {
  border-radius: var(--r-card); overflow: hidden;
  transition: transform .3s; cursor: pointer;
}
.card-img:hover { transform: translateY(-4px); }
.card-img__visual {
  width: 100%; aspect-ratio: 16/10;
  background: var(--bg-card); position: relative; overflow: hidden;
}
.card-img__visual img { width: 100%; height: 100%; object-fit: cover; }
.card-img__body { padding: 24px 0; }
.card-img__cat {
  font-size: 13px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--accent-light); margin-bottom: 8px;
}
.card-img__title {
  font-family: var(--heading); font-size: 22px; font-weight: 400;
  color: var(--t1); line-height: 1.3;
}

/* Case Study Card — Full bleed image + overlay */
/* ---- Bento Mosaic Grid ---- */
.bento-mosaic__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  grid-template-rows: 480px 380px;
  grid-template-areas:
    "a a b b f f f"
    "c c d d f f f";
  gap: 16px;
}
.bento-mosaic__grid .bento-card:nth-child(1) { grid-area: a; }
.bento-mosaic__grid .bento-card:nth-child(2) { grid-area: b; }
.bento-mosaic__grid .bento-card:nth-child(3) { grid-area: c; }
.bento-mosaic__grid .bento-card:nth-child(4) { grid-area: d; }
.bento-mosaic__grid .bento-card:nth-child(5) { grid-area: f; }

.bento-card {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  border-radius: 16px;
  transition: box-shadow 0.4s ease;
}
.bento-card:hover {
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}
.bento-card__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  transition: transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
}
.bento-card__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.bento-card:hover .bento-card__bg {
  transform: scale(1.08);
}
.bento-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(10, 10, 39, 0.92) 0%,
    rgba(10, 10, 39, 0.5) 40%,
    rgba(10, 10, 39, 0.1) 70%,
    transparent 100%
  );
  z-index: 1;
  pointer-events: none;
}
.bento-card__content {
  position: relative;
  z-index: 2;
  padding: 32px;
}
.bento-card__eyebrow {
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent-light);
  margin-bottom: 12px;
}
.bento-card__title {
  font-family: var(--heading);
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 400;
  color: var(--white);
  line-height: 1.3;
}
.bento-card__arrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  font-size: 14px;
  font-weight: 500;
  color: var(--white);
  opacity: 0;
  transform: translateX(-8px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.bento-card__arrow svg {
  width: 16px;
  height: 16px;
  transition: transform 0.3s ease;
}
.bento-card:hover .bento-card__arrow {
  opacity: 1;
  transform: translateX(0);
}
.bento-card:hover .bento-card__arrow svg {
  transform: translateX(4px);
}

/* Featured card (large, right side) */
.bento-card--featured {
  background: linear-gradient(135deg, var(--primary) 0%, #1a0a5c 100%);
}
.bento-card--featured .bento-card__bg {
  opacity: 0.45;
  mix-blend-mode: luminosity;
}
.bento-card--featured .bento-card__content {
  padding: 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
}
.bento-card--featured .bento-card__eyebrow {
  font-size: 13px;
  margin-bottom: 20px;
}
.bento-card--featured .bento-card__title {
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 300;
  line-height: 1.2;
  max-width: 480px;
}
.bento-card--featured .bento-card__arrow {
  margin-top: 32px;
  font-size: 16px;
}
.bento-card--featured .btn {
  margin-top: 32px;
  width: fit-content;
}

/* Responsive Bento */
@media (max-width: 1024px) {
  .bento-mosaic__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
    grid-template-areas:
      "f f"
      "a b"
      "c d";
  }
  .bento-card { min-height: 320px; }
}
@media (max-width: 640px) {
  .bento-mosaic__grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      "f"
      "a"
      "b"
      "c"
      "d";
  }
  .bento-card { min-height: 280px; }
  .bento-card--featured { min-height: 400px; }
}

/* ============================================================
   8. SPLIT SECTION — Bild + Text, asymmetrisch
   ============================================================ */
.section-split { padding: var(--section-gap) 0; }
.section-split--dark { background: var(--bg-deep); }
.section-split--dark-alt { background: var(--bg-primary); }
.section-split--light { background: var(--white); }

/* Split-specific grid: wider gap, smaller image */
.section-split .grid-75 { grid-template-columns: 5fr 6fr; gap: 40px; }
.section-split .grid-57 { grid-template-columns: 6fr 5fr; gap: 40px; }

.section-split__media {
  border-radius: var(--r-container); overflow: hidden;
  aspect-ratio: 4/3; background: var(--bg-card);
}
.section-split__text { padding-top: 20px; }
.section-split__text .section-label { margin-bottom: 24px; }
.section-split__text h2 { margin-bottom: 20px; }
.section-split__text p {
  font-size: 17px; line-height: 1.7; margin-bottom: 24px;
}
.section-split--dark h2 { color: var(--t1); }
.section-split--dark p { color: var(--t2); }
.section-split--light h2 { color: var(--tl1); }
.section-split--light p { color: var(--tl2); }

/* Checklist */
.checklist { list-style: none; margin-bottom: 24px; }
.checklist li {
  display: flex; gap: 10px; font-size: 16px; margin-bottom: 8px;
  padding-left: 0;
}
.checklist li::before { content: '→'; color: var(--accent); flex-shrink: 0; }

/* ============================================================
   9. STEPS — Nummern-Grid
   ============================================================ */
.section-steps { padding: var(--section-gap) 0; background: var(--bg-primary); }
.step {
  padding-top: 32px;
  border-top: 1px solid var(--border);
}
.step__num {
  font-family: var(--heading); font-size: 56px; font-weight: 200;
  line-height: 1; margin-bottom: 16px;
  background: linear-gradient(135deg, #8FFBBD, #67DEE3);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.step__title {
  font-family: var(--heading); font-size: 20px; font-weight: 500;
  color: var(--t1); margin-bottom: 8px;
}
.step__body { font-size: 15px; color: var(--t2); line-height: 1.6; }

/* ============================================================
   9b. STEPS ACCORDION — Sticky-Visual + Scrollable Steps
   Generische Komponente für Feature-Cluster-Sektionen.
   Wird in Branchenseiten mehrfach pro Seite verwendet.
   ============================================================ */

/* --- Layout ------------------------------------------------- */
.section-steps-accordion {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  max-width: 1400px;
  margin: 0 auto;
}
.section-steps-accordion__header {
  grid-column: 1 / -1;
  text-align: center;
  padding: 0 40px 48px;
}
.section-steps-accordion__header .section-label {
  display: inline-block;
  margin-bottom: 16px;
}
.section-steps-accordion__header h2 {
  font-family: var(--heading);
  font-size: clamp(21px, 3.2vw, 37px);
  font-weight: 500;
  margin-bottom: 12px;
}
.section-steps-accordion__header p {
  font-size: 1.05rem;
  max-width: 640px;
  margin: 0 auto;
  line-height: 1.6;
}

/* --- Visual column (sticky) --------------------------------- */
.section-steps-accordion__visual {
  position: sticky;
  top: calc((100vh - 28.125vw - 80px) / 2);
  align-self: start;
  overflow: hidden;
  padding: 40px;
}
.section-steps-accordion__img-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
}
.acc-img {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.5s ease;
}
.acc-img.is-active { opacity: 1; }
.acc-img__inner {
  width: 100%;
  height: 100%;
  border-radius: 16px;
  overflow: hidden;
}

/* --- Progress dots ------------------------------------------ */
.acc-progress {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
}
.acc-progress__dot {
  width: 10px;
  height: 10px;
  border-radius: 10px;
  background: rgba(0, 88, 255, 0.12);
  transition: all 0.3s ease;
  cursor: pointer;
}
.acc-progress__dot.is-active {
  width: 28px;
  background: #0058FF;
}

/* --- Content column (steps) --------------------------------- */
.section-steps-accordion__content {
  padding: 80px 60px 80px 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border: none;
}

/* --- Individual step ---------------------------------------- */
.acc-step {
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  border-top: none;
  transition: all 0.4s ease;
  padding: 24px 0;
  margin-bottom: 25px;
  border-radius: 16px;
}
.acc-step:last-child {
  border-bottom: none;
  margin-bottom: 0;
}
.acc-step.is-active {
  background: linear-gradient(135deg, rgba(103, 222, 227, 0.15), rgba(143, 251, 189, 0.15));
  border-bottom-color: transparent;
  padding: 24px;
}

/* --- Step header -------------------------------------------- */
.acc-step__header {
  display: grid;
  grid-template-columns: 48px 1fr;
  grid-template-rows: auto auto;
  gap: 0 8px;
  padding: 0;
}
.acc-step__label {
  grid-column: 1 / -1;
  font-size: 0.89rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, #110BB9, #0058FF);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 10px;
}
.acc-step__num {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.93rem;
  font-weight: 500;
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  color: #ffffff;
  transition: all 0.3s;
  grid-column: 1;
  grid-row: 2;
  align-self: start;
  margin-top: 2px;
}
.acc-step__title {
  font-family: var(--heading);
  font-size: 1.34rem;
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.02em;
  color: #080B16;
  background: none;
  -webkit-background-clip: unset;
  -webkit-text-fill-color: unset;
  background-clip: unset;
  grid-column: 2;
  grid-row: 2;
  align-self: start;
  margin-top: 3px;
}

/* --- Step body ---------------------------------------------- */
.acc-step__body {
  max-height: none;
  overflow: visible;
  padding: 8px 0 0 0;
  color: var(--tl1, #151539);
}
.acc-step__text {
  font-size: 1.03rem;
  line-height: 1.7;
  color: var(--tl1, #151539);
  max-width: 480px;
}

/* --- Modifier: flat/simple (solid colors statt Gradient) ---- */
.section-steps-accordion--simple .acc-step.is-active {
  background: rgba(0, 88, 255, 0.04);
}
.section-steps-accordion--simple .acc-step__label {
  background: none;
  -webkit-background-clip: unset;
  -webkit-text-fill-color: unset;
  background-clip: unset;
  color: #0058FF;
}
.section-steps-accordion--simple .acc-step__title {
  background: none;
  -webkit-background-clip: unset;
  -webkit-text-fill-color: unset;
  background-clip: unset;
  color: #080B16;
}

/* --- RESPONSIVE: Tablet 1024px ------------------------------ */
@media (max-width: 1024px) {
  .section-steps-accordion {
    display: block !important;
    min-height: auto;
    overflow: hidden;
  }
  .section-steps-accordion__visual { display: none; }
  .section-steps-accordion__content {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-padding-left: 40px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 16px;
    padding: 0 40px 20px;
    min-height: auto;
  }
  .section-steps-accordion__content::-webkit-scrollbar { display: none; }
  .acc-step {
    min-width: 72%;
    width: 72%;
    scroll-snap-align: start;
    flex-shrink: 0;
    padding: 0;
    background: rgba(0, 88, 255, 0.03);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 16px;
    box-sizing: border-box;
    overflow: hidden;
    border-top: none;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  }
  .acc-step:first-child { border-top: none; }
  .acc-step .acc-step__body {
    max-height: none;
    opacity: 1;
    padding: 0 24px 24px;
  }
  .acc-step::before {
    content: attr(data-img-label);
    display: flex;
    align-items: center;
    justify-content: center;
    width: calc(100% - 32px);
    margin: 16px auto 0;
    aspect-ratio: 2 / 1;
    font-size: 0.8rem;
    font-weight: 500;
    color: white;
    border-radius: 12px;
    flex-shrink: 0;
  }
  .acc-step[data-index="0"]::before { background: linear-gradient(135deg, #0058FF, #67DEE3); }
  .acc-step[data-index="1"]::before { background: linear-gradient(135deg, #110BB9, #0058FF); }
  .acc-step[data-index="2"]::before { background: linear-gradient(135deg, #67DEE3, #8FFBBD); }
  .acc-step[data-index="3"]::before { background: linear-gradient(30deg, #AC0A4D 18%, #FF2B84); }
  .acc-step[data-index="4"]::before { background: linear-gradient(135deg, #0058FF, #110BB9); }
  .acc-step__header { gap: 12px; padding: 16px 24px 0; border: none; }
  .acc-step__num { width: 36px; height: 36px; font-size: 0.75rem; }
  .acc-step__title { font-size: 1.15rem; }
  .acc-step__text { font-size: 0.9rem; line-height: 1.6; }
  .acc-progress { display: none; }
}

/* --- RESPONSIVE: Mobile 768px ------------------------------- */
@media (max-width: 768px) {
  .section-steps-accordion__content {
    gap: 12px;
    padding: 0 20px 20px;
    scroll-padding-left: 20px;
  }
  .acc-step {
    min-width: 84%;
    width: 84%;
  }
  .acc-step::before {
    width: calc(100% - 24px);
    margin: 12px auto 0;
    font-size: 0.75rem;
  }
  .acc-step__header { padding: 14px 20px 0; }
  .acc-step__title { font-size: 1.05rem; }
  .acc-step .acc-step__body { padding: 0 20px 18px; }
  .acc-step__text { font-size: 0.84rem; }
  .section-steps-accordion__header { padding: 0 24px 32px !important; }
}

/* --- RESPONSIVE: Small mobile 480px ------------------------- */
@media (max-width: 480px) {
  .section-steps-accordion__header h2 { font-size: clamp(1.4rem, 5vw, 2rem); }
  .section-steps-accordion__header p { font-size: 0.95rem; }
}

/* --- Produkt-Welt Farben (default, da data-world="produkt") - */
[data-world="produkt"] .section-steps-accordion__header h2 { color: #151539; }
[data-world="produkt"] .section-steps-accordion__header p  { color: rgba(21, 21, 57, 0.7); }

/* --- Marke-Welt Farben -------------------------------------- */
[data-world="marke"] .section-steps-accordion__header h2 { color: var(--t1); }
[data-world="marke"] .section-steps-accordion__header p  { color: var(--t2); }
[data-world="marke"] .acc-step { border-bottom-color: var(--glass-border); }
[data-world="marke"] .acc-step__body { color: var(--t2); }
[data-world="marke"] .acc-step__text { color: var(--t2); }
[data-world="marke"] .acc-progress__dot { background: rgba(103, 222, 227, 0.2); }
[data-world="marke"] .acc-progress__dot.is-active { background: var(--accent); }

/* ============================================================
   10. SERVICE TAGS — Pills
   ============================================================ */
.tags { display: flex; flex-wrap: wrap; gap: 10px; }
.tags--center { justify-content: center; }
.tag {
  padding: 10px 20px; border: 1px solid var(--pink);
  border-radius: var(--r-tag); color: var(--t2); font-size: 14px;
  font-weight: 400; transition: var(--t-fast);
}
.tag:hover {
  border-color: rgba(255,255,255,0.35);
  color: var(--t1); background: rgba(255,255,255,0.04);
}

/* ============================================================
   11. NEWS CAROUSEL — Smooth Resize Carousel
   ============================================================ */
.section-news { padding: var(--section-gap) 0; background: var(--white); }
.news-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 32px;
}
.news-header__text h2 {
  font-family: var(--heading); font-size: 28px; font-weight: 600;
  color: var(--tl1); margin-bottom: 4px;
}
.news-header__text p { font-size: 18px; color: var(--tl3); }
.news-nav { display: flex; gap: 8px; }
.news-nav__btn {
  width: 44px; height: 44px; border-radius: 50%;
  border: 1px solid #d0d5dd; background: var(--white);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: #667085; transition: all .25s ease;
}
.news-nav__btn:hover { border-color: #98a2b3; color: #344054; background: #f9fafb; }
.news-nav__btn:active { transform: scale(0.95); }

/* Carousel Track */
.news-track {
  display: flex;
  gap: 12px;
  height: 480px;
  overflow: hidden;
  position: relative;
}

/* Individual Card */
.news-card {
  border-radius: 22px;
  overflow: hidden;
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
  transition: flex 0.65s cubic-bezier(0.4, 0, 0.2, 1),
              border-radius 0.65s cubic-bezier(0.4, 0, 0.2, 1);
}
.news-card:hover .news-card__bg { transform: scale(1.03); }

/* Featured (active) card gets ~60% width */
.news-card[data-active="true"] {
  flex: 3.2;
}
/* Non-active cards share the rest */
.news-card[data-active="false"] {
  flex: 1;
}
/* Peek card (partially visible) */
.news-card[data-peek="true"] {
  flex: 0.4;
}

.news-card__bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transition: transform 0.65s cubic-bezier(0.4, 0, 0.2, 1);
}
.news-card__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.1) 40%, transparent 60%);
  opacity: 0;
  transition: opacity 0.65s cubic-bezier(0.4, 0, 0.2, 1);
}
.news-card[data-active="true"] .news-card__overlay { opacity: 1; }

.news-card__content {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 32px; z-index: 2;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.5s ease 0.15s, transform 0.5s ease 0.15s;
}
.news-card[data-active="true"] .news-card__content {
  opacity: 1; transform: translateY(0);
}
.news-card__tag {
  font-size: 12px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.08em; color: rgba(255,255,255,0.7); margin-bottom: 10px;
}
.news-card__title {
  font-family: var(--heading); font-size: 28px; font-weight: 600;
  color: var(--white); line-height: 1.2;
}

/* Footer with description + CTA */
.news-footer {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-top: 28px; gap: 40px;
}
.news-footer__desc {
  font-size: 16px; color: var(--tl2); max-width: 680px; line-height: 1.65;
  min-height: 52px;
  transition: opacity 0.3s ease;
}
.news-footer__desc strong { color: var(--tl1); font-weight: 600; }
.news-footer__link {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 15px; font-weight: 500; color: var(--tl1);
  padding: 12px 24px; border: 1px solid #d0d5dd;
  border-radius: 100px; transition: all .25s ease;
  white-space: nowrap; flex-shrink: 0;
}
.news-footer__link:hover { border-color: #98a2b3; background: #f9fafb; }
.news-footer__link svg { transition: transform .2s; }
.news-footer__link:hover svg { transform: translateX(3px); }

/* ============================================================
   12. TESTIMONIAL WALL
   ============================================================ */
.section-testimonials { padding: var(--section-gap) 0; background: var(--bg-secondary); }
.testimonial-wall {
  columns: 3; column-gap: 20px;
}
.testi-card {
  break-inside: avoid; margin-bottom: 20px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px; padding: 24px;
  transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.testi-card:hover {
  transform: translateY(-4px);
  border-color: rgba(103,222,227,0.25);
  box-shadow: 0 12px 40px rgba(0,0,0,0.2), 0 0 0 1px rgba(103,222,227,0.1);
}
.testi-card__head {
  display: flex; align-items: center; gap: 12px; margin-bottom: 14px;
}
.testi-card__avatar {
  width: 44px; height: 44px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, rgba(103,222,227,0.2), rgba(0,88,255,0.2));
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 700; color: #67DEE3;
  font-family: var(--body);
}
.testi-card__avatar img {
  width: 100%; height: 100%; border-radius: 50%; object-fit: cover;
}
.testi-card__meta { flex: 1; }
.testi-card__name {
  font-size: 14px; font-weight: 600; color: var(--t1); line-height: 1.3;
}
.testi-card__role {
  font-size: 12px; color: var(--t3); line-height: 1.3;
}
.testi-card__stars {
  display: flex; gap: 2px; margin-bottom: 12px;
}
.testi-card__stars svg {
  width: 14px; height: 14px; fill: #67DEE3;
}
.testi-card__text {
  font-size: 14px; line-height: 1.65; color: var(--t2);
}
.testi-card__text strong {
  color: var(--t1); font-weight: 600;
}
.testi-card__highlight {
  color: #67DEE3; font-weight: 500;
}
.testi-card__tags {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px;
}
.testi-card__tag {
  font-size: 11px; padding: 4px 10px; border-radius: 20px;
  background: rgba(103,222,227,0.08); color: #67DEE3;
  font-family: var(--body); font-weight: 500;
}

/* ============================================================
   14. FAQ — Thin dividers, keine Cards
   ============================================================ */
.section-faq { padding: var(--section-gap) 0; }
.section-faq--dark { background: var(--bg-primary); }
.section-faq--light { background: var(--off-white); }
.faq { max-width: 780px; margin: 0 auto; }
.faq__item { border-bottom: 1px solid var(--border); }
.section-faq--light .faq__item { border-color: var(--border-light); }
.faq__q {
  display: flex; justify-content: space-between; align-items: center;
  padding: 24px 0; cursor: pointer; width: 100%; text-align: left;
  background: none; border: none;
  font-family: var(--heading); font-size: 18px; font-weight: 400;
  transition: color .2s;
}
.section-faq--dark .faq__q { color: var(--t1); }
.section-faq--light .faq__q { color: var(--tl1); }
.faq__q:hover { color: var(--accent); }
.faq__arrow {
  width: 20px; height: 20px; flex-shrink: 0; transition: transform .3s;
  color: var(--t3);
}
.faq__item--open .faq__arrow { transform: rotate(180deg); }
.faq__a { padding: 0 0 24px; font-size: 16px; line-height: 1.7; display: none; }
.faq__item--open .faq__a { display: block; }
.section-faq--dark .faq__a { color: var(--t2); }
.section-faq--light .faq__a { color: var(--tl2); }

/* ============================================================
   15. CTA SECTION
   ============================================================ */
.section-cta {
  padding: 80px 0; background: linear-gradient(135deg, #110BB9, #0058FF); text-align: center;
}
.section-cta h2 {
  font-family: var(--heading); font-size: clamp(21px, 3.2vw, 37px);
  font-weight: 500; color: var(--white); line-height: 1.15;
  max-width: 700px; margin: 0 auto 16px;
}
.section-cta p {
  font-size: 17px; color: rgba(255,255,255,0.8);
  max-width: 520px; margin: 0 auto 32px; line-height: 1.6;
}

/* ============================================================
   16. FOOTER — Dark
   ============================================================ */
.footer {
  background: var(--bg-secondary); padding: 64px 0 32px;
  border-top: 1px solid var(--border);
}
.footer__grid {
  display: grid; grid-template-columns: 2.5fr 1fr 1fr 1fr;
  gap: 40px; padding-bottom: 40px; border-bottom: 1px solid var(--border);
}
.footer__brand { font-family: var(--heading); font-size: 18px; font-weight: 500; color: var(--t1); margin-bottom: 12px; }
.footer__desc { font-size: 14px; color: var(--t2); line-height: 1.6; max-width: 280px; }
.footer__col-title {
  font-size: 13px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--t1); margin-bottom: 16px;
}
.footer__links { list-style: none; }
.footer__links li { margin-bottom: 8px; }
.footer__links a { font-size: 14px; color: var(--t2); transition: color .2s; }
.footer__links a:hover { color: var(--accent); }
.footer__bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 24px; font-size: 13px; color: var(--t3); flex-wrap: wrap; gap: 16px;
}
.footer__legal { display: flex; gap: 24px; }
.footer__legal a { color: var(--t3); transition: color .2s; }
.footer__legal a:hover { color: var(--accent); }

/* ============================================================
   17. ARTICLE LAYOUT + STICKY TOC
   ============================================================ */
.article-layout {
  padding: 80px 0 var(--section-gap);
  background: var(--bg-primary);
}
.article-grid {
  max-width: 1100px; margin: 0 auto; padding: 0 2rem;
  display: grid; grid-template-columns: 1fr 280px; gap: 56px;
}
.article__body { max-width: 700px; }

/* Article Header — Meta + Social Share Bar */
.article__header {
  margin-bottom: 40px; padding-bottom: 32px;
  border-bottom: 1px solid var(--border);
}
.article__header h1 {
  font-family: var(--heading); font-size: clamp(28px, 3.5vw, 40px);
  font-weight: 600; color: var(--t1); line-height: 1.2; margin-bottom: 16px;
}
.article__meta {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  font-size: 14px; color: var(--t3); margin-bottom: 20px;
}
.article__meta-sep { color: var(--t3); opacity: 0.4; }
.article__share-bar {
  display: flex; align-items: center; gap: 10px;
}
.article__share-label {
  font-size: 13px; font-weight: 600; color: var(--t2);
  text-transform: uppercase; letter-spacing: 0.06em; margin-right: 4px;
}

.article__body h2 {
  font-family: var(--heading); font-size: 28px; font-weight: 600;
  color: var(--t1); margin: 48px 0 16px; line-height: 1.25;
}
.article__body h2:first-child { margin-top: 0; }
.article__body h3 {
  font-family: var(--heading); font-size: 20px; font-weight: 600;
  color: var(--t1); margin: 36px 0 12px;
}
.article__body p { font-size: 17px; color: var(--t2); line-height: 1.8; margin-bottom: 20px; }
.article__body strong { color: var(--t1); }
.article__body ul, .article__body ol { margin: 0 0 20px 20px; }
.article__body li { color: var(--t2); line-height: 1.8; margin-bottom: 6px; font-size: 17px; }

/* Highlight Box — glassmorphism */
.callout {
  padding: 28px 32px; margin: 32px 0;
  background: rgba(0, 88, 255, 0.06);
  border-left: 3px solid #0058FF;
  border-radius: 0 8px 8px 0;
}
.callout__label {
  font-size: 12px; font-weight: 700; color: #0058FF;
  text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 8px;
}
.callout p { font-size: 16px; color: var(--t1); line-height: 1.7; margin: 0; }

/* Share Button (used in header bar + TOC sidebar) */
.share-btn {
  width: 36px; height: 36px;
  background: transparent;
  border: 1.5px solid var(--border);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--t2); cursor: pointer;
  transition: all 0.25s ease;
}
.share-btn svg { width: 16px; height: 16px; }
.share-btn:hover {
  background: #0058FF; border-color: #0058FF;
  color: var(--white); transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 88, 255, 0.3);
}

/* Sticky Sidebar TOC */
.toc { position: sticky; top: 100px; align-self: start; }
.toc__box {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 28px;
}
.toc__title {
  font-family: var(--heading); font-size: 14px; font-weight: 700;
  color: var(--t1); margin-bottom: 16px;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.toc__list { list-style: none; }
.toc__list li { margin-bottom: 2px; }
.toc__list a {
  font-size: 14px; color: var(--t2); display: block;
  padding: 8px 0 8px 14px; border-left: 2px solid transparent;
  border-radius: 0 6px 6px 0;
  transition: all .2s ease;
}
.toc__list a:hover {
  color: var(--t1); background: rgba(255,255,255,0.03);
  border-color: var(--t3);
}
.toc__list a.active {
  color: #0058FF; border-color: #0058FF;
  background: rgba(0, 88, 255, 0.06); font-weight: 500;
}
.toc__meta {
  margin-top: 20px; padding-top: 16px;
  border-top: 1px solid var(--border);
  font-size: 13px; color: var(--t3); line-height: 1.6;
}
.toc__meta strong { display: block; color: var(--t1); font-weight: 600; }
.toc__share {
  display: flex; gap: 8px; margin-top: 16px; padding-top: 16px;
  border-top: 1px solid var(--border);
}
.toc__reading {
  font-size: 13px; color: var(--t3); margin-top: 16px;
  padding-top: 16px; border-top: 1px solid var(--border);
}

/* Newsletter inline — CTA-Banner-Stil (Blau-Verlauf) */
.newsletter {
  background: linear-gradient(135deg, #110BB9, #0058FF);
  padding: 40px 36px; margin: 48px 0;
  border: none; border-radius: 16px;
  position: relative; overflow: hidden;
}
.newsletter::before {
  content: '';
  position: absolute; top: -40%; right: -20%;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 70%);
  pointer-events: none;
}
.newsletter h4 {
  font-family: var(--heading); font-size: 22px; font-weight: 600;
  color: var(--white); margin-bottom: 8px; position: relative;
}
.newsletter p,
.article__body .newsletter p,
[data-world="produkt"] .article__body .newsletter p {
  font-size: 15px; color: var(--white);
  margin-bottom: 20px; position: relative;
}
.newsletter__form { display: flex; gap: 10px; position: relative; }
.newsletter__form input {
  flex: 1; padding: 14px 18px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 999px;
  color: var(--white);
  font-family: var(--body); font-size: 15px; outline: none;
  backdrop-filter: blur(8px);
}
.newsletter__form input:focus { border-color: rgba(255,255,255,0.5); }
.newsletter__form input::placeholder { color: rgba(255,255,255,0.45); }
.newsletter__form button {
  padding: 14px 28px; background: var(--white); color: #0058FF;
  border: none; border-radius: 999px;
  font-family: var(--body); font-size: 15px; font-weight: 600;
  cursor: pointer; transition: all .25s ease;
}
.newsletter__form button:hover {
  background: var(--off-white); transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
}

/* ============================================================
   18. LEISTUNGSFELDER — "How We Help" Cards with Scroll-Reveal
   ============================================================ */
.section-fields {
  position: relative; z-index: 2;
  background: var(--bg-deep);
  padding: 120px 0 140px;
}
.section-fields .content {
  max-width: var(--content-wide); margin: 0 auto; padding: 0 40px;
}
.section-fields__label {
  font-size: 14px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--accent-light);
  margin-bottom: 20px;
}
.section-fields__headline {
  font-family: var(--heading); font-weight: 500;
  font-size: clamp(21px, 3.2vw, 37px); line-height: 1.15;
  color: var(--t1); max-width: 720px;
  margin-bottom: 72px;
}
.fields-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.field-card {
  display: flex; flex-direction: column;
  cursor: pointer;
  padding: 20px 20px 28px;
  border-radius: 22px;
  background: transparent;
  transition: background 0.35s ease, transform 0.35s ease, box-shadow 0.35s ease;
}
.field-card:hover {
  background: rgba(255, 255, 255, 0.95);
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
}
.field-card__img {
  width: 100%; aspect-ratio: 16/9;
  border-radius: 22px; overflow: hidden;
  margin-bottom: 28px;
}
.field-card__img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.4s;
}
.field-card:hover .field-card__img img {
  transform: scale(1.04);
}
.field-card__title {
  font-family: var(--heading); font-size: 22px; font-weight: 500;
  color: var(--t1); margin-bottom: 12px;
  display: flex; align-items: center; gap: 10px;
  transition: color 0.35s;
}
.field-card:hover .field-card__title {
  color: #151539;
}
.field-card__title .arrow {
  display: inline-flex; font-size: 18px; color: var(--accent-light);
  transition: transform 0.25s, color 0.35s;
}
.field-card:hover .field-card__title .arrow {
  transform: translateX(5px);
  color: var(--accent);
}
.field-card__desc {
  font-size: 15px; line-height: 1.65; color: var(--t2);
  transition: color 0.35s;
}
.field-card:hover .field-card__desc {
  color: #3a3f52;
}
.field-card__cat {
  font-size: 12px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--accent-light, #67DEE3);
  margin-bottom: 8px;
}
.field-card:hover .field-card__cat {
  color: var(--accent, #0058FF);
}

/* Produktwelt: hellerer Hover-Hintergrund */
[data-world="produkt"] .field-card:hover {
  background: var(--white);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}
[data-world="produkt"] .field-card:hover .field-card__title { color: var(--tl1); }
[data-world="produkt"] .field-card:hover .field-card__desc { color: var(--tl2); }

/* Scroll-Reveal Wrapper: fields section covers the next light section */
.fields-reveal-wrapper {
  position: relative;
}
.fields-reveal-wrapper .section-fields {
  position: relative; z-index: 2;
}
.fields-reveal-next {
  /* The next white section sits behind the dark fields section */
  position: sticky; top: 0; z-index: 1;
}

/* ============================================================
   19. CHAT WIDGET
   ============================================================ */
/* ---- Sticky Chat FAB (bottom-right) ---- */
.chat-fab {
  position: fixed; bottom: 24px; right: 24px; z-index: 9998;
}
.chat-fab__btn {
  width: 72px; height: 72px; border-radius: 50%;
  background: #0a0a1a;
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 24px rgba(0,0,0,0.35);
  transition: transform .3s cubic-bezier(0.16,1,0.3,1), box-shadow .3s ease;
  position: relative; overflow: visible;
}
.chat-fab__btn:hover { transform: scale(1.08); box-shadow: 0 8px 32px rgba(0,0,0,0.45), 0 0 24px rgba(103,222,227,0.2); }
.chat-fab__btn:active { transform: scale(0.95); }
.chat-fab__btn { animation: chatFloat 4s ease-in-out infinite; }
@keyframes chatFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
}
.chat-fab__btn:hover { animation: none; transform: scale(1.08); }

/* ---- Energy Ring ---- */
.chat-fab__ring {
  position: absolute; inset: -8px; pointer-events: none; z-index: 0;
  border-radius: 50%;
  animation: ringRotate 4s linear infinite;
}
.chat-fab__ring svg { width: 100%; height: 100%; }
@keyframes ringRotate {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
.chat-fab__ring-glow {
  position: absolute; inset: -12px; border-radius: 50%; pointer-events: none;
  background: conic-gradient(
    rgba(103, 222, 227, 0.25),
    rgba(0, 88, 255, 0.2),
    rgba(255, 43, 132, 0.2),
    rgba(143, 251, 189, 0.25),
    rgba(103, 222, 227, 0.25)
  );
  filter: blur(12px);
  animation: ringRotate 4s linear infinite;
  opacity: 0.7;
}
.chat-fab.is-open .chat-fab__ring,
.chat-fab.is-open .chat-fab__ring-glow { opacity: 0; transition: opacity .3s ease; }

/* ---- Audio Equalizer in FAB ---- */
.chat-fab__face {
  width: 48px; height: 48px; position: relative; z-index: 1;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px;
}
.chat-fab__eq {
  display: flex; align-items: flex-end; justify-content: center; gap: 2.5px;
  height: 18px; width: 36px;
}
.chat-fab__eq-bar {
  width: 3px; border-radius: 2px;
  animation: eqBounce 1.2s ease-in-out infinite alternate;
}
.chat-fab__eq-bar:nth-child(1) { height: 6px; background: #67DEE3; animation-delay: 0s; }
.chat-fab__eq-bar:nth-child(2) { height: 14px; background: #8FFBBD; animation-delay: 0.15s; }
.chat-fab__eq-bar:nth-child(3) { height: 10px; background: #0058FF; animation-delay: 0.3s; }
.chat-fab__eq-bar:nth-child(4) { height: 18px; background: #67DEE3; animation-delay: 0.1s; }
.chat-fab__eq-bar:nth-child(5) { height: 8px; background: #FF2B84; animation-delay: 0.25s; }
.chat-fab__eq-bar:nth-child(6) { height: 14px; background: #8FFBBD; animation-delay: 0.05s; }
.chat-fab__eq-bar:nth-child(7) { height: 6px; background: #0058FF; animation-delay: 0.2s; }
@keyframes eqBounce {
  0%   { transform: scaleY(0.3); }
  50%  { transform: scaleY(1); }
  100% { transform: scaleY(0.5); }
}
.chat-fab__label {
  font-family: var(--body); font-size: 7px; font-weight: 700;
  letter-spacing: 0.8px; text-transform: uppercase;
  background: linear-gradient(90deg, #8FFBBD, #67DEE3);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; line-height: 1;
}

/* Close icon morph */
.chat-fab__close {
  display: none; width: 24px; height: 24px; color: white; z-index: 1;
}
.chat-fab.is-open .chat-fab__face { display: none; }
.chat-fab.is-open .chat-fab__eq-bar { animation-play-state: paused; }
.chat-fab.is-open .chat-fab__close { display: block; }
.chat-fab.is-open .chat-fab__btn { animation: none; background: #0058FF; }

/* ---- Chat Overlay (centered, backdrop blur) ---- */
.chat-overlay {
  position: fixed; inset: 0; z-index: 9998;
  display: flex; align-items: center; justify-content: center;
  background: rgba(10, 10, 39, 0);
  backdrop-filter: blur(0px); -webkit-backdrop-filter: blur(0px);
  pointer-events: none;
  opacity: 0;
  transition: background .4s cubic-bezier(0.16,1,0.3,1),
              backdrop-filter .4s cubic-bezier(0.16,1,0.3,1),
              -webkit-backdrop-filter .4s cubic-bezier(0.16,1,0.3,1),
              opacity .4s cubic-bezier(0.16,1,0.3,1);
}
.chat-overlay.is-visible {
  background: rgba(10, 10, 39, 0.35);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  pointer-events: auto;
  opacity: 1;
}

.chat-modal {
  width: 92%; max-width: 520px; height: 70vh; max-height: 640px;
  background: #ffffff; border-radius: 24px;
  display: flex; flex-direction: column;
  box-shadow: 0 24px 80px rgba(0,0,0,0.18), 0 8px 24px rgba(0,0,0,0.1);
  overflow: hidden;
  transform: translateY(24px) scale(0.96);
  transition: transform .4s cubic-bezier(0.16,1,0.3,1);
}
.chat-overlay.is-visible .chat-modal {
  transform: translateY(0) scale(1);
}

/* Chat header — slim inline bar */
.chat-header {
  padding: 16px 20px; display: flex; align-items: center; gap: 12px;
  border-bottom: 1px solid #f0f0f5;
  background: #ffffff;
}
.chat-header__avatar {
  width: 38px; height: 38px; border-radius: 12px;
  background: linear-gradient(135deg, #151539, #1e1e4a);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.chat-header__avatar svg { width: 22px; height: 22px; }
.chat-header__info { flex: 1; }
.chat-header__name {
  font-family: var(--heading); font-size: 15px; font-weight: 600; color: #151539;
}
.chat-header__status {
  font-size: 11px; color: #4ade80; display: flex; align-items: center; gap: 5px; margin-top: 1px;
}
.chat-header__status::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: #4ade80; display: inline-block;
}
.chat-header__subtitle { display: none; }
.chat-header__close {
  width: 32px; height: 32px; border-radius: 10px;
  border: none; background: #f4f5fa; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: #888; transition: all .2s ease; flex-shrink: 0;
}
.chat-header__close:hover { background: #e8e9f0; color: #151539; }
.chat-header__close svg { width: 16px; height: 16px; }

/* Quick-reply pill buttons */
.chat-quick-replies {
  display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end;
  padding: 0; align-self: flex-end;
}
.chat-quick-reply {
  padding: 8px 16px; border-radius: 20px;
  border: 1.5px solid #0058FF; background: transparent;
  color: #0058FF; font-family: var(--body); font-size: 12px; font-weight: 500;
  cursor: pointer; transition: all .2s ease; white-space: nowrap;
}
.chat-quick-reply:hover {
  background: #0058FF; color: #ffffff;
}

/* Date stamp */
.chat-date {
  text-align: center; font-family: var(--body); font-size: 11px;
  color: #a0a0b8; padding: 6px 0; letter-spacing: 0.3px;
}

/* Chat messages area */
.chat-messages {
  flex: 1; overflow-y: auto; padding: 20px 20px;
  display: flex; flex-direction: column; gap: 14px;
  background: #fafaff;
}
.chat-messages::-webkit-scrollbar { width: 4px; }
.chat-messages::-webkit-scrollbar-track { background: transparent; }
.chat-messages::-webkit-scrollbar-thumb { background: #d0d0e0; border-radius: 2px; }

/* Message bubbles */
.chat-msg { display: flex; gap: 10px; align-items: flex-start; max-width: 88%; }
.chat-msg--bot { align-self: flex-start; }
.chat-msg--user { align-self: flex-end; flex-direction: row-reverse; }

.chat-msg__avatar {
  width: 30px; height: 30px; border-radius: 10px;
  background: linear-gradient(135deg, #151539, #1e1e4a);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.chat-msg__avatar svg { width: 18px; height: 18px; }
.chat-msg--user .chat-msg__avatar {
  background: #0058FF;
}

.chat-msg__bubble {
  padding: 14px 18px; border-radius: 16px;
  font-family: var(--body); font-size: 14.5px; line-height: 1.6;
}
.chat-msg--bot .chat-msg__bubble {
  background: #ffffff; color: #1a1a2e;
  border: 1px solid #ebebf0;
  border-radius: 4px 16px 16px 16px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.chat-msg--user .chat-msg__bubble {
  background: #0058FF;
  color: #ffffff;
  border-radius: 16px 4px 16px 16px;
}
.chat-msg__bubble p { margin: 0 0 8px; }
.chat-msg__bubble p:last-child { margin-bottom: 0; }

/* Links in bot messages */
.chat-msg__link {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; margin-top: 10px;
  background: #f8f9ff; border: 1px solid #ededf5;
  border-radius: 12px; text-decoration: none;
  transition: all .2s ease; cursor: pointer;
}
.chat-msg__link:hover {
  background: #f0f2ff; border-color: #d8dbf0;
  transform: translateX(3px);
}
.chat-msg__link-icon {
  width: 34px; height: 34px; border-radius: 10px;
  background: rgba(0, 88, 255, 0.07);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.chat-msg__link-icon svg { width: 17px; height: 17px; color: #0058FF; }
.chat-msg__link-text { flex: 1; }
.chat-msg__link-title {
  font-size: 13px; font-weight: 600; color: #151539; display: block;
}
.chat-msg__link-desc {
  font-size: 12px; color: #666; display: block; margin-top: 1px;
}
.chat-msg__link-arrow {
  color: #0058FF; font-size: 14px; flex-shrink: 0; transition: transform .2s; opacity: 0.5;
}
.chat-msg__link:hover .chat-msg__link-arrow { transform: translateX(3px); }

/* Typing indicator */
.chat-typing { display: flex; gap: 4px; padding: 4px 0; }
.chat-typing span {
  width: 7px; height: 7px; border-radius: 50%; background: #b0b0c8;
  animation: chatTyping 1.2s infinite ease-in-out;
}
.chat-typing span:nth-child(2) { animation-delay: 0.15s; }
.chat-typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes chatTyping {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30% { transform: translateY(-5px); opacity: 1; }
}

/* Chat input area */
.chat-input {
  padding: 16px 24px; border-top: 1px solid #f0f0f5;
  display: flex; align-items: center; gap: 10px;
  background: #ffffff;
}
.chat-input__attach {
  width: 38px; height: 38px; border-radius: 50%;
  border: none; background: transparent; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: #a0a0b8; transition: all .2s ease; flex-shrink: 0;
}
.chat-input__attach:hover { color: #0058FF; background: rgba(0, 88, 255, 0.06); }
.chat-input__attach svg { width: 20px; height: 20px; }
.chat-input__field {
  flex: 1; padding: 11px 16px;
  background: transparent; border: 1.5px solid #e8e8f0;
  border-radius: 24px; font-family: var(--body);
  font-size: 14px; color: #151539; outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.chat-input__field:focus { border-color: #0058FF; background: #ffffff; box-shadow: 0 0 0 3px rgba(0, 88, 255, 0.08); }
.chat-input__field::placeholder { color: #b0b0c4; }
.chat-input__send {
  width: 38px; height: 38px; border-radius: 50%;
  background: transparent; color: #0058FF;
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s ease; flex-shrink: 0;
}
.chat-input__send:hover {
  background: rgba(0, 88, 255, 0.06);
}
.chat-input__send:active { transform: scale(0.9); }
.chat-input__send svg { width: 20px; height: 20px; }

/* ============================================================
   20. RELATED ARTICLES
   ============================================================ */
.section-related {
  padding: var(--section-gap) 0; background: var(--bg-secondary);
  border-top: 1px solid var(--border);
}

/* ============================================================
   21. PROBLEM / SOLUTION + BEFORE/AFTER
   ============================================================ */
.card-ps {
  padding: 40px; transition: transform .3s;
}
.card-ps:hover { transform: translateY(-4px); }
.card-ps--problem { background: rgba(239,68,68,0.06); border-left: 3px solid #f87171; }
.card-ps--solution { background: rgba(34,197,94,0.06); border-left: 3px solid #4ade80; }
.card-ps h3 { font-family: var(--heading); font-size: 22px; font-weight: 500; margin-bottom: 12px; }
.card-ps--problem h3 { color: #f87171; }
.card-ps--solution h3 { color: #4ade80; }
.card-ps p { font-size: 15px; color: var(--t2); line-height: 1.7; }

.ba-list { list-style: none; }
.ba-list li {
  font-size: 15px; color: var(--t2); padding: 8px 0 8px 24px;
  position: relative; border-bottom: 1px solid var(--border);
}
.ba-list--bad li::before { content: '✕'; position: absolute; left: 0; color: #f87171; font-weight: 600; }
.ba-list--good li::before { content: '✓'; position: absolute; left: 0; color: #4ade80; font-weight: 600; }

/* ============================================================
   22b. FEATURE STEPS — Produktwelt Step-by-Step Showcase
   Inspiriert von modernen SaaS-Landingpages
   ============================================================ */
.feature-steps {
  padding: var(--section-gap) 0;
  background: var(--white);
  position: relative;
}
.feature-steps__header {
  text-align: center;
  margin-bottom: 80px;
}
.feature-steps__header h2 {
  font-family: var(--heading);
  font-size: clamp(21px, 3.2vw, 37px);
  font-weight: 500;
  color: var(--tl1);
  line-height: 1.15;
}

/* Individual step */
.fstep {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 64px;
  align-items: start;
  padding: 56px 64px;
  background: #f4f5f8;
  border-radius: 28px;
  margin-bottom: 32px;
  border: none;
}
.fstep:last-child { margin-bottom: 0; }
.fstep--reverse { direction: ltr; }
.fstep--reverse .fstep__text { order: 1; }
.fstep--reverse .fstep__visual { order: 2; }

/* Step badges */
.fstep__badges {
  display: flex;
  gap: 10px;
  margin-bottom: 24px;
}
.fstep__badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: 100px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.fstep__badge--step {
  background: var(--tl1);
  color: var(--white);
}
.fstep__badge--metric {
  background: var(--white);
  color: var(--tl1);
  border: 1px solid rgba(0,0,0,0.08);
}

/* Step text */
.fstep__title {
  font-family: var(--heading);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 400;
  color: var(--tl1);
  line-height: 1.25;
  margin-bottom: 36px;
}

/* Feature items within step */
.fstep__features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.fstep__feature {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.fstep__feature-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(0, 88, 255, 0.06);
  color: #0058FF;
  margin-bottom: 8px;
}
.fstep__feature-icon svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  stroke-width: 1.8;
  fill: none;
}
.fstep__feature-name {
  font-family: var(--heading);
  font-size: 16px;
  font-weight: 500;
  color: var(--tl1);
}
.fstep__feature-name a {
  color: var(--tl1);
  text-decoration: underline;
  text-decoration-color: rgba(0,0,0,0.15);
  text-underline-offset: 3px;
  transition: text-decoration-color 0.2s;
}
.fstep__feature-name a:hover { text-decoration-color: var(--accent); }
.fstep__feature-desc {
  font-size: 14px;
  color: var(--tl2);
  line-height: 1.6;
}

/* Visual cards (right side) */
.fstep__visual {
  position: relative;
}
.fstep__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.fstep__card {
  background: var(--white);
  border-radius: 16px;
  padding: 24px;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.fstep__card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}
.fstep__card--wide {
  grid-column: 1 / -1;
}
.fstep__card--tall {
  grid-row: span 2;
}
.fstep__card-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 10px;
  border-radius: 6px;
  margin-bottom: 16px;
}
.fstep__card-tag--blue {
  background: rgba(103, 222, 227, 0.08);
  color: #67DEE3;
}
.fstep__card-tag--green {
  background: rgba(0, 88, 255, 0.08);
  color: #0058FF;
}
.fstep__card-tag--pink {
  background: rgba(172, 10, 77, 0.08);
  color: #AC0A4D;
}

/* Mock table inside card */
.mock-table {
  width: 100%;
  font-size: 13px;
}
.mock-table__head {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(0,0,0,0.06);
  color: var(--tl3);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.mock-table__row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 8px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(0,0,0,0.03);
  color: var(--tl2);
}
.mock-table__row span:first-child {
  color: var(--tl1);
  font-weight: 450;
}

/* Mock list inside card */
.mock-list {
  list-style: none;
}
.mock-list li {
  display: flex;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid rgba(0,0,0,0.04);
  font-size: 14px;
  color: var(--tl2);
}
.mock-list li span:first-child {
  display: flex;
  align-items: center;
  gap: 8px;
}
.mock-list__dot {
  width: 8px; height: 8px;
  border-radius: 2px;
  display: inline-block;
}

/* CTA button inside card */
.fstep__card-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background: linear-gradient(135deg, #110BB9, #0058FF);
  color: var(--white);
  font-size: 14px;
  font-weight: 500;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: opacity 0.2s;
}
.fstep__card-btn:hover { opacity: 0.88; }

/* Responsive Feature Steps */
@media (max-width: 1024px) {
  .fstep { grid-template-columns: 1fr; gap: 40px; padding: 44px 40px; }
  .fstep--reverse .fstep__text { order: 0; }
  .fstep--reverse .fstep__visual { order: 0; }
}
@media (max-width: 640px) {
  .fstep__features { grid-template-columns: 1fr; }
  .fstep__cards { grid-template-columns: 1fr; }
  .fstep__card--tall { grid-row: auto; }
  .feature-steps { padding: 60px 0; }
  .fstep { padding: 32px 24px; border-radius: 20px; margin-bottom: 24px; }
  .feature-steps__header { margin-bottom: 40px; }
}

/* ============================================================
   22. PRODUCT SHOWCASE — Sticky List
   ============================================================ */
.showcase { padding: var(--section-gap) 0; background: var(--bg-primary); }
.showcase-grid {
  display: grid; grid-template-columns: 340px 1fr; gap: 32px; align-items: start;
}
.showcase-sidebar { position: sticky; top: 110px; }
.showcase-item {
  display: flex; gap: 12px; padding: 14px 16px;
  border-left: 3px solid transparent;
  background: var(--bg-secondary); cursor: pointer;
  transition: var(--t-fast);
}
.showcase-item + .showcase-item { border-top: 1px solid var(--border); }
.showcase-item.active { border-left-color: var(--accent); background: rgba(103,222,227,0.06); }
.showcase-item:hover:not(.active) { background: rgba(255,255,255,0.02); }
.showcase-item__icon {
  width: 40px; height: 40px; border-radius: 8px;
  background: var(--accent-glow); display: flex;
  align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0;
}
.showcase-item__text strong { font-size: 14px; color: var(--t1); font-weight: 500; display: block; margin-bottom: 2px; }
.showcase-item__text span { font-size: 12px; color: var(--t2); }
.showcase-item.active .showcase-item__text strong { color: var(--accent-light); }

.showcase-preview {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: var(--r-container); min-height: 460px;
  display: flex; align-items: center; justify-content: center;
  color: var(--t3); font-size: 14px;
}

/* ============================================================
   RESPONSIVE — Modern Mobile-First Approach
   Swipeable card carousels, hamburger nav, fluid scaling
   ============================================================ */

/* --- Mobile Hamburger Button --- */
.nav__burger {
  display: none;
  width: 44px; height: 44px;
  background: none; border: none; cursor: pointer;
  position: relative; z-index: 1010;
  flex-direction: column; align-items: center; justify-content: center; gap: 5px;
}
.nav__burger span {
  display: block; width: 22px; height: 2px;
  background: #ffffff; border-radius: 2px;
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.25s ease;
}
.nav__burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2) { opacity: 0; }
.nav__burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* "Menü" label next to burger — hidden on desktop */
.nav__burger-label {
  display: none;
  font-family: var(--heading); font-size: 14px; font-weight: 600;
  color: var(--white); letter-spacing: 0.03em;
  cursor: pointer;
}
/* Desktop: burger-group is transparent wrapper */
.nav__burger-group {
  display: contents;
}

/* Mobile compact CTA — hidden on desktop */
.nav__cta--mobile {
  display: none;
  align-items: center; justify-content: center;
  padding: 10px 20px;
  background: linear-gradient(30deg, #AC0A4D 18%, #FF2B84);
  color: var(--white);
  font-family: var(--heading); font-size: 13px; font-weight: 600;
  border: none; border-radius: 999px; cursor: pointer;
  white-space: nowrap;
  transition: transform 0.2s ease;
}
.nav__cta--mobile:hover { transform: scale(1.03); }

/* --- Mobile Slide-in Panel --- */
.nav__mobile-panel {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1005;
  background: #ffffff;
  padding: 88px 24px 40px;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.nav__mobile-panel.is-open { transform: translateX(0); }
.nav__mobile-panel a {
  display: block;
  font-size: 18px;
  font-weight: 400;
  color: rgba(10, 10, 39, 0.7);
  padding: 14px 0;
  border-bottom: 1px solid rgba(0,0,0,0.06);
  transition: color 0.2s;
}
.nav__mobile-panel a:hover { color: #0a0a27; }
.nav__mobile-panel .nav__dd-group-title {
  margin-top: 24px;
  margin-bottom: 8px;
  font-size: 11px;
}
.nav__mobile-panel .nav__dd-link {
  font-size: 16px;
  padding: 10px 0 10px 12px;
  border-bottom: none;
}
.nav__mobile-panel .nav__cta {
  width: 100%;
  margin: 32px 0 0;
  text-align: center;
  font-size: 16px;
  padding: 16px 28px;
}

/* ============= TABLET: 1024px ============= */
@media (max-width: 1024px) {
  :root {
    --section-gap: 80px;
    --gutter: 24px;
  }

  /* Library Chrome */
  .lib-nav { display: none; }
  .lib-main { margin-left: 0; }

  /* Grid collapses */
  .grid-75, .grid-57, .grid-84, .grid-48 { grid-template-columns: 1fr; }
  .section-split .grid-75,
  .section-split .grid-57 { grid-template-columns: 1fr; gap: 32px; }
  .grid-50 { grid-template-columns: 1fr 1fr; gap: 24px; }
  .grid-3 { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .grid-4 { grid-template-columns: repeat(2, 1fr); gap: 24px; }

  /* Hero */
  .hero .content { grid-template-columns: 1fr; }
  .hero__media { margin-top: 32px; }
  .hero--center { padding: 80px 0 60px; }

  /* Hero Immersive */
  .hero-immersive__content .content {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .hero-immersive__text { max-width: 100%; margin: 0 auto; }
  .hero-immersive__ui { display: none; }
  .hero-immersive__metrics { gap: 40px 32px; }

  /* Fields */
  .fields-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }

  /* Testimonial Wall — 2 columns on tablet */
  .testimonial-wall { columns: 2; }

  /* News Carousel */
  .news-track { height: 400px; }

  /* Article */
  .article-grid { grid-template-columns: 1fr; }
  .toc { position: static; margin-bottom: 40px; }

  /* Showcase */
  .showcase-grid { grid-template-columns: 1fr; }
  .showcase-sidebar { position: static; display: flex; gap: 8px; overflow-x: auto; scrollbar-width: none; padding-bottom: 8px; }
  .showcase-sidebar::-webkit-scrollbar { display: none; }
  .showcase-item { flex-shrink: 0; min-width: 200px; border-left: none; border-bottom: 3px solid transparent; }
  .showcase-item.active { border-left-color: transparent; border-bottom-color: var(--accent); }

  /* Footer */
  .footer__grid { grid-template-columns: 1fr 1fr; }

  /* Orbit */
  .orbit-layout { grid-template-columns: 1fr; }
  .orbit-field { height: 400px; }

  /* Comp preview padding */
  .comp__head { padding: 32px 24px 12px; }
}

/* ============= MOBILE: 768px ============= */
@media (max-width: 768px) {
  /* Navigation: hide desktop, show hamburger + mobile elements */
  .nav__menu { display: none; }
  .nav__cta:not(.nav__mobile-panel .nav__cta):not(.nav__cta--mobile) { display: none; }
  .nav__burger { display: flex; }
  .nav__mobile-panel { display: block; }
  .nav { height: 64px; padding: 0 20px; }
  .nav__dropdown { display: none !important; }

  /* Mobile: burger group becomes flex row */
  .nav__burger-group {
    display: flex; align-items: center; gap: 8px;
  }
  .nav__burger-label { display: block; }

  /* Mobile: compact contact button */
  .nav__cta--mobile { display: inline-flex !important; }

  /* Hero */
  .hero { min-height: auto; padding: 100px 0 60px; }
  .hero__sub { font-size: 17px; }
  .hero__actions { flex-direction: column; gap: 12px; }
  .hero__actions .btn { width: 100%; justify-content: center; }
  .hero--center { min-height: auto; padding: 100px 0 60px; }
  .hero-metrics { grid-template-columns: repeat(3, 1fr); gap: 16px; }
  .hero-metrics__label { font-size: 12px; }

  /* Hero Immersive */
  .hero-immersive__metrics { grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .hero-immersive__metrics-headline { margin-bottom: 40px; }

  /* Grid: 2→1 for some */
  .grid-50 { grid-template-columns: 1fr; }

  /* Card grids → swipeable on mobile */
  #c-flat .grid-3,
  #c-img .grid-3 {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 0 24px 12px;
    scrollbar-width: none;
  }
  #c-flat .grid-3::-webkit-scrollbar,
  #c-img .grid-3::-webkit-scrollbar { display: none; }
  #c-flat .grid-3 > *,
  #c-img .grid-3 > * {
    scroll-snap-align: start;
    flex-shrink: 0;
    width: 78vw;
    max-width: 340px;
  }

  /* Fields → swipeable */
  .fields-grid {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 12px;
    scrollbar-width: none;
  }
  .fields-grid::-webkit-scrollbar { display: none; }
  .field-card {
    scroll-snap-align: start;
    flex-shrink: 0;
    width: 78vw;
    max-width: 340px;
  }
  .section-fields .content { padding: 0 24px; }

  /* Testimonial Wall — single column */
  .testimonial-wall { columns: 1; }

  /* News */
  .news-track { height: 360px; }
  .news-header { flex-direction: column; gap: 16px; }
  .news-footer { flex-direction: column; gap: 20px; }
  .news-footer__link { align-self: flex-start; }

  /* Logo bar */
  .logo-bar__row {
    gap: 32px;
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    padding: 0 24px 8px;
    scrollbar-width: none;
  }
  .logo-bar__row::-webkit-scrollbar { display: none; }
  .logo-bar__item { flex-shrink: 0; scroll-snap-align: start; }

  /* Footer */
  .footer__grid { grid-template-columns: 1fr; gap: 32px; }
  .footer__bottom { flex-direction: column; align-items: flex-start; }

  /* Orbit */
  .orbit-field { height: 340px; }

  /* Steps → swipeable */
  .section-steps .grid-4 {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 12px;
    scrollbar-width: none;
  }
  .section-steps .grid-4::-webkit-scrollbar { display: none; }
  .section-steps .grid-4 .step {
    scroll-snap-align: start;
    flex-shrink: 0;
    width: 72vw;
    max-width: 300px;
  }

  /* Showcase: sidebar becomes horizontal scroll pills */
  .showcase-item { min-width: 160px; padding: 10px 14px; }

  /* Comp labels */
  .comp__label { display: none; }

  /* Comp preview: tighter padding for swipe */
  .comp__preview { overflow: visible; }
  #c-flat .comp__preview,
  #c-img .comp__preview,
  #c-steps .comp__preview {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Buttons stack */
  .hero__actions { align-items: stretch; }
}

/* ============= SMALL MOBILE: 480px ============= */
@media (max-width: 480px) {
  :root {
    --section-gap: 60px;
  }

  .content, .content-wide { padding: 0 16px; }

  /* Hero */
  .hero { padding: 88px 0 48px; }
  .h-display { font-size: clamp(28px, 8vw, 42px); }
  .h-section { font-size: clamp(18px, 4.5vw, 29px); }
  .hero__sub { font-size: 16px; }
  .hero--center .hero__sub { margin-bottom: 28px; }
  .hero-metrics { grid-template-columns: 1fr 1fr 1fr; gap: 12px; }

  /* Hero Immersive — stack metrics */
  .hero-immersive__metrics { grid-template-columns: 1fr; gap: 32px; }
  .hero-immersive__metric-num { font-size: clamp(40px, 12vw, 64px); }

  /* Cards — full-width swipe */
  .field-card { width: 85vw; }
  .section-steps .grid-4 .step { width: 80vw; }
  .testi-card { padding: 20px; }

  /* Grid final collapse */
  .grid-3, .grid-4 { grid-template-columns: 1fr; }

  /* Bento — tighter */
  .bento-card { min-height: 240px; }
  .bento-card__content { padding: 20px; }
  .bento-card--featured .bento-card__content { padding: 28px; }

  /* Tags wrap */
  .tags { gap: 8px; }
  .tag { padding: 8px 16px; font-size: 13px; }

  /* FAQ */
  .faq__q { font-size: 16px; padding: 20px 0; }

  /* CTA */
  .section-cta { padding: 60px 0; }
  .section-cta p { font-size: 15px; }

  /* Footer */
  .footer { padding: 48px 0 24px; }
  .footer__legal { flex-wrap: wrap; gap: 16px; }

  /* Article */
  .article__body p { font-size: 16px; }
  .article__body h2 { font-size: 24px; }
  .article__share-bar { flex-wrap: wrap; }
  .article__share-label { width: 100%; margin-bottom: -4px; }

  /* Chat Widget */
  /* Chat widget — mobile */
  .chat-fab { bottom: 16px; right: 16px; }
  .chat-fab__btn { width: 64px; height: 64px; }
  .chat-fab__face { width: 40px; height: 40px; gap: 2px; }
  .chat-fab__eq { height: 14px; width: 30px; gap: 2px; }
  .chat-fab__eq-bar { width: 2.5px; }
  .chat-fab__label { font-size: 6px; }
  .chat-modal { width: 95%; max-width: 480px; height: 80vh; max-height: none; border-radius: 16px; }

  /* Split section */
  .section-split { padding: 60px 0; }
  .section-split__text p { font-size: 16px; }

  /* Newsletter */
  .newsletter { padding: 24px; }
  .newsletter__form { flex-direction: column; }

  /* Orbit — compact */
  .orbit-field { height: 280px; }
  .orbit-center { width: 80px; height: 80px; font-size: 11px; }
  .orbit-glow { width: 320px; height: 320px; }
  .orbit-bubble { width: 44px; height: 44px; }
  .orbit-bubble img { width: 22px; height: 22px; }
  .orbit-bubble--lg { width: 54px; height: 54px; }
  .orbit-bubble--sm { width: 36px; height: 36px; }

  /* News */
  .news-track { height: 300px; }
  .news-card__title { font-size: 22px; }
  .news-card__content { padding: 20px; }

  /* Problem/Solution */
  .card-ps { padding: 28px; }

  /* Dark shell */
  .dark-shell { margin: 0 12px; padding: 60px 0; }

}

/* Reduce motion for accessibility */
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal--up, .reveal-headline {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
    will-change: auto !important;
  }
  .aurora-atmosphere span,
  .aurora::before,
  .aurora::after {
    animation: none !important;
  }
}

/* ── Performance: layout containment without blocking visibility ── */
.comp {
  contain: layout style;
}

/* ============================================================
   PRODUKTWELT — Component-Level Overrides
   ============================================================ */

/* Library Chrome */
[data-world="produkt"] .lib-nav {
  background: var(--bg-secondary);
}
[data-world="produkt"] .lib-nav h2 { color: var(--t1); }
[data-world="produkt"] .lib-nav .ver,
[data-world="produkt"] .lib-nav .cat { color: var(--t3); }
[data-world="produkt"] .lib-nav a { color: var(--t2); }
[data-world="produkt"] .lib-nav a:hover { color: var(--accent); }
[data-world="produkt"] .comp__head { background: var(--bg-secondary); }
[data-world="produkt"] .comp__head h3 { color: var(--t1); }
[data-world="produkt"] .comp__head p { color: var(--t2); }
[data-world="produkt"] .comp__label { color: var(--t3); }

/* Navigation — already white by default, no Produkt-Welt overrides needed */

/* Section Labels */
[data-world="produkt"] .section-label {
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
[data-world="produkt"] .section-label--dark {
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  border-color: rgba(0,0,0,0.12);
}

/* Hero — bleibt in Produktwelt dunkel wie in Markenwelt */
[data-world="produkt"] .hero {
  background: #151539;
}
[data-world="produkt"] .hero h1 { color: var(--white); -webkit-text-fill-color: var(--white); }
[data-world="produkt"] .hero__sub { color: #9098b0; }
[data-world="produkt"] .hero--center {
  background: #151539;
}
[data-world="produkt"] .hero .section-label--dark {
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
[data-world="produkt"] .hero-metrics { border-color: rgba(255,255,255,0.06); }
[data-world="produkt"] .hero-metrics__num,
[data-world="produkt"] .hero-metrics__num .num-suffix {
  background: linear-gradient(135deg, #8FFBBD, #67DEE3);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
[data-world="produkt"] .hero-metrics__label { color: #9098b0; }

/* Buttons */
[data-world="produkt"] .btn--outline {
  color: var(--white);
  border-color: rgba(255,255,255,0.3);
}
[data-world="produkt"] .btn--outline:hover {
  border-color: rgba(255,255,255,0.6);
  background: rgba(255,255,255,0.06);
}
[data-world="produkt"] .btn--outline-light {
  color: #151539;
  border: 2px solid transparent;
  background: linear-gradient(#fff, #fff) padding-box,
              linear-gradient(135deg, rgba(103,222,227,0.6), rgba(143,251,189,0.6)) border-box;
}
[data-world="produkt"] .btn--outline-light:hover {
  color: #151539;
  background: linear-gradient(rgba(103,222,227,0.06), rgba(143,251,189,0.06)) padding-box,
              linear-gradient(135deg, rgba(103,222,227,0.8), rgba(143,251,189,0.8)) border-box;
}

/* Cards — Flat */
[data-world="produkt"] .card-flat {
  background: var(--white);
  border: 1px solid var(--border);
}
[data-world="produkt"] .card-flat:hover {
  background: var(--bg-secondary);
}
[data-world="produkt"] .card-flat__label { color: var(--accent); }
[data-world="produkt"] .card-flat__title { color: var(--tl1); }
[data-world="produkt"] .card-flat__body { color: var(--tl2); }
[data-world="produkt"] .card-flat__link { color: var(--accent); }

/* Cards — Image */
[data-world="produkt"] .card-img__visual {
  background: var(--bg-secondary);
}
[data-world="produkt"] .card-img__cat { color: var(--accent); }
[data-world="produkt"] .card-img__title { color: var(--tl1); }

/* Cards — Case Study */
[data-world="produkt"] .card-case::before {
  background: linear-gradient(to top, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0.3) 50%, transparent);
}
[data-world="produkt"] .card-case__label { color: var(--accent); }
[data-world="produkt"] .card-case__title { color: var(--tl1); }
[data-world="produkt"] .card-case__metric { color: var(--accent); }

/* Section — Split */
[data-world="produkt"] .section-split--dark {
  background: var(--bg-secondary);
}
[data-world="produkt"] .section-split--dark h2 { color: var(--tl1); }
[data-world="produkt"] .section-split--dark p { color: var(--tl2); }
[data-world="produkt"] .section-split__media {
  background: var(--white);
  border: 1px solid var(--border);
}
/* Marke-Override: Sektionen mit data-world="marke" behalten dunkles Design auch in Produktwelt-Seiten */
[data-world="marke"] {
  /* Hintergründe */
  --bg-deep: #151539;
  --bg-primary: #151539;
  --bg-secondary: #1A1A42;
  --bg-card: rgba(255,255,255,0.04);
  --bg-card-hover: rgba(255,255,255,0.08);
  --bg-elevated: #22224E;

  /* Text Dark BG */
  --t1: rgba(255,255,255,0.95);
  --t2: rgba(255,255,255,0.65);
  --t3: rgba(255,255,255,0.35);

  /* Text Light BG → im Marke-Kontext ebenfalls hell (BG ist immer dunkel) */
  --tl1: rgba(255,255,255,0.95);
  --tl2: rgba(255,255,255,0.65);
  --tl3: rgba(255,255,255,0.35);

  /* Akzent — Cyan/Mint */
  --accent: #67DEE3;
  --accent-hover: #8FFBBD;
  --accent-light: #8FFBBD;
  --accent-glow: rgba(103, 222, 227, 0.12);
  --accent-gradient: linear-gradient(135deg, #67DEE3, #8FFBBD);

  /* Pink */
  --pink: #FF2B84;
  --pink-hover: #FF4D9A;
  --pink-glow: rgba(255, 43, 132, 0.15);

  /* Borders & Glass */
  --border: rgba(255,255,255,0.08);
  --border-accent: #AC0A4D;
  --glass: rgba(255,255,255,0.04);
  --glass-border: rgba(255,255,255,0.08);
}
/* Aurora-Sektionen mit Marke-Override brauchen expliziten dunklen Hintergrund */
.aurora[data-world="marke"] { background: var(--bg-deep); }
.section-split--dark[data-world="marke"] { background: #151539; }
.section-split--dark[data-world="marke"] .section-split__media { border: none; }

/* Steps */
[data-world="produkt"] .section-steps {
  background: var(--white);
}
[data-world="produkt"] .step {
  border-color: rgba(0,0,0,0.08);
}
[data-world="produkt"] .step__num {
  background: linear-gradient(135deg, #8FFBBD, #67DEE3);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
[data-world="produkt"] .step h3 { color: var(--tl1); }
[data-world="produkt"] .step p { color: var(--tl2); }

/* Service Tags */
[data-world="produkt"] .section-tags {
  background: var(--white);
}
[data-world="produkt"] .tags-intro h2 { color: var(--tl1); }
[data-world="produkt"] .tags-intro p { color: var(--tl2); }
[data-world="produkt"] .tag {
  color: #151539;
  border: 2px solid transparent;
  background: linear-gradient(#fff, #fff) padding-box,
              linear-gradient(135deg, rgba(103,222,227,0.6), rgba(143,251,189,0.6)) border-box;
}
[data-world="produkt"] .tag:hover {
  color: #151539;
  background: linear-gradient(rgba(103,222,227,0.06), rgba(143,251,189,0.06)) padding-box,
              linear-gradient(135deg, rgba(103,222,227,0.8), rgba(143,251,189,0.8)) border-box;
}

/* News / Carousel */
[data-world="produkt"] .news-grid {
  background: var(--white);
}
[data-world="produkt"] .news-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
}
[data-world="produkt"] .news-card__title { color: var(--tl1); }
[data-world="produkt"] .news-card__desc { color: var(--tl2); }

/* Testimonial Wall */
[data-world="produkt"] .section-testimonials {
  background: var(--bg-secondary);
}
[data-world="produkt"] .testi-card {
  background: var(--white);
  border: 1px solid var(--border);
}
[data-world="produkt"] .testi-card:hover {
  border-color: rgba(0, 88, 255, 0.3);
  box-shadow: 0 8px 32px rgba(0,0,0,0.06), 0 0 0 1px rgba(0, 88, 255, 0.1);
}
[data-world="produkt"] .testi-card__text { color: var(--tl2); }
[data-world="produkt"] .testi-card__name { color: var(--tl1); }
[data-world="produkt"] .testi-card__role { color: var(--tl2); }
[data-world="produkt"] .testi-card__avatar { background: linear-gradient(135deg, rgba(0,88,255,0.1), rgba(103,222,227,0.1)); color: #0058FF; }
[data-world="produkt"] .testi-card__tag { background: rgba(0,88,255,0.06); color: #0058FF; }

/* Logo Leiste */
[data-world="produkt"] .section-logos {
  background: var(--white);
}
[data-world="produkt"] .logos-label { color: var(--tl1); }
[data-world="produkt"] .logo-bar {
  background: var(--off-white);
  border-color: rgba(0,0,0,0.08);
}
[data-world="produkt"] .logo-bar__label { color: var(--tl3); }
[data-world="produkt"] .logo-bar__item { color: var(--tl1); }

/* FAQ */
[data-world="produkt"] .section-faq {
  background: var(--white);
}
[data-world="produkt"] .faq-title { color: var(--tl1); }
[data-world="produkt"] .faq-item {
  border-color: rgba(0,0,0,0.08);
}
[data-world="produkt"] .faq__q { color: var(--tl1); }
[data-world="produkt"] .faq__a { color: var(--tl2); }
[data-world="produkt"] .faq__item--open .faq__q { color: var(--accent); }
[data-world="produkt"] .faq__item { border-color: rgba(0,0,0,0.08); }
[data-world="produkt"] .faq__arrow { color: var(--tl3); }

/* CTA Banner */
[data-world="produkt"] .section-cta {
  background: linear-gradient(135deg, #110BB9, #0058FF);
  color: var(--white);
}
[data-world="produkt"] .cta-content h2 { color: var(--white); }
[data-world="produkt"] .cta-content p { color: rgba(255,255,255,0.9); }

/* Product Showcase */
[data-world="produkt"] .showcase {
  background: var(--white);
}
[data-world="produkt"] .showcase-item {
  background: var(--bg-secondary);
  border-color: var(--border);
}
[data-world="produkt"] .showcase-item.active {
  background: rgba(0,88,255,0.06);
  border-left-color: var(--accent);
}
[data-world="produkt"] .showcase-item__text strong { color: var(--tl1); }
[data-world="produkt"] .showcase-item__text span { color: var(--tl2); }
[data-world="produkt"] .showcase-preview {
  background: var(--bg-secondary);
  border-color: var(--border);
  color: var(--t2);
}

/* Article */
[data-world="produkt"] .section-article {
  background: var(--white);
}
[data-world="produkt"] .article-layout { background: var(--white); }
[data-world="produkt"] .article__header { border-color: var(--border); }
[data-world="produkt"] .article__header h1 { color: var(--tl1); }
[data-world="produkt"] .article__meta { color: var(--tl3); }
[data-world="produkt"] .article__share-label { color: var(--tl2); }
[data-world="produkt"] .share-btn { border-color: var(--border); color: var(--tl2); }
[data-world="produkt"] .article__body h2 { color: var(--tl1); }
[data-world="produkt"] .article__body h3 { color: var(--tl1); }
[data-world="produkt"] .article__body p { color: var(--tl2); }
[data-world="produkt"] .article__body strong { color: var(--tl1); }
[data-world="produkt"] .article__body li { color: var(--tl2); }
[data-world="produkt"] .callout { background: rgba(0, 88, 255, 0.05); }
[data-world="produkt"] .callout p { color: var(--tl1); }
[data-world="produkt"] .toc__box {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
}
[data-world="produkt"] .toc__title { color: var(--tl1); }
[data-world="produkt"] .toc__list a { color: var(--tl2); }
[data-world="produkt"] .toc__list a:hover { color: var(--tl1); background: rgba(0,0,0,0.02); }
[data-world="produkt"] .toc__list a.active { color: #0058FF; background: rgba(0, 88, 255, 0.05); }
[data-world="produkt"] .toc__meta { color: var(--tl3); border-color: var(--border); }
[data-world="produkt"] .toc__meta strong { color: var(--tl1); }
[data-world="produkt"] .toc__share { border-color: var(--border); }
[data-world="produkt"] .toc__reading { color: var(--tl3); border-color: var(--border); }

/* ============================================================
   ARTICLE HERO — Breadcrumb, Badge & Meta im Hero
   Für Blog-Artikel mit hero--light als Header
   ============================================================ */
.article-hero__breadcrumb {
  font-size: 14px; color: rgba(255,255,255,0.5); margin-bottom: 32px;
}
.article-hero__breadcrumb a {
  color: var(--accent); text-decoration: none;
}
.article-hero__breadcrumb a:hover { text-decoration: underline; }

.article-hero__meta {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  justify-content: center; margin-bottom: 24px;
  font-size: 15px; color: rgba(255,255,255,0.6);
}
.article-hero__badge {
  display: inline-flex; align-items: center; padding: 6px 16px;
  background: rgba(0,88,255,0.15); border: 1px solid rgba(0,88,255,0.25);
  border-radius: 6px; color: var(--accent); font-size: 12px;
  font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
}
.article-hero__sep { color: rgba(255,255,255,0.3); }

/* Section Article — Abstand wenn Hero darüber */
.section-article.has-hero { padding-top: 60px; }

/* Section Related — Weiterführende Artikel */
.section-related {
  padding: 80px 0;
}

[data-world="produkt"] .article-hero__breadcrumb { color: rgba(255,255,255,0.5); }
[data-world="produkt"] .article-hero__meta { color: rgba(255,255,255,0.6); }

/* Related Articles */
[data-world="produkt"] .section-related {
  background: var(--bg-secondary);
  border-color: var(--border);
}

/* Related Articles in Markenwelt (dark) — overrides produkt parent */
.section-related[data-world="marke"] {
  background: var(--bg-primary, #080B16);
  border-color: transparent;
}
.section-related[data-world="marke"] .h-section {
  color: var(--white, #fff);
}
.section-related[data-world="marke"] .field-card__cat {
  color: var(--accent-light, #67DEE3);
}
.section-related[data-world="marke"] .field-card__title {
  color: var(--t1, rgba(255,255,255,0.95));
}
.section-related[data-world="marke"] .field-card__title .arrow {
  color: var(--accent-light, #67DEE3);
}


/* Footer */
/* Footer — immer Markenwelt (dunkel), auch auf Produktwelt-Seiten */
.footer {
  background: #151539;
  border-color: rgba(255,255,255,0.06);
}
.footer__brand { color: #eef0f6; }
.footer__desc { color: #9098b0; }
.footer__col-title { color: #eef0f6; }
.footer__links a { color: #9098b0; }
.footer__links a:hover { color: #67DEE3; }
.footer__bottom { color: #5c6380; border-color: rgba(255,255,255,0.06); }
.footer__legal a { color: #5c6380; }
.footer__legal a:hover { color: #67DEE3; }

/* Section Dim */
[data-world="produkt"] .section-dim__overlay {
  background: rgba(248, 249, 252, 0.95);
}
[data-world="produkt"] .dark-shell {
  background: var(--bg-secondary);
}

/* Problem/Solution Cards */
[data-world="produkt"] .card-ps p { color: var(--tl2); }
[data-world="produkt"] .ba-list li {
  color: var(--tl2);
  border-color: rgba(0,0,0,0.08);
}

/* Showcase hover */
[data-world="produkt"] .showcase-item:hover:not(.active) {
  background: rgba(0,0,0,0.02);
}
[data-world="produkt"] .showcase-item.active .showcase-item__text strong {
  color: var(--accent);
}

/* Leistungsfelder */
[data-world="produkt"] .section-fields {
  background: var(--bg-secondary);
}
[data-world="produkt"] .section-fields__label { color: var(--accent); }
[data-world="produkt"] .section-fields__headline { color: var(--tl1); }
[data-world="produkt"] .field-card__title { color: var(--tl1); }
[data-world="produkt"] .field-card__title .arrow { color: var(--accent); }
[data-world="produkt"] .field-card__desc { color: var(--tl2); }

/* ============================================================
   MARKE-OVERRIDE — Sektionen mit data-world="marke" in Produkt-Seiten
   Muss NACH allen [data-world="produkt"] Regeln stehen (gleiche Spezifität, Reihenfolge gewinnt)
   ============================================================ */
/* Backgrounds */
.aurora[data-world="marke"]         { background: var(--bg-deep); }
.section-steps[data-world="marke"]  { background: var(--bg-primary); }
.section-faq[data-world="marke"]    { background: var(--bg-primary); }
.section-fields[data-world="marke"] { background: var(--bg-deep); }

/* Aurora-Atmosphäre in Marke-Sektionen wieder einblenden
   (Produkt-Welt versteckt alle .aurora-atmosphere pauschal) */
[data-world="marke"] .aurora-atmosphere { display: block; }

/* Card-Flat: Produkt nutzt var(--white) → Marke braucht eigene Regeln */
[data-world="marke"] .card-flat {
  background: var(--bg-card);
  border: 1px solid var(--border);
}
[data-world="marke"] .card-flat:hover {
  background: var(--bg-card-hover);
}

/* Borders mit hardcoded Produkt-Farben zurücksetzen */
[data-world="marke"] .step          { border-color: var(--border); }
[data-world="marke"] .faq__item     { border-color: var(--border); }

/* ============================================================
   IMAGE SUBSTITUTION: Markenwelt uses premium abstract images
   ============================================================ */
/* Image Card 1 - Abstract Blue Wave */
[data-world="marke"] #c-img .card-img:nth-child(1) .card-img__visual {
  background-image: url('img/branche-tile-01.jpg') !important;
}
/* Image Card 2 - Flowing Blue Waves Glow */
[data-world="marke"] #c-img .card-img:nth-child(2) .card-img__visual {
  background-image: url('img/branche-tile-02.jpg') !important;
}
/* Image Card 3 - Abstract Ring */
[data-world="marke"] #c-img .card-img:nth-child(3) .card-img__visual {
  background-image: url('img/branche-tile-03.jpg') !important;
}

/* ===== Article Hero Share Icons ===== */
.article-hero__share {
  display: flex; align-items: center; gap: 14px;
  justify-content: center; margin-top: 28px;
}
.article-hero__share-label {
  font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.1em; color: rgba(255,255,255,0.5);
}
.article-hero__share .hero-share-btn {
  width: 48px; height: 48px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid rgba(255,255,255,0.15);
  background: transparent;
  color: rgba(255,255,255,0.7);
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}
.article-hero__share .hero-share-btn::before {
  content: '';
  position: absolute; inset: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, #67DEE3, #8FFBBD);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.article-hero__share .hero-share-btn:hover {
  border-color: transparent;
  color: #051c2c;
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(103, 222, 227, 0.35);
}
.article-hero__share .hero-share-btn:hover::before {
  opacity: 1;
}
.article-hero__share .hero-share-btn svg {
  width: 20px; height: 20px;
  position: relative; z-index: 1;
}

/* Bento Mosaic — Markenwelt hat keinen Override nötig, dark ist default */
