/* =========================================================================
   newborn-itconsulting.de — main.css
   Design-Tokens und Layout-Basis
   Farb- und Font-Werte aus der alten Betheme-WordPress-Site extrahiert.
   ========================================================================= */

/* === Self-hosted Fonts (WOFF2 zuerst, TTF als Fallback fuer alte Browser) === */
@font-face {
  font-family: "Manrope";
  src: url("/assets/fonts/Manrope-VariableFont_wght.woff2") format("woff2-variations"),
       url("/assets/fonts/Manrope-VariableFont_wght.ttf") format("truetype-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Figtree";
  src: url("/assets/fonts/Figtree-VariableFont_wght.woff2") format("woff2-variations"),
       url("/assets/fonts/Figtree-VariableFont_wght.ttf") format("truetype-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* === Design-Tokens === */
:root {
  /* Farbpalette (Blau-fokussiert) */
  --color-primary:        #0089f7;  /* Hauptblau — CTAs, Links, Akzent */
  --color-primary-hover:  #006edf;  /* Hover für Primary */
  --color-primary-dark:   #00294b;  /* Dunkelblau — Headlines, Header, dunkle Bereiche */
  --color-primary-light:  #55ade2;  /* Hellblau — Sekundär-Akzent, Badges */
  --color-accent:         #00a9cb;  /* Türkis — Hover-States, sekundäre Akzente */
  --color-teal-dark:      #104550;  /* Tiefes Teal — Button-Borders, Footer-Akzent */

  /* Neutrale Töne — abgeschwächtes Off-White für ruhiges Gesamtbild */
  --color-text:           #161922;  /* Haupt-Textfarbe (fast schwarz) */
  --color-text-muted:     #4b5563;  /* Body-Text, sekundär */
  --color-text-subtle:    #6b7280;  /* Hinweistexte, Datumsangaben */
  --color-bg:             #f8fafc;  /* abgeschwächtes Weiß, Haupt-Background */
  --color-bg-soft:        #eef2f7;  /* Section-Trennung subtil (helles Blau-Grau) */
  --color-bg-tint:        #e2ecf7;  /* Akzent-Section (Blau-Tint) */
  --color-bg-card:        #ffffff;  /* Cards bleiben klar weiß für Kontrast */
  --color-border:         #d1d9e6;
  --color-border-soft:    #e5eaf1;

  /* Status */
  --color-success:        #3a8b5b;
  --color-danger:          #cf2e2e;

  /* Schriften */
  --font-body:    "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-heading: "Figtree", "Manrope", system-ui, sans-serif;

  /* Heading-Skala — größer und mit mehr Wirkung, inspiriert von Premium-Themes */
  --fs-hero: clamp(2.75rem, 6vw + 1rem, 5.5rem);  /* 44–88 px Hero-Headline */
  --fs-h1:   clamp(2.5rem, 4.5vw + 1rem, 4.5rem); /* 40–72 px */
  --fs-h2:   clamp(2rem,   3.5vw + 0.75rem, 3.5rem); /* 32–56 px */
  --fs-h3:   clamp(1.5rem, 2vw + 0.5rem, 2.5rem);  /* 24–40 px */
  --fs-h4:   clamp(1.25rem, 1vw + 0.5rem, 1.75rem); /* 20–28 px */
  --fs-h5:   1.25rem;   /* 20 px */
  --fs-h6:   0.875rem;  /* 14 px */
  --fs-body: 1.0625rem; /* 17 px für bessere Lesbarkeit */
  --fs-small: 0.9375rem;

  --lh-tight: 1.1;
  --lh-normal: 1.5;
  --lh-loose: 1.7;

  /* Spacing-Skala */
  --space-3xs: 0.25rem;
  --space-2xs: 0.5rem;
  --space-xs:  0.75rem;
  --space-sm:  1rem;
  --space-md:  1.5rem;
  --space-lg:  2rem;
  --space-xl:  3rem;
  --space-2xl: 4rem;
  --space-3xl: 6rem;
  --space-4xl: 8rem;

  /* Layout */
  --max-width:        1920px;
  --max-width-text:   75ch;
  --container-pad:    clamp(1rem, 5vw, 4rem);

  /* Radien */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;
  --radius-pill: 999px;

  /* Schatten */
  --shadow-sm: 0 1px 2px rgba(0, 41, 75, 0.06);
  --shadow-md: 0 4px 12px rgba(0, 41, 75, 0.08);
  --shadow-lg: 0 12px 32px rgba(0, 41, 75, 0.12);

  /* Transitions */
  --transition: 0.2s ease;
}

/* === Reset / Normalize (minimal) === */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  overflow-x: clip;
  max-width: 100%;
}

img, video, svg, iframe {
  max-width: 100%;
  height: auto;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--color-text);
  background: var(--color-bg);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

img, picture, svg, video {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition);
}
a:hover, a:focus {
  color: var(--color-primary-hover);
  text-decoration: underline;
}

ul, ol { padding-inline-start: 1.25em; }
li + li { margin-block-start: 0.25em; }

button {
  font-family: inherit;
  cursor: pointer;
}

/* === Typography === */
h1, h2, h3, h4 {
  font-family: var(--font-heading);
  color: var(--color-primary-dark);
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-md);
  font-weight: 600;
}
h5, h6 {
  font-family: var(--font-body);
  font-weight: 500;
  margin: 0 0 var(--space-sm);
  color: var(--color-text);
}

h1 { font-size: var(--fs-h1); letter-spacing: -0.03em; }
h2 { font-size: var(--fs-h2); letter-spacing: -0.02em; }
h3 { font-size: var(--fs-h3); letter-spacing: -0.01em; }
h4 { font-size: var(--fs-h4); }
h5 { font-size: var(--fs-h5); }
h6 { font-size: var(--fs-h6); }

p { margin: 0 0 var(--space-md); }

/* Fließtext-Container für lange Inhalte */
.prose {
  max-width: var(--max-width-text);
}

/* === Accessibility-Helpers === */
.skip-link {
  position: absolute;
  inset-inline-start: -9999px;
  top: 0;
  background: var(--color-primary-dark);
  color: #fff;
  padding: var(--space-sm) var(--space-md);
  z-index: 9999;
}
.skip-link:focus {
  inset-inline-start: 0;
}

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

:focus-visible {
  outline: 3px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: 2px;
}

/* === Container === */
.container {
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

/* === Buttons === */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2xs);
  padding: 0.875rem 1.75rem;
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.2;
  border: 2px solid transparent;
  border-radius: var(--radius-md);
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
  cursor: pointer;
  text-decoration: none;
}

.button--primary {
  background: var(--color-primary);
  color: #fff;
}
.button--primary:hover, .button--primary:focus {
  background: var(--color-primary-hover);
  color: #fff;
  text-decoration: none;
  transform: translateY(-1px);
}

.button--ghost {
  background: transparent;
  color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
}
.button--ghost:hover, .button--ghost:focus {
  background: var(--color-primary-dark);
  color: #fff;
  text-decoration: none;
}

/* === Site-Header / Navigation === */
/* Variante A: klassisch sticky weiß (Subpages mit hellem Hero). */
/* Variante B: "Floating Pill" — als rounded weißer Container über dem Hero. */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  pointer-events: none; /* Klicks gehen durch wo nichts ist */
  transition: top 0.25s ease;
}
/* Beim Scrollen (via JS .is-scrolled): klassische rechteckige Top-Bar oben angeheftet.
   Übersteuert die overlay/pill-Variante. */
.site-header.is-scrolled,
.site-header.is-scrolled.is-overlay {
  margin-bottom: 0;
  background: rgba(248, 250, 252, 0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-border-soft);
}
.site-header.is-scrolled .site-nav {
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  margin: 0;
  transition: background var(--transition), box-shadow var(--transition), border-radius var(--transition), margin var(--transition);
}
.site-header.is-scrolled .site-nav__inner {
  padding: var(--space-sm) var(--container-pad);
}
.site-header.is-overlay {
  /* überlagert den Hero (Home, Service-Pages mit BG-Bild) */
  margin-bottom: -90px;
  background: transparent;
}
.site-header:not(.is-overlay) {
  background: rgba(248, 250, 252, 0.85);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-border-soft);
}
.site-header > * { pointer-events: auto; }

.site-nav {
  background: var(--color-bg);
  border-radius: 999px;
  box-shadow: 0 8px 30px rgba(0, 41, 75, 0.08);
  margin: var(--space-md) var(--container-pad) 0;
}
.site-header:not(.is-overlay) .site-nav {
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  margin: 0;
}

.site-nav__inner {
  max-width: var(--max-width);
  margin-inline: auto;
  padding: 0.75rem var(--space-lg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
}
.site-header:not(.is-overlay) .site-nav__inner {
  padding: var(--space-sm) var(--container-pad);
}

.site-nav__call {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-family: var(--font-body);
  font-size: 0.875rem;
  color: var(--color-text-muted);
}
.site-nav__call-label { display: none; }
@media (min-width: 1100px) { .site-nav__call-label { display: inline; } }
.site-nav__call-number {
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--color-primary-dark);
  text-decoration: none;
}
.site-nav__call-number:hover { color: var(--color-primary); }
.site-nav__cta {
  background: var(--color-primary);
  color: #fff;
  padding: 0.6em 1.25em;
  border-radius: 999px;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.9375rem;
  text-decoration: none;
  transition: background var(--transition), transform var(--transition);
  white-space: nowrap;
}
.site-nav__cta:hover { background: var(--color-primary-dark); color: #fff; transform: translateY(-1px); text-decoration: none; }

.site-nav__brand { display: flex; align-items: center; }
.site-nav__logo  { height: 48px; width: auto; }

.site-nav__menu {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: var(--space-lg);
  align-items: center;
}
.site-nav__mobile-only { display: none; }
.site-nav__item + .site-nav__item { margin-block-start: 0; }

.site-nav__link {
  font-family: var(--font-body);
  font-weight: 500;
  color: var(--color-primary-dark);
  padding: var(--space-2xs) 0;
  position: relative;
}
.site-nav__link:hover,
.site-nav__link:focus,
.site-nav__link.is-active {
  color: var(--color-primary);
  text-decoration: none;
}
.site-nav__link.is-active::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  bottom: -4px;
  height: 2px;
  background: var(--color-primary);
  border-radius: 2px;
}

.site-nav__caret {
  font-size: 0.7em;
  margin-inline-start: 0.25em;
  transition: transform var(--transition);
  display: inline-block;
}
.site-nav__item.has-mega:hover .site-nav__caret,
.site-nav__item.has-mega:focus-within .site-nav__caret,
.site-nav__item.has-mega.is-open .site-nav__caret {
  transform: rotate(180deg);
}

.site-nav__brand-text {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary-dark);
}

/* === Mega-Menu === */
.site-nav__item.has-mega { position: static; }

.mega-menu {
  position: absolute;
  inset-inline: 0;
  top: 100%;
  background: var(--color-bg);
  border-top: 1px solid var(--color-border-soft);
  border-bottom: 3px solid var(--color-primary);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s linear 0.2s;
  z-index: 90;
}

/* Hover-Bridge: unsichtbarer Bereich oberhalb des Mega-Menus, damit die Maus
   nicht in einem Pixel-Gap zwischen Nav-Item und Dropdown "abrutscht". */
.mega-menu::before {
  content: "";
  position: absolute;
  inset-inline: 0;
  top: -16px;
  height: 16px;
}

/* Geöffnet wird das Menü ausschließlich über JS via .is-open, NICHT mehr per :hover/:focus-within
   (sonst schließt es zu schnell, sobald die Maus den Nav-Punkt verlässt). */
.site-nav__item.has-mega.is-open .mega-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s;
}

.mega-menu__inner {
  max-width: var(--max-width);
  margin-inline: auto;
  padding: var(--space-xl) var(--container-pad);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl);
}

.mega-menu__heading {
  font-family: var(--font-heading);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin: 0 0 var(--space-md);
  padding-bottom: var(--space-2xs);
  border-bottom: 2px solid var(--color-border-soft);
}

.mega-menu__list { list-style: none; padding: 0; margin: 0; }
.mega-menu__list li + li { margin-block-start: var(--space-2xs); }

.mega-menu__link {
  display: block;
  padding: var(--space-2xs) var(--space-sm);
  border-radius: var(--radius-md);
  color: var(--color-primary-dark);
  text-decoration: none;
  transition: background var(--transition), color var(--transition);
}
.mega-menu__link:hover,
.mega-menu__link:focus-visible {
  background: var(--color-bg-soft);
  color: var(--color-primary);
  text-decoration: none;
}

.mega-menu__label {
  display: block;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
}
.mega-menu__desc {
  display: block;
  font-size: var(--fs-small);
  color: var(--color-text-muted);
}

/* === Mobile Nav === */
.site-nav__toggle {
  display: none;
  background: transparent;
  border: 0;
  padding: var(--space-2xs);
  flex-direction: column;
  gap: 5px;
}
.site-nav__toggle span {
  display: block;
  width: 28px; height: 3px;
  background: var(--color-primary-dark);
  border-radius: 2px;
  transition: transform var(--transition), opacity var(--transition);
}

@media (max-width: 960px) {
  .site-header { top: 1.5rem; }
  .site-header.is-scrolled { top: 0; }
  .site-nav__toggle { display: inline-flex; order: 2; }
  .site-nav__call { display: none; }
  .site-nav__cta { display: none; }
  .site-nav__inner { padding: 0.6rem 1rem; }
  .site-nav__logo { height: 36px; }

  .site-nav__menu {
    position: fixed;
    inset: 72px 0 0 0;
    background: var(--color-bg);
    flex-direction: column;
    gap: 0;
    padding: var(--space-md) var(--container-pad) var(--space-3xl);
    /* Element bleibt im Viewport (kein translateX) — Slide-Effekt via clip-path,
       damit DevTools keinen Content-Overflow melden. */
    clip-path: inset(0 0 0 100%);
    pointer-events: none;
    transition: clip-path 0.3s ease;
    overflow-y: auto;
    align-items: stretch;
  }
  .site-nav__menu.is-open {
    clip-path: inset(0 0 0 0);
    pointer-events: auto;
  }

  /* Tel + CTA werden nur in aufgeklapptem Mobile-Menü sichtbar */
  .site-nav__mobile-only { display: block !important; }
  .site-nav__mobile-only + .site-nav__mobile-only { border-top: 0; }

  .site-nav__item { width: 100%; border-bottom: 1px solid var(--color-border-soft); }
  .site-nav__link {
    display: block;
    padding: var(--space-md) 0;
    font-size: 1.125rem;
  }

  /* Mega-Menu auf Mobile als Accordion */
  .mega-menu {
    position: static;
    box-shadow: none;
    border-top: 0;
    border-bottom: 0;
    opacity: 1;
    visibility: visible;
    transform: none;
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition);
  }
  .site-nav__item.has-mega.is-open .mega-menu {
    max-height: 1500px;
    transition: max-height 0.5s ease-in-out;
  }
  .mega-menu__inner {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
    padding: var(--space-md) 0 var(--space-lg);
  }
  .mega-menu__heading { font-size: 0.75rem; margin-bottom: var(--space-sm); }
  .mega-menu__link { padding: var(--space-sm); }

  body.nav-is-open { overflow: hidden; }
}

/* === Site-Main / Sections === */
.site-main { min-height: 60vh; }

.section {
  position: relative;
  padding-block: clamp(var(--space-2xl), 6vw, var(--space-4xl));
  overflow: hidden;
}
.section--soft { background: var(--color-bg-soft); }
.section--tint { background: var(--color-bg-tint); }
.section--dark {
  background: linear-gradient(135deg, var(--color-primary-dark), #001a30);
  color: #fff;
}
.section--dark h1, .section--dark h2, .section--dark h3, .section--dark h4 { color: #fff; }

/* Abstrakte Deko-Shapes für Sections (positioniert über ::before / ::after) */
.section--shape-tl::before {
  content: "";
  position: absolute;
  top: -120px; left: -120px;
  width: 360px; height: 360px;
  background: radial-gradient(circle, rgba(0,137,247,0.07), transparent 70%);
  border-radius: 50%;
  z-index: 0;
  pointer-events: none;
}
.section--shape-br::after {
  content: "";
  position: absolute;
  bottom: -160px; right: -100px;
  width: 420px; height: 420px;
  background: radial-gradient(circle, rgba(85,173,226,0.08), transparent 70%);
  border-radius: 50%;
  z-index: 0;
  pointer-events: none;
}
.section > * { position: relative; z-index: 1; }

/* === Site-Footer === */
.site-footer {
  background: var(--color-primary-dark);
  color: rgba(255, 255, 255, 0.85);
  padding-block: var(--space-2xl);
}
.site-footer a {
  color: rgba(255, 255, 255, 0.85);
}
.site-footer a:hover, .site-footer a:focus {
  color: var(--color-primary-light);
}

.site-footer__inner {
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: var(--container-pad);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-xl);
}

.site-footer__heading {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-primary-light);
  margin: 0 0 var(--space-md);
}

.site-footer__list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.site-footer__list li + li { margin-top: var(--space-2xs); }

.site-footer__address { font-style: normal; line-height: var(--lh-loose); }
.site-footer__claim { color: rgba(255,255,255,0.7); margin-top: var(--space-sm); }

.site-footer__bottom {
  max-width: var(--max-width);
  margin: var(--space-2xl) auto 0;
  padding: var(--space-md) var(--container-pad) 0;
  border-top: 1px solid rgba(255,255,255,0.1);
  text-align: center;
  font-size: var(--fs-small);
  color: rgba(255,255,255,0.6);
}

/* === Cookie-Banner === */
/* Backdrop-Overlay bei Force-Choice (erster Besuch) */
.cookie-banner-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 41, 75, 0.6);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  z-index: 8999;
  animation: fadeIn 0.25s ease-out;
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
body.is-consent-locked {
  overflow: hidden;
}

.cookie-banner {
  position: fixed;
  inset: auto 0 0 0;
  background: var(--color-bg);
  border-top: 3px solid var(--color-primary);
  box-shadow: 0 -16px 40px rgba(0, 41, 75, 0.18);
  z-index: 9000;
  animation: slideUp 0.3s ease-out;
  max-height: 90vh;
  overflow-y: auto;
}
@keyframes slideUp {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}
.cookie-banner__inner {
  max-width: 720px;
  margin-inline: auto;
  padding: var(--space-lg) var(--container-pad);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.cookie-banner__head {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
}
.cookie-banner__heading {
  font-family: var(--font-heading);
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0;
}
.cookie-banner__text {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  line-height: 1.55;
}
.cookie-banner__details-toggle {
  background: transparent;
  border: 0;
  padding: 0;
  font: inherit;
  color: var(--color-primary);
  cursor: pointer;
  text-align: left;
  font-size: 0.8125rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  align-self: flex-start;
}
.cookie-banner__details-toggle::after {
  content: "›";
  display: inline-block;
  transition: transform var(--transition);
  font-size: 1.1em;
  line-height: 1;
}
.cookie-banner.is-details-open .cookie-banner__details-toggle::after {
  transform: rotate(90deg);
}
.cookie-banner__options {
  display: none;
  flex-direction: column;
  gap: var(--space-sm);
  padding-top: var(--space-sm);
}
.cookie-banner.is-details-open .cookie-banner__options { display: flex; }
.cookie-banner.is-settings .cookie-banner__options { display: flex; }
.cookie-banner.is-settings .cookie-banner__details-toggle { display: none; }

.cookie-banner__actions {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  justify-content: flex-end;
}
@media (max-width: 640px) {
  .cookie-banner__actions { flex-direction: column-reverse; }
  .cookie-banner__actions .button { width: 100%; }
}

/* === Cookie-Option (Toggle-Switch + Label) === */
.cookie-option {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-md);
  align-items: flex-start;
  padding: var(--space-md);
  background: var(--color-bg-soft);
  border-radius: var(--radius-md);
  cursor: pointer;
}
.cookie-option--locked { cursor: default; opacity: 0.85; }
.cookie-option__switch {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
}
.cookie-option__switch input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  margin: 0;
}
.cookie-option__switch input:disabled { cursor: default; }
.cookie-option__slider {
  position: absolute;
  inset: 0;
  background: var(--color-border);
  border-radius: 999px;
  transition: background var(--transition);
}
.cookie-option__slider::before {
  content: "";
  position: absolute;
  height: 18px;
  width: 18px;
  left: 3px;
  top: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform var(--transition);
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.cookie-option__switch input:checked + .cookie-option__slider {
  background: var(--color-primary);
}
.cookie-option__switch input:checked + .cookie-option__slider::before {
  transform: translateX(20px);
}
.cookie-option__switch input:focus-visible + .cookie-option__slider {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.cookie-option__body { display: flex; flex-direction: column; gap: 0.25rem; }
.cookie-option__title {
  font-weight: 600;
  color: var(--color-primary-dark);
  font-size: 0.875rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
}
.cookie-option__badge {
  font-size: 0.6875rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  background: #fff;
  padding: 0.15em 0.6em;
  border-radius: 999px;
  border: 1px solid var(--color-border-soft);
}
.cookie-option__desc {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}
.cookie-option__services {
  list-style: none;
  padding: 0;
  margin: var(--space-2xs) 0 0;
  font-size: 0.75rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}
.cookie-option__services li {
  padding: 0.25rem 0 0.25rem 0.75rem;
  border-left: 2px solid var(--color-border);
  margin-top: 0.25rem;
}
.cookie-option__services strong { color: var(--color-primary-dark); }

/* === Floating Settings-Icon (unten links, immer sichtbar) === */
.consent-fab {
  position: fixed;
  bottom: clamp(1rem, 3vw, 1.5rem);
  left: clamp(1rem, 3vw, 1.5rem);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #fff;
  color: var(--color-primary);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-md);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 150;
  transition: background var(--transition), color var(--transition), transform var(--transition);
}
.consent-fab:hover {
  background: var(--color-primary);
  color: #fff;
  transform: translateY(-2px);
}
.consent-fab:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* === FAQ-Akkordeon (native <details>) === */
.faq-item {
  border-bottom: 1px solid var(--color-border-soft);
  padding-block: var(--space-md);
}
.faq-item > summary {
  font-family: var(--font-heading);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  cursor: pointer;
  list-style: none;
  padding-inline-end: var(--space-xl);
  position: relative;
}
.faq-item > summary::-webkit-details-marker { display: none; }
.faq-item > summary::after {
  content: "+";
  position: absolute;
  inset-inline-end: 0;
  top: 0;
  font-size: 1.5rem;
  color: var(--color-primary);
  transition: transform var(--transition);
}
.faq-item[open] > summary::after { content: "−"; }
.faq-item > *:not(summary) { margin-top: var(--space-sm); }

/* === Hero (Spaciaz-Style: full-width BG-Image, zentrierte H1, Teaser-Cards unten) === */
.hero {
  position: relative;
  /* min-height von 78vh auf 60vh reduziert — weniger leere Fläche unter dem Content,
     Hero schrumpft auf näher am Inhalt + Padding. */
  min-height: 60vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  /* Bottom-Padding halbiert (war clamp(4rem, 8vw, 6rem)) */
  padding-block: clamp(6rem, 12vw, 10rem) clamp(2rem, 4vw, 3rem);
  overflow: hidden;
  isolation: isolate;
  color: #fff;
  background-color: var(--color-primary-dark);
}
@media (max-width: 720px) {
  .hero {
    min-height: auto;
    padding-block: 9rem 1.5rem;
  }
}
@media (max-width: 480px) {
  .hero {
    padding-block: 8rem 1.25rem;
  }
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
}
.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(
      ellipse 900px 500px at center 60%,
      rgba(0, 20, 40, 0.65) 0%,
      rgba(0, 20, 40, 0) 70%
    ),
    linear-gradient(
      180deg,
      rgba(0, 20, 40, 0.78) 0%,
      rgba(0, 20, 40, 0.72) 50%,
      rgba(0, 20, 40, 0.9) 100%
    );
}

.hero__container {
  position: relative;
  z-index: 1;
  max-width: var(--max-width);
  margin-inline: auto;
  padding: 0 var(--container-pad);
  text-align: center;
  width: 100%;
}

.hero h1,
.hero__container h1 {
  color: #ffffff !important;
  font-size: clamp(2.25rem, 6vw + 1rem, 6rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.035em;
  margin: 0 auto var(--space-md);
  max-width: 16ch;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  animation: fadeInUp 0.7s ease-out 0.1s both;
}
@media (max-width: 480px) {
  .hero h1, .hero__container h1 { font-size: clamp(2rem, 9vw, 2.75rem); max-width: 100%; }
}
.hero .hero__lead,
.hero__container .hero__lead,
.hero__lead {
  font-size: clamp(1.125rem, 1vw + 0.6rem, 1.375rem);
  line-height: 1.6;
  color: #ffffff !important;
  font-weight: 500;
  max-width: 56ch;
  margin: 0 auto var(--space-xl);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  animation: fadeInUp 0.8s ease-out 0.2s both;
}
.hero__cta {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  justify-content: center;
  animation: fadeInUp 0.9s ease-out 0.3s both;
}
.hero .button--primary {
  background: #fff;
  color: var(--color-primary-dark);
}
.hero .button--primary:hover { background: var(--color-primary); color: #fff; }
.hero .button--ghost {
  border-color: rgba(255, 255, 255, 0.45);
  color: #fff;
}
.hero .button--ghost:hover { background: rgba(255, 255, 255, 0.12); color: #fff; }

/* Sub-Bar im Hero (zwischen Headline und Teaser-Cards) */
.hero__subbar {
  position: relative;
  z-index: 1;
  max-width: var(--max-width);
  margin: clamp(2rem, 6vw, 4rem) auto 0;
  padding: 0 var(--container-pad);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-lg);
  align-items: end;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  padding-top: var(--space-lg);
}
@media (max-width: 768px) { .hero__subbar { grid-template-columns: 1fr; } }

.hero__sub-text {
  color: #fff;
  font-size: clamp(1.25rem, 2vw + 0.5rem, 2rem);
  font-family: var(--font-heading);
  font-weight: 500;
  line-height: 1.25;
  max-width: 40ch;
  margin: 0;
}

/* Teaser-Cards unten im Hero (überlappen die nächste Section) */
.hero__teasers {
  position: relative;
  z-index: 2;
  max-width: var(--max-width);
  margin: clamp(2rem, 5vw, 4rem) auto -8rem;
  padding: 0 var(--container-pad);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-md);
}
.hero-teaser {
  padding: var(--space-lg);
  background: linear-gradient(180deg, rgba(0, 41, 75, 0.75), rgba(0, 26, 48, 0.85));
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-lg);
  color: #fff;
  text-decoration: none;
  transition: transform var(--transition), background var(--transition);
}
.hero-teaser:hover {
  transform: translateY(-4px);
  background: linear-gradient(180deg, var(--color-primary), var(--color-primary-dark));
  text-decoration: none;
  color: #fff;
}
.hero-teaser__icon {
  width: 40px; height: 40px;
  color: var(--color-primary-light);
  margin-bottom: var(--space-sm);
  transition: color var(--transition);
}
.hero-teaser:hover .hero-teaser__icon { color: #fff; }
.hero-teaser__icon svg { width: 100%; height: 100%; }
.hero-teaser__title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: #fff;
  margin: 0 0 var(--space-2xs);
}
.hero-teaser__desc {
  font-size: 0.9375rem;
  color: rgba(255, 255, 255, 0.75);
  margin: 0;
  line-height: 1.5;
}

/* Body unter Hero bekommt durch hero__teasers automatischen Top-Padding.
   Ausnahme: .kpi-stripe direkt nach dem Hero soll seinen kleinen padding-top behalten. */
.hero + .section,
.hero + section:not(.kpi-stripe) { padding-top: clamp(8rem, 12vw, 12rem); }

/* === Eyebrow: schlichter Caps-Label mit kurzer Linie davor (kein Pill, kein animierter Dot) === */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.75em;
  font-family: var(--font-heading);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
  margin-bottom: var(--space-md);
}
.eyebrow::before {
  content: "";
  width: 32px;
  height: 2px;
  background: var(--color-primary);
}
.eyebrow--light { color: rgba(255, 255, 255, 0.9); }
.eyebrow--light::before { background: rgba(255, 255, 255, 0.7); }
.eyebrow--centered { justify-content: center; }
.hero__eyebrow { /* abwärtskompatibel falls noch verwendet */
  display: inline-flex; align-items: center; gap: 0.75em;
  font-family: var(--font-heading); font-size: 0.8125rem;
  font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--color-primary-dark); margin-bottom: var(--space-md);
}
.hero__eyebrow::before {
  content: ""; width: 32px; height: 2px; background: var(--color-primary);
}
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* === Card-Grid === */
.cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-lg);
}
.cards--3col {
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 960px) {
  .cards--3col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .cards--3col { grid-template-columns: 1fr; }
}
.card {
  position: relative;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg) var(--space-lg);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  overflow: hidden;
}
.card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
}
.card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-primary-light);
}
.card:hover::before { transform: scaleX(1); }

.card__icon {
  width: 56px; height: 56px;
  background: linear-gradient(135deg, rgba(0, 137, 247, 0.1), rgba(85, 173, 226, 0.05));
  color: var(--color-primary);
  border-radius: var(--radius-md);
  display: grid; place-items: center;
  margin-bottom: var(--space-md);
  transition: transform 0.3s ease, background 0.3s ease;
}
.card__icon svg { width: 28px; height: 28px; }
.card:hover .card__icon {
  transform: scale(1.1) rotate(-4deg);
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  color: #fff;
}
.card__title {
  font-family: var(--font-heading);
  font-size: 1.375rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-sm);
}
.card__desc {
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  line-height: var(--lh-normal);
  margin: 0 0 var(--space-md);
}
.card__link {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--color-primary);
  text-decoration: none;
}
.card__link::after {
  content: " →";
  transition: margin var(--transition);
  display: inline-block;
}
.card__link:hover::after { margin-left: 4px; }

/* === Service-Card (auf Hub-Page, große visuell-reiche Karten) === */
.service-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  overflow: hidden;
  min-height: 280px;
}
.service-card::after {
  content: "";
  position: absolute;
  bottom: -60px; right: -60px;
  width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(0, 137, 247, 0.06), transparent 70%);
  border-radius: 50%;
  transition: transform 0.5s ease;
}
.service-card:hover::after,
.service-card:focus-visible::after { transform: scale(1.4); }

.service-card:hover,
.service-card:focus-visible {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-primary);
  text-decoration: none;
}
.service-card__icon {
  position: relative;
  z-index: 1;
  width: 64px; height: 64px;
  background: linear-gradient(135deg, rgba(0, 137, 247, 0.1), rgba(85, 173, 226, 0.05));
  color: var(--color-primary);
  border-radius: var(--radius-md);
  display: grid; place-items: center;
  margin-bottom: var(--space-lg);
  transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease;
}
.service-card__icon svg { width: 32px; height: 32px; }
.service-card:hover .service-card__icon {
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  color: #fff;
  transform: rotate(-4deg) scale(1.05);
}
.service-card__category {
  position: relative;
  z-index: 1;
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--space-2xs);
}
.service-card__title {
  position: relative;
  z-index: 1;
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-sm);
  line-height: 1.2;
}
.service-card__desc {
  position: relative;
  z-index: 1;
  font-size: var(--fs-body);
  color: var(--color-text-muted);
  flex-grow: 1;
  margin: 0 0 var(--space-md);
  line-height: 1.6;
}
.service-card__cta {
  position: relative;
  z-index: 1;
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
}
.service-card__cta::after {
  content: "→";
  display: inline-block;
  transition: transform 0.3s ease;
}
.service-card:hover .service-card__cta::after { transform: translateX(4px); }

/* === Steps (Vorgehen) === */
.steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-lg);
  counter-reset: step;
}
.step {
  position: relative;
  padding: var(--space-lg) var(--space-md) var(--space-md);
  background: var(--color-bg-soft);
  border-radius: var(--radius-lg);
  counter-increment: step;
}
.step::before {
  content: counter(step, decimal-leading-zero);
  position: absolute;
  top: -0.5em;
  left: var(--space-md);
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.5rem;
  padding: 0.1em 0.6em;
  border-radius: var(--radius-md);
}
.step__title {
  font-family: var(--font-heading);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: var(--space-sm) 0 var(--space-2xs);
}
.step__desc {
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  margin: 0;
}

/* === USP / Trust (4 Spalten) === */
.usp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-xl);
}
.usp {
  text-align: center;
  padding: var(--space-lg) var(--space-md);
}
.usp__icon {
  width: 72px; height: 72px;
  margin: 0 auto var(--space-md);
  background: linear-gradient(135deg, rgba(0, 137, 247, 0.12), rgba(85, 173, 226, 0.05));
  color: var(--color-primary);
  border-radius: var(--radius-lg);
  display: grid; place-items: center;
  transition: transform 0.3s ease;
}
.usp__icon svg { width: 36px; height: 36px; }
.usp:hover .usp__icon {
  transform: scale(1.08) rotate(-4deg);
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  color: #fff;
}
.usp__title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0 0 var(--space-2xs);
}
.usp__desc { font-size: var(--fs-small); color: var(--color-text-muted); margin: 0; line-height: 1.6; }

/* === Pricing-Block === */
.pricing {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-lg);
}
.pricing__card {
  background: var(--color-bg-card);
  border: 2px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
}
.pricing__card.is-featured {
  border-color: var(--color-primary);
  position: relative;
}
.pricing__card.is-featured::before {
  content: "Beliebt";
  position: absolute;
  top: -0.75em;
  inset-inline-start: 50%;
  transform: translateX(-50%);
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-heading);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.3em 1em;
  border-radius: var(--radius-pill);
  text-transform: uppercase;
}
.pricing__name {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-2xs);
}
.pricing__price {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-primary);
  margin: 0 0 var(--space-md);
}
.pricing__price small {
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--color-text-muted);
}
.pricing__features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-md);
  flex-grow: 1;
}
.pricing__features li {
  padding: 0.4em 0 0.4em 1.5em;
  position: relative;
  font-size: var(--fs-small);
}
.pricing__features li::before {
  content: "✓";
  position: absolute;
  inset-inline-start: 0;
  color: var(--color-success);
  font-weight: 700;
}

/* === CTA-Block (Akzent-Blau) === */
.cta {
  position: relative;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: var(--space-3xl) var(--space-xl);
  text-align: center;
  margin-block: var(--space-xl);
  overflow: hidden;
  isolation: isolate;
}
.cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 15% 20%, rgba(255,255,255,0.12), transparent 40%),
    radial-gradient(circle at 85% 80%, rgba(255,255,255,0.08), transparent 50%);
  z-index: -1;
}
.cta h2 { color: #fff; margin: 0 0 var(--space-sm); font-size: clamp(1.75rem, 3vw, 2.75rem); }
.cta p {
  color: rgba(255, 255, 255, 0.9);
  max-width: 60ch;
  margin: 0 auto var(--space-lg);
  font-size: 1.125rem;
}
.cta .button--primary {
  background: #fff;
  color: var(--color-primary);
  font-weight: 700;
}
.cta .button--primary:hover { background: var(--color-bg-tint); color: var(--color-primary-dark); transform: translateY(-2px); }
.cta .button--ghost {
  border-color: rgba(255, 255, 255, 0.5);
  color: #fff;
}
.cta .button--ghost:hover { background: rgba(255, 255, 255, 0.15); color: #fff; border-color: #fff; }
.cta__actions { display: inline-flex; flex-wrap: wrap; gap: var(--space-md); justify-content: center; }

/* === Logo-Strip === */
.logo-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-xl);
  opacity: 0.65;
}
.logo-strip img { max-height: 40px; width: auto; }

/* === FAQ improvements (in Service-Pages besser sichtbar) === */
.faq {
  max-width: 80ch;
  margin-inline: auto;
}
.faq-group__title {
  font-family: var(--font-heading);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
  font-weight: 600;
  margin: var(--space-xl) 0 var(--space-sm);
  padding-bottom: var(--space-2xs);
  border-bottom: 1px solid var(--color-border-soft);
}
.faq-group__title:first-child {
  margin-top: 0;
}

/* === Section-Heading-Bereich === */
.section__head { text-align: center; margin-bottom: var(--space-2xl); }
.section__head h2 { margin-bottom: var(--space-sm); }
.section__head .lead {
  font-size: 1.125rem;
  color: var(--color-text-muted);
  max-width: 60ch;
  margin: 0 auto;
}

/* === Service-Card mit Hintergrundbild (Hub-Page Hauptvariante) === */
.service-tile {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  aspect-ratio: 4/5;
  min-height: 360px;
  background: var(--color-primary-dark);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-decoration: none;
  color: #fff;
  isolation: isolate;
}
.service-tile__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
}
.service-tile__bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.8s ease;
}
.service-tile:hover .service-tile__bg img { transform: scale(1.08); }
.service-tile__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 41, 75, 0.35) 0%, rgba(0, 41, 75, 0.85) 100%);
  z-index: 1;
}
.service-tile__top {
  position: relative;
  z-index: 1;
  padding: var(--space-lg) var(--space-lg) 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.service-tile__arrow {
  width: 40px; height: 40px;
  background: rgba(255, 255, 255, 0.92);
  border-radius: 50%;
  display: grid; place-items: center;
  color: var(--color-primary-dark);
  transition: background var(--transition), transform var(--transition);
}
.service-tile:hover .service-tile__arrow {
  background: var(--color-primary);
  color: #fff;
  transform: rotate(-45deg);
}
.service-tile__arrow svg { width: 18px; height: 18px; }
.service-tile__body {
  position: relative;
  z-index: 1;
  padding: 0 var(--space-lg) var(--space-lg);
}
.service-tile__category {
  display: inline-block;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.75);
  margin-bottom: var(--space-2xs);
}
.service-tile__title {
  font-family: var(--font-heading);
  font-size: clamp(1.25rem, 2vw, 1.625rem);
  font-weight: 600;
  color: #fff;
  margin: 0 0 var(--space-sm);
  line-height: 1.2;
}
.service-tile__desc {
  color: rgba(255, 255, 255, 0.85);
  font-size: 0.9375rem;
  line-height: 1.5;
  margin: 0;
}

/* === Image+Text-Section (Bild links + Text rechts mit Icon-Liste) === */
.image-text {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(var(--space-xl), 5vw, var(--space-3xl));
  align-items: center;
}
.image-text--reverse { direction: rtl; }
.image-text--reverse > * { direction: ltr; }
@media (max-width: 900px) { .image-text { grid-template-columns: 1fr; } }

.image-text__media {
  position: relative;
}
.image-text__media img {
  width: 100%;
  border-radius: var(--radius-lg);
  aspect-ratio: 4/5;
  object-fit: cover;
  box-shadow: var(--shadow-md);
}
.image-text__floating {
  position: absolute;
  bottom: var(--space-lg);
  left: var(--space-lg);
  background: var(--color-bg-card);
  padding: var(--space-md);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  max-width: 220px;
}
.image-text__floating-num {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-primary);
  margin: 0;
  line-height: 1;
}
.image-text__floating-label {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  margin: 0.25em 0 0;
}

.image-text__body h2 { font-size: clamp(2rem, 3.5vw + 0.75rem, 3.25rem); margin-bottom: var(--space-md); }
.image-text__lead {
  font-size: 1.0625rem;
  color: var(--color-text-muted);
  line-height: 1.7;
  margin-bottom: var(--space-xl);
}
.feature-list { list-style: none; padding: 0; margin: 0; }
.feature-list__item {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-top: 1px solid var(--color-border-soft);
}
.feature-list__item:first-child { border-top: 0; padding-top: 0; }
.feature-list__icon {
  width: 56px; height: 56px;
  background: linear-gradient(135deg, rgba(0, 137, 247, 0.12), rgba(85, 173, 226, 0.05));
  color: var(--color-primary);
  border-radius: var(--radius-md);
  display: grid; place-items: center;
}
.feature-list__icon svg { width: 26px; height: 26px; }
.feature-list__title {
  font-family: var(--font-heading);
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0 0 0.25em;
}
.feature-list__desc { font-size: 0.9375rem; color: var(--color-text-muted); margin: 0; line-height: 1.6; }

/* === Stats-Block (Zahlen + großes Bild) === */
.stats-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: var(--space-md);
}
@media (max-width: 900px) { .stats-grid { grid-template-columns: 1fr 1fr; grid-template-rows: auto; } }
.stats-grid__media {
  grid-row: span 2;
  position: relative;
  aspect-ratio: 4/5;
  -webkit-clip-path: url(#media-tab-clip);
  clip-path: url(#media-tab-clip);
}
@media (max-width: 900px) { .stats-grid__media { grid-column: span 2; aspect-ratio: 4/5; } }
.stats-grid__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.stat-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.stat-card__label {
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  border-bottom: 1px solid var(--color-border-soft);
  padding-bottom: var(--space-sm);
  margin-bottom: var(--space-md);
}
.stat-card__value {
  font-family: var(--font-heading);
  font-size: clamp(2.5rem, 4vw + 1rem, 4rem);
  font-weight: 700;
  color: var(--color-primary-dark);
  line-height: 1;
  margin: auto 0 0.25em;
}
.stat-card__value sup { color: var(--color-primary); font-size: 0.5em; vertical-align: super; }
.stat-card__sub {
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  margin: 0;
}
.stat-card--image {
  padding: 0;
  overflow: hidden;
  position: relative;
  aspect-ratio: 4/3;
}
.stat-card--image img { width: 100%; height: 100%; object-fit: cover; }

/* Mobile: 1 Spalte, kleines Bild ausblenden — MUSS NACH allen stat-card / stat-card--image Default-Regeln kommen */
@media (max-width: 640px) {
  .stats-grid { grid-template-columns: 1fr; }
  .stats-grid__media { grid-column: span 1; }
  .stat-card--image { display: none; }
}

/* === Final-CTA-Section vor Footer (Screen 7 Style) === */
.final-cta {
  position: relative;
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: clamp(4rem, 10vw, 8rem) var(--container-pad);
  overflow: hidden;
  color: #fff;
  background: var(--color-primary-dark);
}
.final-cta__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
}
.final-cta__bg img { width: 100%; height: 100%; object-fit: cover; }
.final-cta__bg::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0, 41, 75, 0.6), rgba(0, 26, 48, 0.85));
}
.final-cta__watermark {
  position: absolute;
  bottom: -2vw;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(8rem, 16vw, 20rem);
  color: rgba(255, 255, 255, 0.05);
  letter-spacing: -0.04em;
  pointer-events: none;
  white-space: nowrap;
  z-index: 0;
  max-width: 100%;
}
@media (max-width: 1024px) {
  .final-cta__watermark { font-size: 9rem; }
}
@media (max-width: 768px) {
  .final-cta__watermark { font-size: 7rem; }
}
@media (max-width: 480px) {
  .final-cta__watermark { font-size: 5.5rem; }
}
@media (max-width: 400px) {
  .final-cta__watermark { font-size: 4.5rem; }
}
@media (max-width: 360px) {
  .final-cta__watermark { font-size: 4rem; }
}
.final-cta__inner { position: relative; z-index: 1; max-width: 800px; }
.final-cta h2 {
  font-size: clamp(2.5rem, 5vw + 1rem, 5rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.05;
  margin: 0 0 var(--space-md);
  letter-spacing: -0.02em;
}
.final-cta p {
  color: rgba(255, 255, 255, 0.85);
  font-size: 1.0625rem;
  max-width: 50ch;
  margin: 0 auto var(--space-xl);
}
.final-cta__circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.9375rem;
  line-height: 1.2;
  text-decoration: none;
  text-align: center;
  padding: 1em;
  transition: transform var(--transition), background var(--transition), box-shadow var(--transition);
  box-shadow: 0 12px 40px rgba(0, 137, 247, 0.4);
}
.final-cta__circle:hover {
  background: #fff;
  color: var(--color-primary);
  transform: scale(1.05);
  text-decoration: none;
  box-shadow: 0 16px 48px rgba(0, 137, 247, 0.5);
}

/* === Contact-Form-CTA-Section (Screen 6 Style: BG-Bild + Form-Card) === */
.contact-cta {
  position: relative;
  padding: clamp(3rem, 8vw, 6rem) var(--container-pad);
  background: var(--color-bg-soft);
}
.contact-cta__bg {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  max-width: var(--max-width);
  margin: 0 auto;
  min-height: 480px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.contact-cta__bg-img {
  position: absolute; inset: 0;
  z-index: -2;
}
.contact-cta__bg-img img { width: 100%; height: 100%; object-fit: cover; }
.contact-cta__bg-img::after {
  content: "";
  position: absolute; inset: 0;
  background: rgba(0, 41, 75, 0.55);
}
.contact-cta__card {
  position: relative;
  z-index: 1;
  background: var(--color-bg-card);
  border-radius: var(--radius-lg);
  padding: clamp(2rem, 4vw, 3rem);
  max-width: 720px;
  width: calc(100% - var(--space-2xl));
  box-shadow: 0 24px 60px rgba(0, 41, 75, 0.25);
}
.contact-cta__card h2 {
  text-align: center;
  font-size: clamp(1.5rem, 2.5vw + 0.5rem, 2.25rem);
  margin-bottom: var(--space-lg);
}

/* === Footer (floating rounded white container) === */
body { background: var(--color-primary-dark); }
.site-main { background: var(--color-bg); }

.site-footer {
  background: transparent;
  color: var(--color-text);
  padding: clamp(var(--space-xl), 5vw, var(--space-3xl)) var(--container-pad) var(--space-xl);
  margin-top: 0;
}
.site-footer__card {
  max-width: var(--max-width);
  margin: 0 auto;
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  padding: clamp(2rem, 4vw, 3.5rem);
  box-shadow: 0 -10px 40px rgba(0, 41, 75, 0.08);
}

.site-footer__inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr 1.4fr;
  gap: clamp(var(--space-md), 3vw, var(--space-2xl));
  padding-bottom: var(--space-xl);
  border-bottom: 1px solid var(--color-border-soft);
}
@media (max-width: 900px) {
  .site-footer__inner { grid-template-columns: 1fr 1fr; }
  .site-footer__col--brand { grid-column: span 2; }
}
@media (max-width: 540px) {
  .site-footer__inner { grid-template-columns: 1fr; }
  .site-footer__col--brand { grid-column: span 1; }
}

.site-footer a {
  color: var(--color-text);
  text-decoration: none;
}
.site-footer a:hover { color: var(--color-primary); text-decoration: none; }

.site-footer__heading {
  font-family: var(--font-heading);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-muted);
  margin: 0 0 var(--space-md);
  text-transform: none;
  letter-spacing: 0;
}
.site-footer__list { list-style: none; padding: 0; margin: 0; }
.site-footer__list li { margin: 0 0 var(--space-sm); }
.site-footer__list a { font-weight: 500; }

.site-footer__col--brand .site-footer__claim {
  color: var(--color-text-muted);
  font-size: 0.9375rem;
  line-height: 1.6;
  margin: var(--space-md) 0 0;
}

.site-footer__contact { display: flex; flex-direction: column; gap: var(--space-md); }
.site-footer__contact-tel,
.site-footer__contact-mail {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  font-family: var(--font-heading);
  /* Schriftgröße auf max 1.125rem (18px) begrenzt, damit hello@newborn-itconsulting.de
     in der Footer-Spalte einzeilig bleibt. nowrap als zusätzliche Garantie. */
  font-size: clamp(0.9375rem, 0.5vw + 0.75rem, 1.125rem);
  font-weight: 600;
  color: var(--color-primary-dark);
  white-space: nowrap;
}
.site-footer__contact-tel svg,
.site-footer__contact-mail svg {
  width: 1.1em;
  height: 1.1em;
  flex-shrink: 0;
  color: var(--color-primary);
}
.site-footer__social {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
  font-size: 0.9375rem;
  color: var(--color-text-muted);
}
.site-footer__social a {
  display: inline-flex;
  align-items: center;
  gap: 0.45em;
  font-weight: 500;
}
.site-footer__social a svg {
  width: 1.1em;
  height: 1.1em;
  color: var(--color-primary);
}
.site-footer__social a:hover svg,
.site-footer__social a:focus-visible svg {
  color: var(--color-primary-hover);
}

.site-footer__bottom {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: var(--space-lg);
  font-size: 0.875rem;
  color: var(--color-text-muted);
  text-align: center;
}

.site-footer__logo { height: 44px; width: auto; }
.site-footer__logo-fallback {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-primary-dark);
}

/* === Back-to-Top-Button === */
.back-to-top {
  position: fixed;
  bottom: clamp(1rem, 3vw, 2rem);
  right: clamp(1rem, 3vw, 2rem);
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  border: none;
  display: grid;
  place-items: center;
  cursor: pointer;
  z-index: 200;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: opacity var(--transition), visibility var(--transition), transform var(--transition), background var(--transition);
  box-shadow: 0 8px 24px rgba(0, 137, 247, 0.4);
}
.back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.back-to-top:hover {
  background: var(--color-primary-dark);
  transform: translateY(-4px);
}
.back-to-top svg { width: 22px; height: 22px; }

/* === Reference-Card (Referenzen-Section auf Startseite) === */
.reference-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}
.reference-grid--3col { grid-template-columns: repeat(3, 1fr); }
.reference-grid--2col { grid-template-columns: repeat(2, 1fr); max-width: 960px; margin-inline: auto; }
.reference-grid--single { grid-template-columns: 1fr; max-width: 920px; margin-inline: auto; }
@media (max-width: 960px) {
  .reference-grid,
  .reference-grid--3col,
  .reference-grid--2col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .reference-grid,
  .reference-grid--3col,
  .reference-grid--2col { grid-template-columns: 1fr; }
}

/* Single-Card-Variante: horizontale Card (Bild links, Body rechts) damit die
   einzelne Referenz nicht leer aussieht. Auf Mobile faellt sie zurueck zur
   normalen vertikalen Card. */
.reference-grid--single .reference-card {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  align-items: stretch;
}
.reference-grid--single .reference-card__media {
  height: 100%;
  min-height: 320px;
}
.reference-grid--single .reference-card__body {
  padding: clamp(var(--space-lg), 2.5vw, var(--space-xl));
  justify-content: center;
}
.reference-grid--single .reference-card__title {
  font-size: clamp(1.5rem, 1.5vw + 1rem, 2rem);
}
@media (max-width: 700px) {
  .reference-grid--single .reference-card {
    grid-template-columns: 1fr;
  }
  .reference-grid--single .reference-card__media {
    min-height: 220px;
  }
}
.reference-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  border: 1px solid var(--color-border-soft);
  box-shadow: var(--shadow-sm);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
.reference-card:hover {
  text-decoration: none;
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-border);
  text-decoration: none;
}
.reference-card__media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--color-bg-soft);
}
.reference-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
.reference-card:hover .reference-card__media img {
  transform: scale(1.06);
}
/* Modifier für Bilder, die NICHT beschnitten werden sollen (z.B. Device-Mockups
   mit eigenem Background). Bild wird komplett ins Frame eingepasst, Letterboxing
   matcht via Card-BG die soft-Section-Farbe — wirkt wie ein integriertes Showcase. */
.reference-card__media--contain img {
  object-fit: contain;
  padding: var(--space-md);
}
.reference-card:hover .reference-card__media--contain img {
  transform: scale(1.03); /* dezenter Hover, sonst läuft das Mockup über das padding */
}
.reference-card__body {
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  flex-grow: 1;
}
.reference-card__title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0;
  color: var(--color-primary-dark);
  line-height: 1.3;
}
.reference-card__location {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  margin: 0;
}
.reference-card__location svg { flex-shrink: 0; }
.reference-card__link {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  margin-top: auto;
  padding-top: var(--space-sm);
  color: var(--color-primary);
  font-weight: 600;
  font-size: 0.9375rem;
}
.reference-card__link svg {
  transition: transform 0.3s ease;
}
.reference-card:hover .reference-card__link {
  color: var(--color-primary-hover);
}
.reference-card:hover .reference-card__link svg {
  transform: translateX(4px);
}

/* === Trust-Logos-Strip (selbst-gehosted, in Akzent-Blau) === */
.trust-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: clamp(var(--space-lg), 3vw, var(--space-2xl));
}
.trust-logo {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1.125rem;
  color: var(--color-text-muted);
  opacity: 0.7;
  transition: opacity var(--transition), color var(--transition);
  letter-spacing: -0.01em;
}
.trust-logo:hover {
  opacity: 1;
  color: var(--color-primary-dark);
}
.trust-logo--small { font-size: 0.9375rem; }

/* === Stats-Row (4 große Zahlen in einer Reihe) === */
.stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-lg);
  padding: var(--space-xl) 0;
  border-top: 1px solid var(--color-border-soft);
  border-bottom: 1px solid var(--color-border-soft);
}
.stat-row-item {
  text-align: center;
  padding: var(--space-md);
}
.stat-row-item__value {
  font-family: var(--font-heading);
  font-size: clamp(2.5rem, 4vw + 0.5rem, 4.5rem);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1;
  margin: 0 0 var(--space-2xs);
  letter-spacing: -0.02em;
}
.stat-row-item__value sup {
  color: var(--color-primary-dark);
  font-size: 0.5em;
  vertical-align: super;
  font-weight: 600;
}
.stat-row-item__label {
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  margin: 0;
}

/* === Testimonial-Card === */
.testimonials {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-lg);
}
.testimonial {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg);
  position: relative;
  display: flex;
  flex-direction: column;
}
.testimonial::before {
  content: """;
  position: absolute;
  top: -0.2em;
  left: var(--space-md);
  font-family: var(--font-heading);
  font-size: 6rem;
  color: var(--color-primary);
  opacity: 0.18;
  line-height: 1;
}
.testimonial__quote {
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--color-text);
  margin: 0 0 var(--space-lg);
  flex-grow: 1;
  position: relative;
  z-index: 1;
}
.testimonial__author {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.testimonial__avatar {
  width: 48px; height: 48px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.testimonial__name {
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0;
  font-size: 0.9375rem;
}
.testimonial__role {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  margin: 0;
}
.testimonial__stars {
  display: flex;
  gap: 2px;
  margin-bottom: var(--space-sm);
  color: var(--color-primary);
}
.testimonial__stars svg { width: 16px; height: 16px; fill: currentColor; }

/* === Comparison-Table === */
.compare-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-lg);
}
.compare-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--color-bg-card);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 41, 75, 0.06);
  min-width: 720px;
}
.compare-table th,
.compare-table td {
  padding: var(--space-md) var(--space-lg);
  text-align: left;
  border-bottom: 1px solid var(--color-border-soft);
  font-size: 0.9375rem;
  vertical-align: top;
}
.compare-table thead th {
  font-family: var(--font-heading);
  font-size: 1.0625rem;
  font-weight: 600;
  background: var(--color-bg-soft);
  color: var(--color-primary-dark);
}
.compare-table th:first-child,
.compare-table td:first-child {
  color: var(--color-text-muted);
  font-weight: 500;
  width: 30%;
}
.compare-table .col-newborn {
  background: rgba(0, 137, 247, 0.04);
  position: relative;
}
.compare-table thead .col-newborn {
  color: var(--color-primary);
  background: rgba(0, 137, 247, 0.08);
}
.compare-table tbody tr:last-child td { border-bottom: 0; }
.compare-table .check { color: var(--color-success); font-weight: 600; }
.compare-table .cross { color: var(--color-text-subtle); }

/* Mobile: Card-Stack-Layout statt Tabelle */
@media (max-width: 640px) {
  .compare-table { min-width: 0; display: block; box-shadow: none; background: transparent; }
  .compare-table thead { display: none; }
  .compare-table tbody { display: flex; flex-direction: column; gap: var(--space-md); }
  .compare-table tr {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: var(--color-bg-card);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0, 41, 75, 0.06);
  }
  .compare-table td {
    padding: var(--space-sm) var(--space-md);
    border-bottom: 0;
    font-size: 0.875rem;
  }
  .compare-table td:first-child {
    grid-column: 1 / -1;
    background: var(--color-bg-soft);
    font-family: var(--font-heading);
    font-weight: 600;
    color: var(--color-primary-dark);
    width: auto;
    padding: var(--space-sm) var(--space-md);
  }
  .compare-table td:nth-child(2)::before {
    content: "DIY-Baukasten";
    display: block;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    margin-bottom: 0.25em;
  }
  .compare-table td:nth-child(3)::before {
    content: "NewBorn";
    display: block;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-primary);
    margin-bottom: 0.25em;
  }
}

/* === Industries-Grid === */
.industries {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-md);
}
.industry {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  transition: border-color var(--transition), transform var(--transition);
}
.industry:hover {
  border-color: var(--color-primary-light);
  transform: translateY(-2px);
}
.industry__icon {
  width: 36px; height: 36px;
  background: rgba(0, 137, 247, 0.1);
  color: var(--color-primary);
  border-radius: var(--radius-sm);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.industry__icon svg { width: 20px; height: 20px; }
.industry__name {
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0;
  font-size: 0.9375rem;
}

/* === About-Section (Wer wir sind: links Eyebrow, rechts große H2, darunter 2 Spalten + Stats-Grid) === */
.about-header {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: clamp(var(--space-md), 3vw, var(--space-2xl));
  margin-bottom: var(--space-2xl);
  align-items: start;
}
.about-header .eyebrow { margin-top: 0.6em; }
.about-header h2 {
  font-size: clamp(2rem, 4vw + 0.5rem, 4rem);
  margin: 0;
  letter-spacing: -0.02em;
  line-height: 1.1;
}
@media (max-width: 900px) {
  .about-header { grid-template-columns: 1fr; gap: var(--space-md); }
}

.about-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  margin-left: auto;
  max-width: 66.66%;
  margin-bottom: var(--space-2xl);
}
@media (max-width: 900px) {
  .about-cols { grid-template-columns: 1fr; max-width: 100%; gap: var(--space-lg); }
}

.about-col__title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-sm);
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
}
.about-col__title svg {
  width: 28px; height: 28px;
  color: var(--color-primary);
}
.about-col p {
  color: var(--color-text-muted);
  font-size: 1rem;
  line-height: 1.65;
  margin: 0;
}

.stat-card--statement p {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--color-text);
  margin: var(--space-sm) 0 0;
  font-weight: 500;
}
.stat-card--statement .stat-card__value { display: none; }
.stat-card--statement .stat-card__sub { display: none; }

/* =========================================================================
   STARTSEITE + KONTAKT — Komponenten ab Phase 4
   ========================================================================= */

/* === Hero-Split: BG-Bild volle Breite, Content linke Hälfte ===
   Container folgt exakt der gleichen Positionierungs-Logik wie
   .site-nav__inner (außen container-pad-Margin via min(), innen space-lg-Padding),
   damit der Text auf einer vertikalen Linie mit dem NewBorn-Logo der Nav
   beginnt — auf jeder Bildschirmbreite. */
.hero--split .hero__container {
  text-align: left;
  width: min(100% - 2 * var(--container-pad), var(--max-width));
  max-width: none;
  margin-inline: auto;
  padding-inline: var(--space-lg);
}
.hero--split .hero__container h1 {
  margin-inline: 0;
  /* max-width ~ halbe Container-Breite (24ch ≈ Bruchpunkt für 3 Zeilen).
     22ch war zu eng (5 Zeilen), 34ch war zu breit (2 Zeilen, Hero zu flach
     → Stripe der Folgesektion sichtbar). 24ch trifft den Sweet-Spot. */
  max-width: 16ch;
  text-align: left;
  /* Etwas kleiner als der zentrierte Hero, weil mehr Text Platz braucht */
  font-size: clamp(2rem, 4.5vw + 0.5rem, 4.5rem);
  line-height: 1.08;
}
.hero--split .hero__container .hero__lead {
  margin-inline: 0;
  max-width: 45ch;
  text-align: left;
}
.hero--split .hero__cta {
  justify-content: flex-start;
}
.hero--split .hero__bg::after {
  /* Verlauf von dunkel links nach transparent rechts, damit Text auf BG lesbar bleibt. */
  background:
    linear-gradient(90deg, rgba(0, 20, 40, 0.85) 0%, rgba(0, 20, 40, 0.5) 55%, rgba(0, 20, 40, 0.2) 100%),
    linear-gradient(180deg, rgba(0, 20, 40, 0.45) 0%, rgba(0, 20, 40, 0.7) 100%);
}
@media (max-width: 720px) {
  .hero--split .hero__bg::after {
    background:
      linear-gradient(180deg, rgba(0, 20, 40, 0.7) 0%, rgba(0, 20, 40, 0.85) 100%);
  }
  .hero--split .hero__container h1 { max-width: 100%; }
}

/* === KPI-Stripe (direkt unter dem Hero) === */
.kpi-stripe {
  background: var(--color-bg-card);
  border-block: 1px solid var(--color-border-soft);
  /* Top-Padding gemessen austariert (+2rem) */
  padding-block: clamp(2.5rem, 3vw, 2.75rem) clamp(2rem, 4vw, 3rem);
  position: relative;
  z-index: 2;
  margin-top: 0;
}
.hero + .kpi-stripe {
  margin-top: -1px; /* nahtloser Übergang zum Hero */
}
.kpi-stripe__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl);
  align-items: center;
}
@media (max-width: 700px) { .kpi-stripe__grid { grid-template-columns: 1fr; gap: var(--space-md); } }

.kpi {
  text-align: center;
  padding: var(--space-sm) var(--space-md);
  position: relative;
}
.kpi + .kpi {
  border-inline-start: 1px solid var(--color-border-soft);
}
@media (max-width: 700px) {
  .kpi + .kpi { border-inline-start: 0; }
}
.kpi__value {
  font-family: var(--font-heading);
  font-size: clamp(2.5rem, 4vw + 0.5rem, 3.75rem);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1;
  margin: 0 0 var(--space-2xs);
  letter-spacing: -0.02em;
}
.kpi__value sup {
  font-size: 0.5em;
  color: var(--color-primary-dark);
  vertical-align: super;
  font-weight: 600;
}
.kpi__value small {
  font-size: 0.55em;
  color: var(--color-primary-dark);
  font-weight: 600;
}
.kpi__label {
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  margin: 0;
}

/* Wenn KPI-Stripe direkt nach dem Hero kommt: kein Top-Padding der nachfolgenden .section nötig */
.hero + .kpi-stripe + .section { padding-top: clamp(var(--space-2xl), 6vw, var(--space-4xl)); }

/* === Process / Ablauf (4 Schritte mit Nummer, Icon, Titel, Beschreibung) === */
.process {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
  counter-reset: process;
  position: relative;
}
@media (max-width: 960px) { .process { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .process { grid-template-columns: 1fr; } }

.process__step {
  position: relative;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg) var(--space-lg);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  margin: 0;
}
.process__step + .process__step { margin-top: 0; }
.process__step:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary-light);
}
/* Verbindungslinie zwischen den Steps (Desktop, dezent) */
@media (min-width: 961px) {
  .process__step:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    inset-inline-end: calc(var(--space-lg) * -0.5 - 6px);
    width: 12px;
    height: 12px;
    transform: translateY(-50%) rotate(45deg);
    border-top: 2px solid var(--color-primary-light);
    border-right: 2px solid var(--color-primary-light);
    opacity: 0.5;
  }
}
.process__num {
  position: absolute;
  top: var(--space-md);
  inset-inline-end: var(--space-md);
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 800;
  color: var(--color-bg-soft);
  line-height: 1;
  letter-spacing: -0.04em;
}
.process__icon {
  width: 56px; height: 56px;
  background: linear-gradient(135deg, rgba(0, 137, 247, 0.1), rgba(85, 173, 226, 0.05));
  color: var(--color-primary);
  border-radius: var(--radius-md);
  display: grid; place-items: center;
  margin-bottom: var(--space-md);
  transition: transform 0.3s ease, background 0.3s ease;
}
.process__icon svg { width: 28px; height: 28px; }
.process__step:hover .process__icon {
  transform: scale(1.05) rotate(-3deg);
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  color: #fff;
}
.process__title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-sm);
}
.process__desc {
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  margin: 0;
}

/* === FAQ + Form Split-Section === */
.faq-form-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(var(--space-xl), 5vw, var(--space-3xl));
  align-items: start;
}
@media (max-width: 960px) {
  .faq-form-split { grid-template-columns: 1fr; gap: var(--space-2xl); }
}
.faq-form-split__faq h2 { margin-bottom: var(--space-sm); }
.faq-form-split__faq .lead {
  font-size: 1.0625rem;
  color: var(--color-text-muted);
}
.faq-form-split__form { position: sticky; top: 120px; }
@media (max-width: 960px) {
  .faq-form-split__form { position: static; }
}

/* === Contact-Form Card === */
.contact-form-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 3vw, 2.5rem);
  box-shadow: 0 8px 32px rgba(0, 41, 75, 0.06);
}
.contact-form-card--wide { max-width: 760px; margin-inline: auto; }
.contact-form-card__heading {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 2.5vw + 0.5rem, 2.25rem);
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-sm);
  letter-spacing: -0.01em;
}
.contact-form-card__sub {
  color: var(--color-text-muted);
  font-size: 1rem;
  margin: 0 0 var(--space-lg);
  line-height: 1.5;
}

.contact-form-wrap { padding-block: var(--space-md); }

/* === Form-Felder === */
.contact-form { display: flex; flex-direction: column; gap: var(--space-md); }

.form-row {
  display: grid;
  gap: var(--space-md);
}
.form-row--2 { grid-template-columns: 1fr 1fr; }
@media (max-width: 600px) { .form-row--2 { grid-template-columns: 1fr; } }

.form-field { display: flex; flex-direction: column; gap: 0.4rem; }
.form-field label {
  font-family: var(--font-heading);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  display: flex;
  align-items: baseline;
  gap: 0.5em;
}
.form-field .req { color: var(--color-primary); }
.form-field .opt { color: var(--color-text-subtle); font-weight: 400; font-size: 0.8125rem; }

.form-field input[type="text"],
.form-field input[type="email"],
.form-field input[type="tel"],
.form-field textarea {
  width: 100%;
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--color-text);
  background: var(--color-bg);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 0.75rem 0.9rem;
  transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}
.form-field textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.5;
}
.form-field input:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  background: var(--color-bg-card);
  box-shadow: 0 0 0 3px rgba(0, 137, 247, 0.15);
}
.form-field input::placeholder,
.form-field textarea::placeholder {
  color: var(--color-text-subtle);
  opacity: 1;
}

.form-field--check label {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-weight: 500;
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  line-height: 1.5;
  cursor: pointer;
}
.form-field--check input[type="checkbox"] {
  width: 1.125rem; height: 1.125rem;
  margin-top: 0.2rem;
  flex-shrink: 0;
  accent-color: var(--color-primary);
  cursor: pointer;
}

.form-error {
  margin: 0;
  font-size: 0.875rem;
  color: var(--color-danger);
}

.form-alert {
  padding: var(--space-md);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-lg);
  font-size: 0.9375rem;
  line-height: 1.5;
  border: 1.5px solid;
}
.form-alert--success {
  background: rgba(58, 139, 91, 0.08);
  border-color: var(--color-success);
  color: #1f5a37;
}
.form-alert--error {
  background: rgba(207, 46, 46, 0.06);
  border-color: var(--color-danger);
  color: #8c1717;
}

.contact-form__submit {
  align-self: flex-start;
  margin-top: var(--space-sm);
  padding-inline: 1.75rem;
}
.contact-form__submit svg { width: 18px; height: 18px; }

.contact-form__legal {
  font-size: 0.8125rem;
  color: var(--color-text-subtle);
  margin: var(--space-md) 0 0;
  line-height: 1.5;
}

/* Honeypot — für Bots sichtbar, für Nutzer und Screenreader unsichtbar */
.hp-field {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* === Page-Intro (kompakter Header für Subseiten ohne Hero) === */
.page-intro {
  padding-block: clamp(4rem, 8vw, 6rem) clamp(2rem, 4vw, 3rem);
}
.page-intro__inner {
  text-align: center;
  max-width: 760px;
  margin-inline: auto;
}
.page-intro h1 {
  font-size: clamp(2.25rem, 4vw + 1rem, 3.75rem);
  margin-bottom: var(--space-md);
}
.page-intro .lead {
  font-size: 1.125rem;
  color: var(--color-text-muted);
  line-height: 1.6;
}

/* === Contact-Grid (Kontakt-Seite) === */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
}
.contact-grid--3col { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 960px) {
  .contact-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-grid--3col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .contact-grid { grid-template-columns: 1fr; }
  .contact-grid--3col { grid-template-columns: 1fr; }
}

.contact-tile {
  display: flex;
  flex-direction: column;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  text-decoration: none;
  color: inherit;
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.contact-tile:not(.contact-tile--static):hover {
  transform: translateY(-4px);
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md);
  text-decoration: none;
}
.contact-tile--static { cursor: default; }
.contact-tile__icon {
  width: 48px; height: 48px;
  background: linear-gradient(135deg, rgba(0, 137, 247, 0.12), rgba(85, 173, 226, 0.05));
  color: var(--color-primary);
  border-radius: var(--radius-md);
  display: grid; place-items: center;
  margin-bottom: var(--space-md);
}
.contact-tile__icon svg { width: 22px; height: 22px; }
.contact-tile__label {
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0 0 0.4rem;
}
.contact-tile__value {
  font-family: var(--font-heading);
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0 0 0.4rem;
  line-height: 1.35;
  word-break: break-word;
}
.contact-tile__hint {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  margin: auto 0 0;
}

/* === Reviews-Hero (Full-BG Carousel mit Pill, Quote, Avatar, Arrows) === */
.reviews-hero {
  position: relative;
  isolation: isolate;
  /* overflow: visible, damit die Pille bei top:-10px nicht abgeschnitten wird.
     BG-Image-Container ist position:absolute; inset:0 — überfüllt die Section eh nicht. */
  overflow: visible;
  /* Section-BG matched die Section direkt darüber (.section--soft).
     Dort wo die mask-image den dunklen BG aus .reviews-hero__bg ausschneidet,
     scheint diese Farbe durch — kein Farbangleich-Problem mehr möglich. */
  background-color: var(--color-bg-soft);
  color: #ffffff;
  padding-block: clamp(7rem, 12vw, 10rem) clamp(4rem, 8vw, 6rem);
  margin-block: 0;
}
/* Der BG-Container hat selbst overflow: hidden, damit das Image nicht über
   die Section-Grenzen hinausragt (gleicher Effekt wie vorher auf .reviews-hero). */
.reviews-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  overflow: hidden;
}

/* Tab als gestyltes inline SVG — sitzt oben mittig auf dem dunklen BG,
   gefüllt mit der Section-BG-Farbe, wirkt visuell wie ein Cutout. */
.reviews-hero__tab {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 600px;
  height: 95px;
  z-index: 2;
  pointer-events: none;
  display: block;
}
.reviews-hero__tab path {
  fill: var(--color-bg-soft);
  /* Stroke in der gleichen Farbe verdeckt die SVG-Anti-Aliasing-Kante
     (sonst entsteht eine 1-px-Linie wo der Pfad auf den dunklen BG trifft). */
  stroke: var(--color-bg-soft);
  stroke-width: 1.5;
  vector-effect: non-scaling-stroke;
}
.reviews-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.reviews-hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 1100px 600px at center 55%, rgba(0, 20, 40, 0.65) 0%, rgba(0, 20, 40, 0) 70%),
    linear-gradient(180deg, rgba(0, 20, 40, 0.6) 0%, rgba(0, 20, 40, 0.5) 50%, rgba(0, 20, 40, 0.75) 100%);
}

/* Pille — sitzt absolut zentriert über dem Tab-Cutout, ragt deutlich über den
   Section-Top hinaus (top: -30px). */
.reviews-hero__pill {
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  background: var(--color-primary);
  color: #ffffff;
  font-family: var(--font-heading);
  font-size: 1.125rem;       /* +2px (von 16 → 18px) */
  font-weight: 500;
  padding: calc(0.65em + 5px) calc(1.4em + 5px);   /* +5px allseitig */
  border: 0;
  outline: 0;
  border-radius: var(--radius-pill);
  white-space: nowrap;
}
.reviews-hero__pill strong { font-weight: 700; }
.reviews-hero__pill-star {
  display: inline-grid;
  place-items: center;
  color: #ffd34a;
}
.reviews-hero__pill-star svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
  stroke: none;
}

@media (max-width: 540px) {
  .reviews-hero__pill {
    font-size: 0.875rem;
    padding: 0.6em 1.2em;
    top: -26px;
    /* Explizite width statt max-width — sonst shrinkt inline-flex auf die schmalste
       Wrap-Breite ("Bewertungen" allein ~95px) statt die volle Breite zu nutzen.
       Mit fester width: 320px wrappt der Text kontrolliert nach "5,0 Sterne",
       sodass "bei 25 Google-Bewertungen" in EINER Zeile bleibt. */
    width: 250px;
    box-sizing: border-box;
    white-space: normal;
    text-align: center;
    line-height: 1.25;
    flex-wrap: wrap;
    justify-content: center;
  }
  .reviews-hero__tab { width: 360px; height: 90px; }
}

/* Inner-Wrapper für Slides + Nav-Buttons */
.reviews-hero__inner {
  position: relative;
  max-width: 1400px;
  margin-inline: auto;
  padding-inline: clamp(4rem, 8vw, 6rem);
  text-align: center;
}

/* Track + Slides */
.reviews-hero__track {
  position: relative;
  /* Fixe Höhe damit das Carousel zwischen kurzen und langen Reviews nicht springt.
     Alle Slides liegen via grid-area: 1/1 übereinander und werden vertikal zentriert. */
  min-height: 520px;
  display: grid;
}
.reviews-hero__track > .review-slide {
  grid-area: 1 / 1;
}
@media (max-width: 720px) {
  .reviews-hero__track { min-height: 620px; }
}

.review-slide {
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.5s ease, transform 0.5s ease, visibility 0s linear 0.5s;
  pointer-events: none;
  /* Inhalt vertikal zentrieren — sonst kleben kurze Quotes oben und lange unten. */
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.review-slide.is-active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity 0.5s ease, transform 0.5s ease, visibility 0s;
  pointer-events: auto;
}

.review-slide__quote {
  font-family: var(--font-heading);
  /* Default = sehr kurze Quotes (<= 150 Zeichen). Modifier --md/--lg/--xl skalieren
     für längere Reviews runter, damit die Section-Höhe stabil bleibt. */
  font-size: clamp(1.625rem, 2.2vw + 0.6rem, 2.625rem);
  font-weight: 600;
  line-height: 1.2;
  color: #ffffff;
  letter-spacing: -0.015em;
  margin: 0 auto var(--space-2xl);
  max-width: 22ch;
  quotes: none;
}
.review-slide__quote::before,
.review-slide__quote::after { content: ""; }

/* Mittlere Länge (150–300 Zeichen) — z.B. Su Jui, Valon */
.review-slide--md .review-slide__quote {
  font-size: clamp(1.375rem, 1.6vw + 0.5rem, 2rem);
  line-height: 1.3;
  max-width: 34ch;
}
/* Lange Quotes (300–500 Zeichen) */
.review-slide--lg .review-slide__quote {
  font-size: clamp(1.125rem, 1vw + 0.5rem, 1.5rem);
  line-height: 1.45;
  max-width: 52ch;
  letter-spacing: -0.005em;
}
/* Sehr lange Quotes (>500 Zeichen) — z.B. Gjevat, Dominic.
   Body-Font sorgt für bessere Lesbarkeit über mehrere Zeilen. */
.review-slide--xl .review-slide__quote {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.7vw + 0.5rem, 1.25rem);
  font-weight: 500;
  line-height: 1.55;
  max-width: 64ch;
  letter-spacing: 0;
}

.review-slide__author {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
}
.review-slide__avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: cover;
  margin-bottom: 0.4rem;
  border: 2px solid rgba(255, 255, 255, 0.2);
}
.review-slide__name {
  font-family: var(--font-heading);
  font-weight: 600;
  color: #ffffff;
  font-size: 1.0625rem;
  margin: 0;
}
.review-slide__role {
  font-size: 0.9375rem;
  color: rgba(255, 255, 255, 0.7);
  margin: 0;
}

/* Nav-Arrows */
.reviews-hero__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.95);
  color: var(--color-primary-dark);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: background var(--transition), color var(--transition), transform var(--transition);
  z-index: 2;
}
.reviews-hero__nav:hover,
.reviews-hero__nav:focus-visible {
  background: var(--color-primary);
  color: #ffffff;
}
.reviews-hero__nav svg { width: 22px; height: 22px; }
.reviews-hero__nav--prev { left: clamp(0.5rem, 2vw, 1.5rem); }
.reviews-hero__nav--next {
  right: clamp(0.5rem, 2vw, 1.5rem);
  background: var(--color-primary);
  color: #ffffff;
}
.reviews-hero__nav--next:hover,
.reviews-hero__nav--next:focus-visible {
  background: var(--color-primary-hover);
  transform: translateY(-50%) scale(1.05);
}

@media (max-width: 540px) {
  .reviews-hero__nav { width: 44px; height: 44px; }
  .reviews-hero__nav svg { width: 18px; height: 18px; }
}

/* === Solution-Rows (3 alternierende Image+Text-Zeilen "Diese Probleme lösen wir") === */
.solution-rows {
  display: flex;
  flex-direction: column;
  gap: clamp(var(--space-2xl), 5vw, var(--space-3xl));
}

.solution-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(var(--space-xl), 4vw, var(--space-3xl));
  align-items: center;
}
/* Default (Row 1, 3): Text LINKS, Bild RECHTS */
.solution-row__body { order: 1; }
.solution-row__media { order: 2; }
/* Row 2 (even): Bild LINKS, Text RECHTS */
.solution-row:nth-child(even) .solution-row__body { order: 2; }
.solution-row:nth-child(even) .solution-row__media { order: 1; }

@media (max-width: 900px) {
  .solution-row { grid-template-columns: 1fr; gap: var(--space-lg); }
  /* Mobile: immer Bild zuerst (oben), Text unten */
  .solution-row__media,
  .solution-row:nth-child(even) .solution-row__media { order: 1; }
  .solution-row__body,
  .solution-row:nth-child(even) .solution-row__body { order: 2; }
}

/* Slide-In-Animation: jede Hälfte fadet rein und gleitet von ihrer Seite hinein */
.solution-row__body,
.solution-row__media {
  opacity: 0;
  transition: opacity 0.75s ease-out, transform 0.75s ease-out;
}
/* Default (Row 1, 3): Body von LINKS, Media von RECHTS */
.solution-row__body { transform: translateX(-50px); }
.solution-row__media { transform: translateX(50px); }
/* Row 2 (even): umgekehrt */
.solution-row:nth-child(even) .solution-row__body { transform: translateX(50px); }
.solution-row:nth-child(even) .solution-row__media { transform: translateX(-50px); }

.solution-row.is-visible .solution-row__body,
.solution-row.is-visible .solution-row__media {
  opacity: 1;
  transform: translateX(0);
}

@media (max-width: 900px) {
  /* Mobile: beide Hälften kommen von unten statt seitlich */
  .solution-row__body,
  .solution-row__media,
  .solution-row:nth-child(even) .solution-row__body,
  .solution-row:nth-child(even) .solution-row__media {
    transform: translateY(30px);
  }
  .solution-row.is-visible .solution-row__body,
  .solution-row.is-visible .solution-row__media {
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .solution-row__body,
  .solution-row__media {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

.solution-row__media {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  box-shadow: var(--shadow-md);
}
.solution-row__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
.solution-row:hover .solution-row__media img {
  transform: scale(1.03);
}
/* Annotation-Overlay: SVG liegt deckungsgleich auf dem Bild,
   ist nicht interaktiv und skaliert NICHT mit dem Hover-Zoom des Bildes. */
.solution-row__media--annotated .solution-row__annotations {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.solution-row__body {
  display: flex;
  flex-direction: column;
}

/* Riesige Outline-Zahl als visueller Anker (01 / 02 / 03) */
.solution-row__num {
  font-family: var(--font-heading);
  font-size: clamp(4rem, 7vw, 6rem);
  font-weight: 800;
  line-height: 0.9;
  color: transparent;
  -webkit-text-stroke: 1.5px var(--color-primary);
  letter-spacing: -0.04em;
  display: block;
  margin: 0 0 var(--space-sm);
}

/* Category-Eyebrow mit kurzem Strich davor */
.solution-row__category {
  font-family: var(--font-heading);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  gap: 0.7em;
  margin-bottom: var(--space-md);
}
.solution-row__category::before {
  content: "";
  width: 32px;
  height: 2px;
  background: var(--color-primary);
}

.solution-row__title {
  font-family: var(--font-heading);
  /* Deutlich größer — Display-Größe statt H3-Größe */
  font-size: clamp(2.75rem, 4.5vw + 0.5rem, 4.5rem);
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-xl);
  letter-spacing: -0.03em;
  line-height: 1.02;
}

.solution-row__list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-xl);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xs) var(--space-md);
}
@media (max-width: 540px) {
  .solution-row__list { grid-template-columns: 1fr; }
}
.solution-row__list li {
  position: relative;
  padding-inline-start: 1.2em;
  font-size: 1rem;
  color: var(--color-text);
  line-height: 1.5;
}
.solution-row__list li::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  top: 0.6em;
  width: 7px;
  height: 7px;
  background: var(--color-primary);
  border-radius: 50%;
}

.solution-row__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md) var(--space-xl);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border-soft);
}
.solution-row__cta {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  color: var(--color-primary);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  transition: color var(--transition);
}
.solution-row__cta::after {
  content: "→";
  transition: transform var(--transition);
  display: inline-block;
}
.solution-row__cta:hover {
  color: var(--color-primary-hover);
  text-decoration: none;
}
.solution-row__cta:hover::after {
  transform: translateX(3px);
}

/* === Reduced Motion === */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  html { scroll-behavior: auto; }
}

/* === Container-Variante: mittel (für Detail-Seiten wie Referenz-Detail) === */
.container--narrow {
  max-width: 1200px;
}
/* Innerhalb von --narrow: Lese-Container für reine Text-Sections */
.container--reading {
  max-width: 75ch;
  margin-inline: auto;
}

/* === Reference-Grid: "Alle Referenzen" CTA-Block unter dem Grid === */
.reference-grid__more {
  margin-top: var(--space-2xl);
  margin-bottom: clamp(2rem, 5vw, 4rem);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
}
.reference-grid__more-text {
  margin: 0;
  max-width: 50ch;
  color: var(--color-text-muted);
  font-size: 1rem;
}

/* === Reference-Detail-Page === */
.reference-detail__back {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  text-decoration: none;
  margin-bottom: var(--space-lg);
  padding: 0.4rem 0.75rem 0.4rem 0.5rem;
  border-radius: var(--radius-pill);
  transition: color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}
.reference-detail__back:hover {
  color: var(--color-primary);
  background: var(--color-bg-soft);
  transform: translateX(-2px);
  text-decoration: none;
}
.reference-detail__head {
  padding-top: var(--space-2xl);
  padding-bottom: var(--space-lg);
  text-align: center;
}
.reference-detail__head .reference-detail__back {
  /* Back-Link linksbündig, Header-Inhalt mittig */
  align-self: flex-start;
  margin-right: auto;
  text-align: left;
}
.reference-detail__head > .container--narrow {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.reference-detail__head > .container--narrow > * {
  align-self: center;
}
.reference-detail__head > .container--narrow > .reference-detail__back {
  align-self: flex-start;
}

/* === "Alle Referenzen ansehen"-Block nach Galerie === */
.reference-detail__more {
  padding-top: 0;
  padding-bottom: var(--space-2xl);
}
.reference-detail__more-inner {
  text-align: center;
  padding: var(--space-xl) 0;
  border-top: 1px solid var(--color-border-soft);
}
.reference-detail__date {
  font-size: 0.875rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0 0 var(--space-sm);
}
.reference-detail__title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4vw + 0.5rem, 3rem);
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0;
  line-height: 1.15;
}
.reference-detail__cover {
  margin: var(--space-lg) 0 var(--space-2xl);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  background: var(--color-bg-soft);
}
.reference-detail__cover img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
/* Modifier für Device-Mockups: komplettes Bild zeigen statt beschneiden. */
.reference-detail__cover--contain img {
  object-fit: contain;
  padding: var(--space-lg);
}
.reference-detail__content {
  padding-top: var(--space-md);
  padding-bottom: var(--space-2xl);
}
.reference-detail__content-inner {
  max-width: 75ch;
  margin-inline: auto;
}
.reference-detail__category-label {
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
  font-weight: 600;
  margin: 0 0 var(--space-sm);
}
.reference-detail__subtitle {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 2vw + 0.5rem, 2rem);
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-lg);
  line-height: 1.25;
}
.reference-detail__body {
  font-size: 1.0625rem;
  line-height: 1.75;
  color: var(--color-text);
}
.reference-detail__body p {
  margin: 0 0 var(--space-md);
}
.reference-detail__body h3 {
  font-family: var(--font-heading);
  font-size: 1.375rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: var(--space-xl) 0 var(--space-sm);
  line-height: 1.3;
}
.reference-detail__body strong {
  color: var(--color-primary-dark);
  font-weight: 600;
}
.reference-detail__body ul {
  margin: 0 0 var(--space-md);
  padding-left: 1.25rem;
}
.reference-detail__body ul li {
  margin-bottom: var(--space-2xs);
}
.reference-detail__external {
  margin: var(--space-xl) 0 0;
  font-size: 0.9375rem;
}
.reference-detail__external a {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  color: var(--color-primary);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
}
.reference-detail__external a:hover {
  color: var(--color-primary-hover);
}

/* === Gallery (3 Spalten, klickbar als Lightbox-Trigger) === */
.reference-detail__gallery-section {
  padding-top: 0;
  padding-bottom: var(--space-2xl);
}
.reference-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}
@media (max-width: 768px) {
  .reference-gallery { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .reference-gallery { grid-template-columns: 1fr; }
}
.reference-gallery__item {
  margin: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-bg-soft);
  aspect-ratio: 4 / 3;
  box-shadow: var(--shadow-sm);
}
.reference-gallery__item a {
  display: block;
  width: 100%;
  height: 100%;
}
.reference-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.reference-gallery__item:hover img {
  transform: scale(1.04);
}

/* === CTA-Banner (am Ende der Detailseite, heller Live-Stil) === */
.cta-banner {
  background: var(--color-bg-soft);
  padding: clamp(var(--space-2xl), 6vw, var(--space-3xl)) 0;
  border-top: 1px solid var(--color-border-soft);
}
.cta-banner__inner {
  text-align: center;
}
.cta-banner__title {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 2.5vw + 0.5rem, 2.25rem);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-md);
  line-height: 1.25;
}
.cta-banner__text {
  font-size: 1.0625rem;
  color: var(--color-text-muted);
  max-width: 56ch;
  margin: 0 auto var(--space-2xl);
  line-height: 1.7;
}
.cta-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(var(--space-md), 3vw, var(--space-2xl));
  justify-content: center;
  align-items: center;
  margin-bottom: var(--space-xl);
}
.cta-banner__action {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  color: var(--color-primary-dark);
  text-decoration: none;
  font-weight: 600;
  font-size: 1.0625rem;
  transition: color 0.2s ease;
}
.cta-banner__action:hover {
  color: var(--color-primary);
  text-decoration: none;
}
.cta-banner__action-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #fff;
  color: var(--color-primary);
  border: 1px solid var(--color-border-soft);
  box-shadow: var(--shadow-sm);
  flex-shrink: 0;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.cta-banner__action:hover .cta-banner__action-icon {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}
.cta-banner__action-label {
  letter-spacing: 0.01em;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.cta-banner__social {
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
}
.cta-banner__social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fff;
  color: var(--color-primary);
  border: 1px solid var(--color-border-soft);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.cta-banner__social a:hover {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
  transform: translateY(-2px);
}
@media (max-width: 560px) {
  .cta-banner__actions {
    flex-direction: column;
    gap: var(--space-md);
  }
}

/* === Lightbox (Galerie-Popup) === */
.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0, 41, 75, 0.94);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  padding: clamp(1rem, 4vw, 3rem);
}
.lightbox.is-open {
  display: flex;
  animation: lightbox-fade 0.2s ease-out;
}
@keyframes lightbox-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}
.lightbox__stage {
  position: relative;
  max-width: min(90vw, 1400px);
  max-height: 88vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lightbox__img {
  max-width: 100%;
  max-height: 88vh;
  width: auto;
  height: auto;
  display: block;
  border-radius: var(--radius-md);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5);
  background: #1a1a1a;
}
.lightbox__counter {
  position: absolute;
  bottom: -2.25rem;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  font-variant-numeric: tabular-nums;
  pointer-events: none;
}
.lightbox__close,
.lightbox__prev,
.lightbox__next {
  position: absolute;
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.25);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  padding: 0;
  z-index: 10;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: background 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
}
.lightbox__close:hover,
.lightbox__prev:hover,
.lightbox__next:hover {
  background: rgba(0, 0, 0, 0.75);
  border-color: rgba(255, 255, 255, 0.5);
}
.lightbox__close {
  top: 1.25rem;
  right: 1.25rem;
  width: 48px;
  height: 48px;
}
.lightbox__prev,
.lightbox__next {
  top: 50%;
  width: 56px;
  height: 56px;
  margin-top: -28px;
}
.lightbox__prev { left: 1.25rem; }
.lightbox__next { right: 1.25rem; }
.lightbox.is-single .lightbox__prev,
.lightbox.is-single .lightbox__next,
.lightbox.is-single .lightbox__counter { display: none; }

@media (max-width: 640px) {
  .lightbox { padding: 0.5rem; }
  .lightbox__stage { max-width: 100vw; max-height: 80vh; }
  .lightbox__img { max-height: 80vh; }
  .lightbox__prev { left: 0.5rem; width: 44px; height: 44px; margin-top: -22px; }
  .lightbox__next { right: 0.5rem; width: 44px; height: 44px; margin-top: -22px; }
  .lightbox__close { top: 0.75rem; right: 0.75rem; width: 40px; height: 40px; }
  .lightbox__counter { bottom: -1.75rem; font-size: 0.8125rem; }
}

/* === Kontaktseite: Hero im Live-Stil (CAPS-Title) === */
.contact-hero {
  padding-block: clamp(4rem, 8vw, 6rem) clamp(2rem, 4vw, 3rem);
  text-align: center;
}
.contact-hero__inner {
  max-width: 820px;
  margin-inline: auto;
}
.contact-hero__title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4vw + 0.5rem, 3.25rem);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--color-primary-dark);
  line-height: 1.2;
  margin: var(--space-sm) 0 var(--space-md);
}
.contact-hero__lead {
  font-size: 1.125rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  max-width: 60ch;
  margin-inline: auto;
}

/* === Kontaktseite: 2-Spalten-Layout Maps + Formular === */
.contact-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  align-items: stretch;
}
.contact-split__map,
.contact-split__form {
  display: flex;
  flex-direction: column;
}
.contact-split__map .maps-consent {
  flex: 1 1 auto;
  min-height: 100%;
}
.contact-split__form .contact-form-card {
  flex: 1 1 auto;
  height: 100%;
}
@media (max-width: 960px) {
  .contact-split {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
  }
  .contact-split__map .maps-consent { min-height: 360px; }
}

/* === Google-Maps-Consent (Click-to-Load) === */
.maps-consent {
  position: relative;
  width: 100%;
  min-height: 450px;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.maps-consent.is-loaded {
  background: transparent;
  border-color: transparent;
  padding: 0;
}
.maps-consent__placeholder {
  max-width: 520px;
  padding: var(--space-2xl) var(--space-xl);
  text-align: center;
}
.maps-consent__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: #fff;
  color: var(--color-primary);
  border: 1px solid var(--color-border-soft);
  margin-bottom: var(--space-md);
  box-shadow: var(--shadow-sm);
}
.maps-consent__title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-sm);
}
.maps-consent__text {
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  margin: 0 0 var(--space-lg);
}
.maps-consent__alt {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  margin: var(--space-md) 0 0;
}
.maps-consent iframe {
  width: 100%;
  height: 100%;
  min-height: 450px;
  border: 0;
  display: block;
}
@media (max-width: 640px) {
  .maps-consent { min-height: 360px; }
  .maps-consent iframe { min-height: 360px; }
}

/* ===========================================================
   Service-Page-Komponenten (geteilt von /webdesign/, /smart-home/, /seo/ …)
   =========================================================== */

/* --- Schmaler Quote-Strip mit Lead-Spruch (.service-intro) ---
   Reviews-Pille wurde entfernt (Redundanz zum Hero-Stats-Block). Statt
   Trust-Bar fungiert der Lead-Text jetzt als Zitat-/Spruch-Element.
   Specificity-Override gegen `.hero + .section { padding-top: 8-12rem }`. */
.section--quote,
.hero + .section.section--quote,
.hero + section.section--quote {
  padding-block: clamp(var(--space-sm), 1.5vw, var(--space-md));
}
.service-intro {
  text-align: center;
  max-width: 85ch;
  margin: 0 auto;
}
.service-intro__lead {
  font-size: clamp(1.0625rem, 0.7vw + 0.85rem, 1.375rem);
  line-height: 1.55;
  color: var(--color-text-muted);
  margin: 0;
  font-style: italic;
  quotes: "„" """ "‚" "'";
}
.service-intro__lead::before { content: open-quote; color: var(--color-primary); font-style: normal; font-weight: 700; margin-right: 0.1em; }
.service-intro__lead::after  { content: close-quote; color: var(--color-primary); font-style: normal; font-weight: 700; margin-left: 0.1em; }

/* === Pain-Stage: Pinned section with scroll-driven slide switching ===
   Layout: Wrapper ist N * 100vh hoch (N = 4 Slides), .pain-stage__sticky
   bleibt für die Scroll-Distanz am Bildschirm kleben. JS aktualisiert
   .is-active je nach Scroll-Position. BG- und Textfarbe morphen via CSS-Vars. */
.pain-stage {
  position: relative;
  /* 4 Slides * 100vh Scroll-Distanz = 400vh — jeder Slide bekommt einen
     vollen Viewport Scroll-Distanz, damit auch schnelle Scroller nicht
     versehentlich 2 Slides auf einmal überspringen. */
  height: 400vh;
  background-color: var(--pain-bg, #ffffff);
  color: var(--pain-text, #00294b);
  transition:
    background-color 0.7s cubic-bezier(0.4, 0, 0.2, 1),
    color 0.5s ease;
  /* KEIN overflow: hidden hier — würde position: sticky am Kind brechen,
     weil der Sticky-Anker dann auf diesen Container statt auf den
     Viewport fixiert wird. Clipping passiert stattdessen auf __sticky. */
}
.pain-stage__sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;  /* Clipping für Slide-Eintritts-Translation */
}
.pain-stage__inner {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  padding-top: clamp(4rem, 7vw, 6rem);
  padding-bottom: clamp(6rem, 10vh, 8rem);
}
.pain-stage__head {
  flex-shrink: 0;
  text-align: center;
  max-width: 60ch;
  margin-inline: auto;
}
.pain-stage__head h2 {
  color: inherit;
  margin: var(--space-sm) 0 0;
  font-size: clamp(1.75rem, 2.5vw + 0.5rem, 2.75rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.pain-stage__head .eyebrow--light,
.pain-stage__head .eyebrow {
  color: inherit;
  opacity: 0.65;
}

/* Slides-Container: nimmt Restplatz, .position:relative für absolute Kinder */
.pain-stage__slides {
  position: relative;
  flex: 1;
  min-height: 0;
}
.pain-stage__slide {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  opacity: 0;
  visibility: hidden;
  transform: translate(60px, 60px) scale(0.96);
  transition:
    opacity 0.55s ease,
    transform 0.7s cubic-bezier(0.16, 1, 0.3, 1),
    visibility 0s linear 0.55s;
  pointer-events: none;
}
.pain-stage__slide.is-active {
  opacity: 1;
  visibility: visible;
  transform: translate(0, 0) scale(1);
  transition:
    opacity 0.55s ease,
    transform 0.7s cubic-bezier(0.16, 1, 0.3, 1),
    visibility 0s;
  pointer-events: auto;
}

.pain-stage__visual {
  display: grid;
  place-items: center;
  height: 100%;
  max-height: clamp(260px, 42vh, 440px);
}
.pain-stage__visual img {
  width: 100%;
  height: 100%;
  max-width: 440px;
  object-fit: contain;
  filter: drop-shadow(0 30px 60px rgba(0, 0, 0, 0.25));
}

.pain-stage__copy {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.pain-stage__num {
  font-family: var(--font-heading);
  font-size: clamp(4rem, 8vw + 1rem, 9rem);
  font-weight: 900;
  line-height: 0.85;
  color: inherit;
  opacity: 0.16;
  letter-spacing: -0.05em;
  margin: 0;
}
.pain-stage__title {
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 2vw + 0.75rem, 2.5rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: inherit;
  margin: 0;
}
.pain-stage__text {
  font-size: clamp(1rem, 0.5vw + 0.85rem, 1.125rem);
  line-height: 1.65;
  color: inherit;
  opacity: 0.82;
  max-width: 52ch;
  margin: 0;
}
.pain-stage__text strong {
  opacity: 1;
  font-weight: 700;
}

/* Nav-Dots am unteren Rand — absolut positioniert, damit lange Slide-Texte
   nicht in die Dot-Zone laufen koennen. Reservezone via padding-bottom auf __inner. */
.pain-stage__nav {
  position: absolute;
  bottom: clamp(1.5rem, 3vh, 3rem);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
  z-index: 2;
}
.pain-stage__dot {
  appearance: none;
  border: 1px solid currentColor;
  background: transparent;
  color: inherit;
  font-family: var(--font-heading);
  font-size: 0.875rem;
  font-weight: 700;
  padding: 0.55em 1.2em;
  border-radius: 999px;
  cursor: pointer;
  transition: background-color 0.3s, color 0.3s, border-color 0.3s, opacity 0.3s;
  letter-spacing: 0.05em;
  opacity: 0.45;
}
.pain-stage__dot:hover {
  opacity: 0.85;
}
.pain-stage__dot.is-active {
  background: var(--pain-text, #00294b);
  color: var(--pain-bg, #ffffff);
  border-color: var(--pain-text, #00294b);
  opacity: 1;
}

/* ===== Mobile + reduced-motion Fallback ===== */
@media (max-width: 900px), (prefers-reduced-motion: reduce) {
  .pain-stage {
    height: auto;
    background-color: var(--color-bg);
    color: var(--color-text);
    overflow: visible;
  }
  .pain-stage__sticky {
    position: static;
    height: auto;
    padding-block: clamp(3rem, 8vw, 5rem);
  }
  .pain-stage__inner {
    grid-template-rows: none;
    height: auto;
  }
  .pain-stage__head h2,
  .pain-stage__head .eyebrow--light {
    color: var(--color-primary-dark);
  }
  .pain-stage__head .eyebrow--light {
    color: var(--color-primary);
    opacity: 1;
  }
  .pain-stage__slides {
    display: flex;
    flex-direction: column;
    gap: var(--space-xl);
  }
  .pain-stage__slide {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    pointer-events: auto;
    background: var(--slide-bg, var(--color-primary-dark));
    color: var(--slide-text, #ffffff);
    border: 1px solid var(--color-border-soft);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    grid-template-columns: 1fr;
    gap: var(--space-lg);
  }
  /* Brand-Farbpalette (gleiche wie Desktop-Scroll-Stages):
     Slide 1 = weiß mit dunklem Text, Slides 2-4 = Blau-Töne mit weißem Text. */
  .pain-stage__slide:nth-child(1) { --slide-bg: #ffffff; --slide-text: #00294b; }
  .pain-stage__slide:nth-child(2) { --slide-bg: #0089f7; --slide-text: #ffffff; }
  .pain-stage__slide:nth-child(3) { --slide-bg: #006edf; --slide-text: #ffffff; }
  .pain-stage__slide:nth-child(4) { --slide-bg: #00294b; --slide-text: #ffffff; }

  .pain-stage__visual { max-height: 260px; }
  .pain-stage__visual img { max-width: 320px; }
  .pain-stage__title,
  .pain-stage__text,
  .pain-stage__num { color: inherit; }
  .pain-stage__nav { display: none; }
}

/* --- USP-Grid (4 Karten mit Icon) --- */
.usp-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}
@media (max-width: 1100px) { .usp-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .usp-grid { grid-template-columns: 1fr; } }
.usp-card {
  padding: var(--space-lg);
  border-radius: var(--radius-lg);
  background: #ffffff;
  border: 1px solid var(--color-border-soft);
  box-shadow: var(--shadow-sm);
}
.usp-card__icon {
  display: inline-grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: var(--color-bg-tint);
  color: var(--color-primary);
  margin-bottom: var(--space-md);
}
.usp-card__icon svg { width: 26px; height: 26px; }
.usp-card__title {
  font-family: var(--font-heading);
  font-size: 1.1875rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-sm);
}
.usp-card__text {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--color-text-muted);
  margin: 0;
}

/* --- Service-Grid (3-Spalten Leistungs-Items) --- */
.service-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}
@media (max-width: 1000px) { .service-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .service-grid { grid-template-columns: 1fr; } }
.service-grid__item {
  padding: var(--space-md) 0;
}
.service-grid__icon {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--color-bg-tint);
  color: var(--color-primary);
  margin-bottom: var(--space-sm);
}
.service-grid__icon svg { width: 22px; height: 22px; }
.service-grid__title {
  font-family: var(--font-heading);
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0 0 0.4rem;
}
.service-grid__text {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--color-text-muted);
  margin: 0;
}

/* --- Feature-Marquee (3 auto-scrolling columns + SEO copy) --- */
.feature-marquee-section {
  overflow: hidden;
  background: var(--color-primary-dark);
  background-image:
    radial-gradient(60% 60% at 20% 20%, rgba(0, 137, 247, 0.18), transparent 70%),
    radial-gradient(50% 60% at 90% 80%, rgba(0, 110, 223, 0.12), transparent 70%);
  color: #ffffff;
}

.feature-marquee {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: clamp(var(--space-xl), 5vw, var(--space-2xl));
  align-items: center;
}

.feature-marquee__cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  height: clamp(560px, 70vh, 720px);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 14%, #000 86%, transparent 100%);
          mask-image: linear-gradient(to bottom, transparent 0%, #000 14%, #000 86%, transparent 100%);
}

.feature-marquee__col {
  overflow: hidden;
  position: relative;
}

.feature-marquee__track {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  will-change: transform;
}

.feature-marquee__col--down .feature-marquee__track {
  animation: featureScrollDown 42s linear infinite;
}
.feature-marquee__col--up .feature-marquee__track {
  animation: featureScrollUp 38s linear infinite;
}
.feature-marquee__col:nth-child(3) .feature-marquee__track {
  animation-duration: 46s;
}

.feature-marquee__cols:hover .feature-marquee__track {
  animation-play-state: paused;
}

@keyframes featureScrollUp {
  from { transform: translateY(0); }
  to   { transform: translateY(-50%); }
}
@keyframes featureScrollDown {
  from { transform: translateY(-50%); }
  to   { transform: translateY(0); }
}

.feature-marquee__copy {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  min-height: clamp(420px, 60vh, 620px);
  display: flex;
  align-items: center;
  isolation: isolate;
}
.feature-marquee__copy-media {
  position: absolute;
  inset: 0;
  z-index: -2;
}
.feature-marquee__copy-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.feature-marquee__copy::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(125deg, rgba(0, 41, 75, 0.92) 0%, rgba(0, 41, 75, 0.78) 45%, rgba(0, 41, 75, 0.55) 100%),
    linear-gradient(to top, rgba(0, 41, 75, 0.6), transparent 60%);
}
.feature-marquee__copy-inner {
  padding: clamp(var(--space-xl), 4vw, var(--space-2xl));
  max-width: 36rem;
  color: #ffffff;
}
.feature-marquee__title {
  font-family: var(--font-heading);
  font-size: clamp(2.25rem, 5vw, 4rem);
  line-height: 1.04;
  letter-spacing: -0.025em;
  color: #ffffff;
  margin: 0.75rem 0 1.25rem;
}
.feature-marquee__lead {
  font-size: 1.0625rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
  margin: 0 0 1.75rem;
  max-width: 32em;
}
.feature-marquee__copy .button--primary {
  background: #ffffff;
  color: var(--color-primary);
  font-weight: 700;
}
.feature-marquee__copy .button--primary:hover,
.feature-marquee__copy .button--primary:focus {
  background: var(--color-bg-tint);
  color: var(--color-primary-dark);
  transform: translateY(-2px);
}

/* Card im Marquee + Mobile-Grid */
.feature-card {
  background: #ffffff;
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  box-shadow: 0 2px 10px rgba(20, 38, 78, 0.04);
  list-style: none;
}
.feature-card__icon {
  display: inline-grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--color-bg-tint);
  color: var(--color-primary);
  margin-bottom: 0.25rem;
}
.feature-card__icon svg { width: 20px; height: 20px; }
.feature-card__title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0;
}
.feature-card__text {
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--color-text-muted);
  margin: 0;
}

/* Mobile-Fallback-Grid */
.feature-marquee__mobile {
  display: none;
  list-style: none;
  padding: 0;
  margin: 0;
}

@media (max-width: 960px) {
  .feature-marquee { grid-template-columns: 1fr; gap: var(--space-xl); }
  .feature-marquee__copy { max-width: none; }
  .feature-marquee__cols { display: none; }
  .feature-marquee__mobile {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
  }
}
@media (max-width: 560px) {
  .feature-marquee__mobile { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .feature-marquee__cols { display: none; }
  .feature-marquee__mobile {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
  }
}

/* --- Tech-Stack vs. Anti-Stack Split --- */
.tech-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
}
@media (max-width: 900px) { .tech-split { grid-template-columns: 1fr; } }
.tech-split__col {
  padding: var(--space-xl);
  border-radius: var(--radius-lg);
  background: #ffffff;
  border: 1px solid var(--color-border-soft);
}
.tech-split__col--use   { border-top: 4px solid var(--color-success); }
.tech-split__col--avoid { border-top: 4px solid var(--color-danger); }
.tech-split__title {
  display: flex;
  align-items: center;
  gap: 0.55em;
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-md);
}
.tech-split__icon {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-success);
  color: #ffffff;
  flex-shrink: 0;
}
.tech-split__icon--avoid { background: var(--color-danger); }
.tech-split__icon svg { width: 16px; height: 16px; }
.tech-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.tech-list li {
  padding-left: 1.5em;
  position: relative;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--color-text-muted);
}
.tech-list li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-weight: 700;
}
.tech-list li strong { color: var(--color-text); font-weight: 600; }

/* --- Section-Head linksbündig (für Local-SEO Section) --- */
.section__head--left { text-align: left; max-width: none; }
.section__head--left .eyebrow,
.section__head--left h2 { text-align: left; }

/* --- Local-SEO-Sektion --- */
.local-seo__intro {
  max-width: 80ch;
  margin-bottom: var(--space-2xl);
}
.local-seo__intro p {
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--color-text-muted);
  margin: 0 0 var(--space-md);
}
.local-seo__intro strong { color: var(--color-text); }

.local-seo__measures-title,
.local-seo__areas-title {
  font-family: var(--font-heading);
  font-size: clamp(1.25rem, 1vw + 0.75rem, 1.5rem);
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-lg);
}

.local-seo__measures-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}
@media (max-width: 1000px) { .local-seo__measures-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .local-seo__measures-grid { grid-template-columns: 1fr; } }
.local-seo__measure {
  padding: var(--space-lg);
  border-left: 3px solid var(--color-primary);
  background: var(--color-bg-tint);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.local-seo__measure h4 {
  font-family: var(--font-heading);
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-xs);
}
.local-seo__measure p {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--color-text-muted);
  margin: 0;
}
.local-seo__measure code {
  background: rgba(0, 137, 247, 0.1);
  color: var(--color-primary-dark);
  padding: 0.1em 0.4em;
  border-radius: 4px;
  font-family: ui-monospace, Consolas, monospace;
  font-size: 0.875em;
}

.local-seo__areas-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-sm) var(--space-lg);
  font-size: 0.9375rem;
  color: var(--color-text-muted);
}
.local-seo__areas-list li {
  padding-left: 1.5em;
  position: relative;
  line-height: 1.6;
}
.local-seo__areas-list li::before {
  content: "📍";
  position: absolute;
  left: 0;
  font-size: 0.875em;
}
.local-seo__areas-list strong { color: var(--color-text); font-weight: 600; }

/* --- Hero Stats-Bar (Variante C, z.B. auf /webdesign/) ---
   .hero--stats Modifier reserviert unten Platz für die absolute positionierte
   Stats-Leiste. Glas-Effekt mit backdrop-filter, dezenter Border oben. */
.hero--stats {
  padding-bottom: clamp(8rem, 12vw, 10rem);
}
@media (max-width: 720px) {
  .hero--stats { padding-bottom: 11rem; }
}
.hero__stats {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1;
  background: rgba(0, 14, 28, 0.55);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-top: 1px solid rgba(255, 255, 255, 0.14);
  padding-block: clamp(1rem, 1.5vw + 0.5rem, 1.5rem);
}
.hero__stats-inner {
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: var(--container-pad);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
  text-align: center;
}
.hero__stat-num {
  display: block;
  font-family: var(--font-heading);
  font-size: clamp(1.375rem, 1.6vw + 0.5rem, 2rem);
  font-weight: 800;
  color: #ffffff;
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.hero__stat-star {
  color: #ffd34a;
  font-size: 0.85em;
  margin-left: 0.15em;
}
.hero__stat-label {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.8125rem;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.35;
}
@media (max-width: 720px) {
  .hero__stats-inner {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm) var(--space-md);
  }
  .hero__stat-num { font-size: 1.25rem; }
  .hero__stat-label { font-size: 0.75rem; }
}

/* --- Hero Pierce-Variante (NewBorn als Display-Wortmarke, Foto piercet H1) ---
   Hintergrund pitch-black, damit das MacBook-Foto (ebenfalls auf Schwarz)
   nahtlos in die Section verschmilzt — kein Freistellen nötig. */
.hero--pierce {
  background: #000;
  text-align: center;
  /* Hero-Default-min-height 60vh + justify-center druecken Content runter.
     Pierce-Variante soll oben kleben, daher Override. */
  justify-content: flex-start;
  min-height: auto;
  padding-block: clamp(7rem, 11vw, 9rem) clamp(2rem, 4vw, 3rem);
}
.hero--pierce .hero__container {
  text-align: center;
}
.hero--pierce .hero__cta {
  justify-content: center;
}

.hero__stage {
  position: relative;
  display: grid;
  place-items: center;
  margin-block: clamp(0.5rem, 1vw, 1.25rem) clamp(0.75rem, 1.5vw, 1.5rem);
  min-height: clamp(260px, 36vw, 560px);
}
.hero__brand {
  position: relative;
  z-index: 1;
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  color: #ffffff;
  font-size: clamp(4.5rem, 17vw, 13rem);
  letter-spacing: -0.045em;
  line-height: 0.95;
  text-align: center;
  white-space: nowrap;
  user-select: none;
}
.hero__pierce-img {
  position: absolute;
  z-index: 2;
  top: 50%;
  left: 50%;
  width: clamp(440px, 58vw, 920px);
  height: auto;
  /* Foto ist Portrait, Laptop sitzt im unteren Drittel. Mit -50% wird
     Foto-Mitte auf Stage-Mitte gelegt, mit weiterem Pull-Up sitzt die
     Bildschirm-Oberkante auf der Hoehe der Wortmarke und piercet sie. */
  transform: translate(-50%, -62%);
  pointer-events: none;
  user-select: none;
  /* Foto-Hintergrund ist near-black, hat aber leichte Tonal-Abweichung gegenueber
     dem Hero-#000. Radial-Mask blendet die Raender weich aus, sodass kein
     sichtbares Rechteck mehr stehen bleibt. */
  -webkit-mask-image: radial-gradient(ellipse 58% 52% at 50% 68%, #000 48%, transparent 95%);
          mask-image: radial-gradient(ellipse 58% 52% at 50% 68%, #000 48%, transparent 95%);
}
.hero--pierce .hero__container h1,
.hero--pierce .hero__container .hero__h1 {
  font-size: clamp(1rem, 1vw + 0.6rem, 1.375rem);
  font-weight: 500;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.92);
  max-width: 52ch;
  margin: 0 auto clamp(1.25rem, 2vw, 1.75rem);
  letter-spacing: 0;
  text-transform: none;
  text-align: center;
}
@media (max-width: 720px) {
  .hero--pierce { padding-block: 7rem 1.5rem; }
  .hero__brand { font-size: clamp(3rem, 18vw, 6rem); }
  .hero__pierce-img { width: 95vw; transform: translate(-50%, -55%); }
  .hero__stage { min-height: clamp(220px, 55vw, 360px); }
}

/* === Dark-Hero Override fuer Pages mit Pierce-Hero (aktuell nur Home) ===
   Standard-Overlay-Header laesst die weisse Pille stehen. Auf der Pierce-Variante
   wollen wir komplett transparent + weisse Schrift, solange nicht gescrollt. */
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav {
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__link,
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__call,
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__call-label,
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__call-number,
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__caret,
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__brand-text {
  color: #ffffff;
}
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__link:hover,
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__link:focus,
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__call-number:hover {
  color: var(--color-primary);
}
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__link.is-active {
  color: #ffffff;
}
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__link.is-active::after {
  background: #ffffff;
}
.page--home .site-header.is-overlay:not(.is-scrolled) .site-nav__toggle span {
  background: #ffffff;
}

/* --- Tech-Stack Vergleichs-Illustration --- */
.tech-illustration {
  margin: 0 auto var(--space-2xl);
  max-width: 880px;
}
.tech-illustration img {
  width: 100%;
  height: auto;
  display: block;
}

/* --- Local-SEO Map + Local-Pack Mockup (2-Spalten nebeneinander, mobile gestackt) --- */
.local-seo__visuals {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}
@media (max-width: 900px) {
  .local-seo__visuals { grid-template-columns: 1fr; }
}
.local-seo__map,
.local-seo__pack {
  margin: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #ffffff;
  border: 1px solid var(--color-border-soft);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
}
.local-seo__map > img,
.local-seo__pack > img {
  flex: 1;
}
.local-seo__map img,
.local-seo__pack img {
  width: 100%;
  height: auto;
  display: block;
}
.local-seo__map-caption,
.local-seo__pack-caption {
  padding: var(--space-sm) var(--space-md);
  font-size: 0.875rem;
  color: var(--color-text-muted);
  text-align: center;
  border-top: 1px solid var(--color-border-soft);
  background: var(--color-bg);
}

/* ===========================================================
   1920px+ Breakpoint — Skalierung für 2K/4K-Displays.
   Hero-Typografie, Stats-Bar und Hero-Höhe wachsen mit, damit Content
   nicht winzig in der Mitte schwebt und der vertikale Whitespace
   nicht ausufert.
   =========================================================== */
@media (min-width: 1920px) {
  /* Hero-Höhe kappen, damit auf 4K nicht 60vh = ~1300px leer bleibt */
  .hero {
    min-height: min(60vh, 900px);
  }

  /* H1 wächst weiter — clamp-Maximum hochziehen */
  .hero h1,
  .hero__container h1 {
    font-size: clamp(4.5rem, 4vw + 1rem, 7rem);
    max-width: 16ch;
  }
  .hero--split .hero__container h1 {
    font-size: clamp(4rem, 3.5vw + 1rem, 6rem);
    max-width: 16ch;
  }

  /* Lead-Text spürbar größer */
  .hero .hero__lead,
  .hero__container .hero__lead,
  .hero__lead {
    font-size: clamp(1.375rem, 0.9vw + 0.6rem, 1.75rem);
    max-width: 45ch;
  }

  /* Eyebrow etwas voluminöser */
  .eyebrow,
  .eyebrow--light {
    font-size: 1rem;
    letter-spacing: 0.18em;
  }

  /* CTAs leicht größer */
  .hero .button {
    font-size: 1.0625rem;
    padding-block: 0.95rem;
    padding-inline: 1.75rem;
  }

  /* Stats-Bar Zahlen + Labels mitwachsen lassen */
  .hero__stat-num {
    font-size: clamp(2rem, 1.4vw + 0.8rem, 2.75rem);
  }
  .hero__stat-label {
    font-size: 0.9375rem;
  }
  .hero__stats {
    padding-block: clamp(1.25rem, 1vw + 0.5rem, 1.875rem);
  }
}

/* ===========================================================
   yourseo.app-Spotlight (SEO-Pillar-Page)
   2-Spalten: links Device-Mockup-Bild, rechts Copy + Feature-Liste + CTAs.
   =========================================================== */
.yourseo-spotlight__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
  gap: clamp(var(--space-xl), 3vw, var(--space-2xl));
  align-items: center;
}
@media (max-width: 900px) {
  .yourseo-spotlight__grid { grid-template-columns: 1fr; }
}
.yourseo-spotlight__media,
.yourseo-spotlight__copy {
  min-width: 0;
}
.yourseo-spotlight__media {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: linear-gradient(135deg, #f1f5fb 0%, #e5edf6 100%);
  border: 1px solid var(--color-border-soft);
  box-shadow: var(--shadow-md);
}
.yourseo-spotlight__media a {
  display: block;
  line-height: 0;
}
.yourseo-spotlight__media img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.4s cubic-bezier(0.2, 0.65, 0.3, 1);
}
.yourseo-spotlight__media a:hover img {
  transform: scale(1.02);
}
.yourseo-spotlight__copy h2 {
  margin-top: 0.25em;
  margin-bottom: 0.6em;
}
.yourseo-spotlight__copy .lead {
  color: var(--color-text-muted);
  margin-bottom: var(--space-lg);
}
.yourseo-spotlight__copy a:not(.button) {
  color: var(--color-primary);
  text-decoration: none;
}
.yourseo-spotlight__copy a:not(.button):hover {
  text-decoration: underline;
}
.yourseo-spotlight__features {
  list-style: none;
  margin: 0 0 var(--space-xl) 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.yourseo-spotlight__features li {
  display: flex;
  align-items: flex-start;
  gap: 0.85em;
  line-height: 1.55;
  font-size: 1rem;
  color: var(--color-text);
}
.yourseo-spotlight__feature-icon {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: rgba(0, 137, 247, 0.12);
  color: var(--color-primary);
  flex: 0 0 28px;
}
.yourseo-spotlight__feature-icon svg {
  width: 16px;
  height: 16px;
  stroke-width: 2.5;
}
.yourseo-spotlight__feature-text {
  flex: 1;
  min-width: 0;
}
.yourseo-spotlight__feature-text strong {
  color: var(--color-text);
  font-weight: 700;
}
.yourseo-spotlight__cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

/* ===========================================================
   Leistungen-Hub-Page (/leistungen/)
   2x2 Grid von grossen Service-Cards mit Icon, Lead, Bullets, CTA.
   =========================================================== */
.leistungen-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-lg);
}
@media (max-width: 900px) { .leistungen-grid { grid-template-columns: 1fr; } }
.leistungen-card {
  padding: clamp(var(--space-lg), 2vw, var(--space-xl));
  border-radius: var(--radius-lg);
  background: #ffffff;
  border: 1px solid var(--color-border-soft);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.leistungen-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.leistungen-card__head {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}
.leistungen-card__icon {
  display: inline-grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: var(--color-bg-tint);
  color: var(--color-primary);
  flex-shrink: 0;
}
.leistungen-card__icon svg { width: 28px; height: 28px; }
.leistungen-card__title {
  font-family: var(--font-heading);
  font-size: clamp(1.375rem, 1vw + 0.9rem, 1.75rem);
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0;
}
.leistungen-card__lead {
  font-size: 1.0625rem;
  line-height: 1.55;
  color: var(--color-text-muted);
  margin: 0;
}
.leistungen-card__bullets {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.6em;
}
.leistungen-card__bullets li {
  display: flex;
  align-items: flex-start;
  gap: 0.6em;
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--color-text);
}
.leistungen-card__bullet-icon {
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: rgba(0, 137, 247, 0.12);
  color: var(--color-primary);
  flex: 0 0 22px;
  margin-top: 0.15em;
}
.leistungen-card__bullet-icon svg { width: 14px; height: 14px; stroke-width: 2.5; }
.leistungen-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  margin-top: auto;
  padding-top: var(--space-sm);
  color: var(--color-primary);
  font-weight: 600;
  text-decoration: none;
  border-top: 1px solid var(--color-border-soft);
}
.leistungen-card__cta:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

/* ============================================================
 * USE-CASE-GRID — API-Integrationen Use-Cases (Stripe, Lexware …)
 * Variante mit Featured-Cards (mit Bullets) und Standard-Cards.
 * Layout: 3-spaltig auf Desktop, 2-spaltig auf Tablet, 1-spaltig auf Mobile.
 * ============================================================ */
.use-case-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  align-items: stretch;
}
@media (max-width: 1000px) { .use-case-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .use-case-grid { grid-template-columns: 1fr; } }

.use-case-card {
  display: flex;
  flex-direction: column;
  padding: var(--space-lg);
  background: var(--color-bg-card, #ffffff);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-md);
  box-shadow: 0 1px 2px rgba(0, 41, 75, 0.04);
}
.use-case-card--featured {
  background: var(--color-bg-tint);
  border-left: 4px solid var(--color-primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.use-case-card__head {
  margin-bottom: var(--space-sm);
}
.use-case-card__category {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: 0.4em;
}
.use-case-card__title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 0;
  line-height: 1.25;
}
.use-case-card__text {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--color-text-muted);
  margin: 0 0 var(--space-sm);
}
.use-case-card__bullets {
  list-style: none;
  padding: 0;
  margin: var(--space-xs) 0 0;
  display: grid;
  gap: 0.45em;
}
.use-case-card__bullets li {
  position: relative;
  padding-left: 1.25em;
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--color-text);
}
.use-case-card__bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-primary);
}

/* ============================================================
 * BLOG — Listing, Cards, Filter-Pills und Post-Detail
 * ============================================================ */

/* Grid mit 3 Cards (auf Desktop), 2 (Tablet), 1 (Mobile) */
.blog-grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}
@media (max-width: 1000px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .blog-grid { grid-template-columns: 1fr; } }

.blog-card {
  list-style: none;
}
.blog-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: #ffffff;
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-md);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.blog-card__link:hover,
.blog-card__link:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0, 41, 75, 0.08);
  border-color: var(--color-primary);
  text-decoration: none;
}
.blog-card__link:hover .blog-card__title,
.blog-card__link:hover .blog-card__excerpt,
.blog-card__link:hover .blog-card__date,
.blog-card__link:hover .blog-card__category,
.blog-card__link:hover .blog-card__read {
  text-decoration: none;
}
.blog-card__cover {
  aspect-ratio: 16 / 9;
  background: var(--color-bg-tint);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.blog-card__cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.blog-card__body {
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 0.5em;
}
.blog-card__meta {
  display: flex;
  align-items: center;
  gap: 0.5em;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-text-muted);
  letter-spacing: 0.03em;
}
.blog-card__category {
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}
.blog-card__dot {
  color: var(--color-border);
}
.blog-card__read {
  color: var(--color-text-muted);
}
.blog-card__title {
  font-family: var(--font-heading);
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-primary-dark);
  margin: 0;
}
.blog-card__link:hover .blog-card__title {
  color: var(--color-primary);
}
.blog-card__excerpt {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--color-text-muted);
  margin: 0;
  flex: 1;
}
.blog-card__date {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  margin-top: 0.5em;
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-border-soft);
}

/* Section-Container fuer Blog auf Service-/Startseite */
.blog-section__more {
  margin-top: var(--space-xl);
  text-align: center;
}
.blog-section__empty {
  text-align: center;
  color: var(--color-text-muted);
  font-size: 0.9375rem;
  margin: var(--space-xl) 0;
}

/* Filter-Pills auf Blog-Uebersicht */
.blog-filter-section { padding-block: var(--space-lg) var(--space-md); }
.blog-filter {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-sm) var(--space-md);
}
.blog-filter__label {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-text-muted);
  letter-spacing: 0.03em;
  text-transform: uppercase;
}
.blog-filter__pills {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
}
.blog-filter__pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  padding: 0.5em 1em;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
  background: #ffffff;
  border: 1px solid var(--color-border-soft);
  border-radius: 999px;
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.blog-filter__pill:hover,
.blog-filter__pill:focus-visible {
  background: var(--color-bg-tint);
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
}
.blog-filter__pill.is-active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #ffffff;
}
.blog-filter__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.4em;
  height: 1.4em;
  padding: 0 0.4em;
  font-size: 0.7rem;
  font-weight: 700;
  background: var(--color-bg-tint);
  color: var(--color-text-muted);
  border-radius: 999px;
  line-height: 1;
}
.blog-filter__pill.is-active .blog-filter__count {
  background: rgba(255, 255, 255, 0.22);
  color: #ffffff;
}

.blog-empty {
  text-align: center;
  padding: var(--space-2xl) var(--space-md);
}
.blog-empty h2 {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  margin-bottom: var(--space-md);
  color: var(--color-primary-dark);
}

/* Blog-Post Detail */
.blog-post { padding-block: var(--space-xl) var(--space-2xl); }
.blog-post__header { padding-block: var(--space-xl) var(--space-md); }
.blog-post__back {
  margin-bottom: var(--space-lg);
}
.blog-post__back a {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-muted);
  text-decoration: none;
}
.blog-post__back a:hover {
  color: var(--color-primary);
}
.blog-post__back svg {
  transform: rotate(180deg);
}
.blog-post__meta-top {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
  align-items: center;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-bottom: var(--space-md);
}
.blog-post__category {
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}
.blog-post__dot { color: var(--color-border); }
.blog-post__title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4.5vw, 3rem);
  font-weight: 800;
  line-height: 1.15;
  color: var(--color-primary-dark);
  margin: 0 0 var(--space-md);
  letter-spacing: -0.01em;
}
.blog-post__lead {
  font-size: 1.125rem;
  line-height: 1.6;
  color: var(--color-text);
  margin: 0 0 var(--space-lg);
  max-width: 70ch;
}
.blog-post__author {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  padding-block: var(--space-md);
  border-top: 1px solid var(--color-border-soft);
}
.blog-post__cover {
  margin-block: var(--space-lg) var(--space-xl);
}
.blog-post__cover img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-lg);
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

/* Body-Typografie fuer Markdown-gerendertes HTML im .prose-Container */
.blog-post__body .prose {
  max-width: 70ch;
  margin-inline: auto;
  font-size: 1.0625rem;
  line-height: 1.75;
  color: var(--color-text);
}
.blog-post__body .prose h2 {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 2.5em 0 0.6em;
  line-height: 1.25;
}
.blog-post__body .prose h3 {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin: 1.8em 0 0.5em;
  line-height: 1.3;
}
.blog-post__body .prose p { margin: 0 0 1.2em; }
.blog-post__body .prose a {
  color: var(--color-primary);
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 0.18em;
}
.blog-post__body .prose a:hover {
  color: var(--color-primary-dark);
}
.blog-post__body .prose ul,
.blog-post__body .prose ol {
  margin: 0 0 1.2em;
  padding-left: 1.5em;
}
.blog-post__body .prose li { margin-bottom: 0.4em; }
.blog-post__body .prose blockquote {
  margin: 1.8em 0;
  padding: 1.2em 1.5em;
  background: var(--color-bg-tint);
  border-left: 4px solid var(--color-primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: 1rem;
  line-height: 1.6;
}
.blog-post__body .prose blockquote p:last-child { margin-bottom: 0; }
.blog-post__body .prose code {
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
  font-size: 0.9em;
  background: var(--color-bg-tint);
  padding: 0.15em 0.4em;
  border-radius: 4px;
}
.blog-post__body .prose pre {
  background: #0a1428;
  color: #e2e8f0;
  padding: 1.2em;
  border-radius: var(--radius-md);
  overflow-x: auto;
  margin: 1.5em 0;
}
.blog-post__body .prose pre code {
  background: transparent;
  padding: 0;
  color: inherit;
}
.blog-post__body .prose img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  margin: 2em 0;
  display: block;
  background: var(--color-bg-tint);
}
.blog-post__body .prose strong {
  color: var(--color-primary-dark);
}
.blog-post__body .prose hr {
  margin: 3em 0;
  border: 0;
  border-top: 1px solid var(--color-border-soft);
}
