/* =============================================================================
   MONTARA SOLUTIONS — Landing Page Shared Styles
   Design-Tokens aus docs/BRANCHE.md, Regeln aus docs/DESIGNSYSTEM.md.
   Industrial-Brutalist + Editorial (siehe docs/TASTE-SKILLS.md).
   ============================================================================= */

:root {
  --ink:        #0A0A0B;
  --anthracite: #1A1A1A;
  --graphite:   #2A2A2E;
  --accent:     #FF6B35;
  --accent-600: #F15A1F;
  --accent-50:  #FFF3ED;
  --surface:    #FFFFFF;
  --bg-soft:    #F5F5F7;
  --bg-warm:    #FAFAF7;
  --line:       #E6E6EA;
  --line-soft:  #F0F0F3;
  --text:       #0A0A0B;
  --text-mid:   #52525B;
  --text-dim:   #8A8A94;
  --ease-out:   cubic-bezier(0.22, 1, 0.36, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text);
  background: var(--surface);
  overflow-x: hidden;
  font-feature-settings: "ss01", "cv11";
  padding-top: 0;
}

h1, h2, h3, h4 {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--text);
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }

.container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
}
.container-tight {
  max-width: 980px;
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 720px) {
  .container, .container-tight { padding: 0 20px; }
}

::selection { background: var(--accent); color: #fff; }

/* -------- Utility -------- */
.mono {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 500;
}
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-mid);
  font-weight: 500;
}
.eyebrow::before {
  content: ''; width: 28px; height: 1px; background: var(--accent);
}
.eyebrow--light {
  color: rgba(255,255,255,0.65);
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.01em;
  border-radius: 2px;
  transition: all .25s var(--ease-out);
  min-height: 48px;
  white-space: nowrap;
}
.btn-primary {
  background: var(--accent);
  color: #fff;
}
.btn-primary:hover { background: var(--accent-600); transform: translateY(-1px); }
.btn-ghost {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--line);
}
.btn-ghost:hover { border-color: var(--ink); }
.btn-ghost--light {
  color: #fff;
  border-color: rgba(255,255,255,0.3);
}
.btn-ghost--light:hover { border-color: #fff; }
.btn-dark { background: var(--ink); color: #fff; }
.btn-dark:hover { background: var(--graphite); }

/* =============================================================================
   HEADER (shared across Start + Landing Pages)
   ============================================================================= */
.site-header {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(
    rgba(10, 14, 20, 0.82) 0%,
    rgba(10, 14, 20, 0.55) 70%,
    rgba(10, 14, 20, 0.35) 100%
  );
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  transition: all .3s var(--ease-out);
}
/* Light variant when the page scrolls or when hero is light */
.site-header--solid {
  background: rgba(255,255,255,0.92);
  border-bottom-color: var(--line);
}
.site-header--solid .logo-img { filter: none; }
.site-header--solid .logo-text-main { color: var(--ink); }
.site-header--solid .logo-text-sub { color: var(--text-mid); }
.site-header--solid .nav a { color: var(--text-mid); text-shadow: none; }
.site-header--solid .nav a.active { color: var(--ink); }
.site-header--solid .mobile-toggle { color: var(--ink); }

.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 80px;
  overflow: visible;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 720px) {
  .header-inner { padding: 0 20px; }
}
.logo {
  display: flex; align-items: center; gap: 12px;
  color: #fff;
}
/* Logo — echtes Montara-Logo aus assets/, invertiert für dunklen Header */
.logo { overflow: visible; position: relative; z-index: 2; }
.logo-img {
  display: block;
  height: clamp(84px, 7vw, 112px);
  width: auto;
  object-fit: contain;
  filter: none;
  transition: filter .3s, transform .3s;
  flex-shrink: 0;
}
.logo:hover .logo-img { transform: scale(1.04); }
@media (max-width: 820px) {
  html, body { overflow-x: hidden; max-width: 100%; }
  .header-inner {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 8px;
  }
  .logo { justify-self: center; grid-column: 2; }
  .logo-img { height: 72px; }
  .header-cta {
    grid-column: 3; justify-self: end;
    display: flex; align-items: center; padding: 0;
  }
  .mobile-toggle { margin: 0; }
  .header-inner { height: 72px; padding: 0 16px; }
}
.site-header--solid .logo-img { filter: none; }
.logo-text-group { line-height: 1; }
.logo-text-main {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700; font-size: 15px;
  letter-spacing: 0.08em;
  color: #fff;
  transition: color .3s;
}
.logo-text-sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  margin-top: 2px;
  transition: color .3s;
}

.nav { display: flex; align-items: center; gap: 32px; }
.nav a, .nav-trigger {
  position: relative;
  font-size: 14px; font-weight: 500;
  color: rgba(255,255,255,0.75);
  padding: 4px 0;
  border-bottom: 2px solid transparent;
  text-shadow: 0 1px 3px rgba(0,0,0,0.4);
  transition: color .2s, border-color .2s;
  cursor: pointer;
  background: none;
  font-family: inherit;
}
.nav a:hover, .nav-trigger:hover { color: #fff; }
.nav a.active, .nav-trigger.active { color: #fff; border-bottom-color: var(--accent); }

/* Leistungen-Dropdown */
.nav-group { position: relative; }
.nav-trigger {
  display: inline-flex; align-items: center; gap: 6px;
}
.nav-trigger::after {
  content: '';
  width: 8px; height: 8px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  margin-left: 2px;
  transition: transform .3s var(--ease-out);
  opacity: 0.7;
}
.nav-group:hover .nav-trigger::after,
.nav-group:focus-within .nav-trigger::after {
  transform: rotate(225deg) translateY(2px);
  opacity: 1;
}
.nav-dropdown {
  position: absolute;
  top: calc(100% + 22px);
  left: -20px;
  min-width: 440px;
  background: rgba(10, 14, 20, 0.96);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-top: 2px solid var(--accent);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  border-left: 1px solid rgba(255,255,255,0.06);
  border-right: 1px solid rgba(255,255,255,0.06);
  padding: 6px 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: all .22s var(--ease-out);
  z-index: 110;
  box-shadow: 0 20px 40px rgba(0,0,0,0.35);
}
.nav-group:hover .nav-dropdown,
.nav-group:focus-within .nav-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.nav-dropdown-item {
  display: grid !important;
  grid-template-columns: 48px 1fr auto;
  gap: 14px;
  padding: 14px 22px !important;
  align-items: center;
  color: rgba(255,255,255,0.85) !important;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  border-top: none !important;
  text-shadow: none !important;
}
.nav-dropdown-item:last-child { border-bottom: none; }
.nav-dropdown-item:hover {
  background: rgba(255,107,53,0.08);
  color: #fff !important;
  border-bottom-color: rgba(255,255,255,0.05) !important;
}
.nav-dropdown-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; font-weight: 500;
  letter-spacing: 0.15em;
  color: var(--accent);
}
.nav-dropdown-text { display: flex; flex-direction: column; gap: 2px; }
.nav-dropdown-title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 14px; font-weight: 600;
  letter-spacing: -0.01em;
  color: #fff;
}
.nav-dropdown-sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.nav-dropdown-cat {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 3px 8px;
  border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.6);
}
.nav-dropdown-cat[data-cat="event"] {
  border-color: var(--accent);
  color: var(--accent);
}

.header-cta { display: flex; align-items: center; gap: 12px; }
.mobile-toggle {
  display: none;
  width: 44px; height: 44px;
  align-items: center; justify-content: center;
  color: #fff;
}
@media (max-width: 960px) {
  .nav { display: none; }
  .mobile-toggle { display: inline-flex; }
  .desktop-cta { display: none; }
}

/* Mobile nav overlay (burger open) */
@media (max-width: 820px) {
  .nav.mobile-open {
    display: flex !important;
    position: fixed !important;
    top: 72px !important;
    left: 0 !important;
    right: 0 !important;
    bottom: auto !important;
    height: calc(100vh - 72px) !important;
    max-height: calc(100vh - 72px);
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 24px 20px 40px;
    background: rgba(10, 11, 11, 0.98);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    z-index: 99;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .nav.mobile-open > a,
  .nav.mobile-open .nav-trigger {
    display: block;
    padding: 20px 4px;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 22px; font-weight: 600;
    color: #fff; text-shadow: none;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }
  .nav.mobile-open .nav-group { width: 100%; }
  .nav.mobile-open .nav-dropdown {
    position: static;
    display: flex; flex-direction: column;
    background: transparent;
    box-shadow: none;
    padding: 4px 0 8px;
    min-width: 0; width: 100%;
    border: none;
    visibility: visible; opacity: 1; transform: none;
  }
  .nav.mobile-open .nav-dropdown-item {
    display: grid !important;
    grid-template-columns: 32px 1fr auto !important;
    gap: 10px !important;
    padding: 14px 12px 14px 14px !important;
    border: none !important;
    border-left: 2px solid rgba(255,107,53,0.4) !important;
    margin-left: 4px; margin-bottom: 2px;
    font-size: 14px;
    min-width: 0;
  }
  .nav.mobile-open .nav-dropdown-cat {
    font-size: 9px !important;
    padding: 3px 6px !important;
    white-space: nowrap;
  }
  .nav.mobile-open .nav-dropdown-title { font-size: 14px; }
  .nav.mobile-open .nav-dropdown-sub { font-size: 11px; }
  body.nav-locked { overflow: hidden; }
}

/* =============================================================================
   BREADCRUMB
   ============================================================================= */
.breadcrumb {
  padding: 32px 0 16px;
  border-bottom: 1px solid var(--line);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-mid);
}
.breadcrumb a { color: var(--text-mid); }
.breadcrumb a:hover { color: var(--ink); }
.breadcrumb .sep { margin: 0 12px; color: var(--accent); }
.breadcrumb .current { color: var(--ink); font-weight: 500; }

/* =============================================================================
   LANDING HERO (Cinematic)
   ============================================================================= */
.lp-hero {
  position: relative;
  min-height: 88vh;
  background: var(--ink);
  color: #fff;
  overflow: hidden;
  border-top: 3px solid var(--accent);
}
.lp-hero-bg {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(0.7) saturate(0.9) contrast(1.05);
  animation: lpHeroZoom 18s ease-out forwards;
}
@keyframes lpHeroZoom {
  from { transform: scale(1.0); }
  to   { transform: scale(1.08); }
}
.lp-hero-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(10,10,11,0.78) 0%, rgba(10,10,11,0.35) 60%, rgba(10,10,11,0.55) 100%),
    linear-gradient(180deg, rgba(10,10,11,0.4) 0%, transparent 35%, rgba(10,10,11,0.85) 100%);
  z-index: 1;
}
.lp-hero-inner {
  position: relative; z-index: 2;
  min-height: 88vh;
  padding-top: 160px;
  padding-bottom: 80px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.lp-hero-meta {
  display: flex; align-items: center; gap: 20px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.75);
  flex-wrap: wrap;
}
.lp-hero-meta .cat {
  padding: 5px 12px;
  border: 1px solid rgba(255,255,255,0.25);
  color: #fff;
}
.lp-hero-meta .cat[data-cat="event"] { border-color: var(--accent); color: var(--accent); }
.lp-hero-meta .sep { color: var(--accent); letter-spacing: 0.05em; }
.lp-hero-meta .stamp { color: rgba(255,255,255,0.4); margin-left: auto; }

.lp-hero-content {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(24px, 3vw, 56px);
  align-items: end;
  max-width: 1280px;
}
.lp-hero-num {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: clamp(7rem, 15vw, 15rem);
  line-height: 0.8;
  letter-spacing: -0.06em;
  color: var(--accent);
  text-shadow: 0 4px 32px rgba(0,0,0,0.4);
  margin-bottom: -0.08em;
}
.lp-hero-body { padding-bottom: 12px; }
.lp-hero-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 18px;
}
.lp-hero-title {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: clamp(2.4rem, 5.2vw, 5rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: #fff;
  text-shadow: 0 2px 24px rgba(0,0,0,0.6);
  max-width: 20ch;
  margin-bottom: 24px;
  text-wrap: balance;
}
.lp-hero-lead {
  font-size: clamp(17px, 1.35vw, 22px);
  line-height: 1.5;
  color: rgba(255,255,255,0.88);
  max-width: 620px;
  margin-bottom: 36px;
  font-weight: 300;
}
.lp-hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; }

@media (max-width: 820px) {
  .lp-hero-content { grid-template-columns: 1fr; gap: 4px; }
  .lp-hero-num { font-size: clamp(5rem, 20vw, 8rem); }
  .lp-hero-inner { padding-top: 120px; padding-bottom: 60px; }
}

/* =============================================================================
   SECTION HEAD (shared)
   ============================================================================= */
.section {
  padding: 120px 0;
  background: var(--surface);
}
.section--soft { background: var(--bg-soft); }
.section--dark { background: var(--ink); color: #fff; }
.section--dark h2, .section--dark h3 { color: #fff; }
.section-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 32px; flex-wrap: wrap;
  margin-bottom: 64px;
}
.section-head h2 {
  font-size: clamp(32px, 4.2vw, 56px);
  max-width: 720px;
  text-wrap: balance;
  line-height: 1.02;
}
.section-head h2 small {
  display: block;
  color: var(--text-dim);
  font-weight: 500;
  margin-top: 8px;
  font-size: 0.7em;
}
.section--dark .section-head h2 small { color: rgba(255,255,255,0.5); }

@media (max-width: 720px) {
  .section { padding: 72px 0; }
  .section-head { margin-bottom: 40px; }
}

/* =============================================================================
   LP COMPONENTS: Problem / Benefit / Process / Cross-sell / Final CTA
   ============================================================================= */

/* Kennen Sie das? — problem block with numbered pain-points */
.problems {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
}
.problems .item {
  padding: 40px 32px 40px 0;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.problems .item:last-child { border-right: none; }
.problems .num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--accent);
  margin-bottom: 14px;
}
.problems .q {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-wrap: balance;
}
@media (max-width: 820px) {
  .problems { grid-template-columns: 1fr; }
  .problems .item { padding: 28px 0; border-right: none; }
}

/* Vorteile — 3-column benefit grid */
.benefits {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
}
.benefit-item { }
.benefit-item .marker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--accent);
  margin-bottom: 16px;
  display: flex; align-items: center; gap: 10px;
}
.benefit-item .marker::before {
  content: ''; width: 24px; height: 1px; background: var(--accent);
}
.benefit-item h3 {
  font-size: 24px;
  margin-bottom: 12px;
  letter-spacing: -0.02em;
  text-wrap: balance;
}
.benefit-item p {
  color: var(--text-mid);
  line-height: 1.6;
}
.section--dark .benefit-item p { color: rgba(255,255,255,0.75); }
@media (max-width: 820px) {
  .benefits { grid-template-columns: 1fr; gap: 32px; }
}

/* Was wir machen — detailed offering (2-column) */
.offering {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 72px;
  align-items: start;
}
.offering-text h2 { margin-bottom: 24px; }
.offering-text p {
  color: var(--text-mid);
  font-size: 17px;
  line-height: 1.7;
  margin-bottom: 16px;
}
.offering-list {
  list-style: none;
  border-top: 1px solid var(--line);
}
.offering-list li {
  padding: 16px 0;
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 16px;
  align-items: baseline;
}
.offering-list .num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.15em;
  color: var(--accent);
}
.offering-list .text {
  font-size: 16px;
  line-height: 1.5;
  color: var(--text);
}
@media (max-width: 820px) {
  .offering { grid-template-columns: 1fr; gap: 40px; }
}

/* Process — 4 Step timeline */
.process {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  position: relative;
}
.process::before {
  content: '';
  position: absolute;
  top: 20px; left: 0; right: 0;
  height: 1px;
  background: var(--line);
}
.section--dark .process::before { background: rgba(255,255,255,0.12); }
.process-step { position: relative; padding-top: 60px; }
.process-step::before {
  content: '';
  position: absolute;
  top: 14px; left: 0;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--surface);
  border: 2px solid var(--accent);
}
.section--dark .process-step::before { background: var(--ink); }
.process-step .num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.18em;
  color: var(--accent);
  margin-bottom: 12px;
}
.process-step h4 {
  font-size: 18px;
  letter-spacing: -0.015em;
  margin-bottom: 10px;
}
.process-step p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-mid);
}
.section--dark .process-step p { color: rgba(255,255,255,0.7); }
@media (max-width: 820px) {
  .process { grid-template-columns: 1fr; gap: 24px; }
  .process::before { display: none; }
  .process-step { padding-top: 0; padding-left: 28px; border-left: 1px solid var(--line); }
  .section--dark .process-step { border-left-color: rgba(255,255,255,0.12); }
  .process-step::before { top: 0; left: -8px; }
}

/* Trust / Stat strip */
.trust-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 48px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.section--dark .trust-strip {
  border-color: rgba(255,255,255,0.12);
}
.trust-strip .cell {
  padding: 0 32px;
  border-left: 1px solid var(--line);
}
.section--dark .trust-strip .cell { border-left-color: rgba(255,255,255,0.1); }
.trust-strip .cell:first-child { padding-left: 0; border-left: none; }
.trust-strip .value {
  font-family: 'JetBrains Mono', monospace;
  font-size: 38px; font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: 12px;
  color: var(--ink);
}
.section--dark .trust-strip .value { color: #fff; }
.trust-strip .value .unit { color: var(--accent); font-size: 0.55em; margin-left: 4px; }
.trust-strip .label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-mid);
}
.section--dark .trust-strip .label { color: rgba(255,255,255,0.6); }
@media (max-width: 820px) {
  .trust-strip { grid-template-columns: repeat(2, 1fr); gap: 32px 0; }
  .trust-strip .cell { padding: 0 16px; }
  .trust-strip .cell:nth-child(3) { border-left: none; padding-left: 0; }
  .trust-strip .value { font-size: 28px; }
}

/* FAQ (accordion) */
.faq-list { max-width: 820px; margin: 0 auto; }
.faq-item {
  border-top: 1px solid var(--line);
  padding: 22px 0;
}
.faq-item:last-child { border-bottom: 1px solid var(--line); }
.section--dark .faq-item,
.section--dark .faq-item:last-child { border-color: rgba(255,255,255,0.12); }
.faq-q {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 24px;
  width: 100%;
  text-align: left;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 18px; font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--ink);
  cursor: pointer;
  padding: 0;
}
.section--dark .faq-q { color: #fff; }
.faq-q::after {
  content: '+';
  font-family: 'JetBrains Mono', monospace;
  font-size: 22px; color: var(--accent);
  transition: transform .25s var(--ease-out);
}
.faq-item.open .faq-q::after { transform: rotate(45deg); }
.faq-a {
  margin-top: 0;
  max-height: 0;
  overflow: hidden;
  color: var(--text-mid);
  font-size: 15px; line-height: 1.6;
  transition: max-height .35s var(--ease-out), margin-top .35s var(--ease-out);
}
.section--dark .faq-a { color: rgba(255,255,255,0.75); }
.faq-item.open .faq-a {
  margin-top: 14px;
  max-height: 500px;
}

/* Cross-sell — related services grid */
.cross-sell {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.cross-sell-item {
  padding: 28px;
  border: 1px solid var(--line);
  background: var(--surface);
  transition: all .25s var(--ease-out);
  display: flex; flex-direction: column; justify-content: space-between;
  min-height: 200px;
}
.cross-sell-item:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
}
.cross-sell-item .num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.18em;
  color: var(--accent);
  margin-bottom: 14px;
}
.cross-sell-item h4 {
  font-size: 22px;
  letter-spacing: -0.02em;
  margin-bottom: 8px;
  text-wrap: balance;
}
.cross-sell-item .desc {
  font-size: 14px; color: var(--text-mid); line-height: 1.55;
  margin-bottom: 18px;
}
.cross-sell-item .arrow {
  color: var(--accent);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: gap .25s;
  display: inline-flex; gap: 8px;
}
.cross-sell-item:hover .arrow { gap: 14px; }
@media (max-width: 820px) {
  .cross-sell { grid-template-columns: 1fr; }
}

/* Final CTA block */
.final-cta {
  background: var(--ink);
  color: #fff;
  padding: 120px 0;
  border-top: 3px solid var(--accent);
  position: relative;
  overflow: hidden;
}
.final-cta-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 32px;
  text-align: center;
}
.final-cta h2 {
  color: #fff;
  font-size: clamp(36px, 5.2vw, 68px);
  line-height: 1;
  margin-bottom: 24px;
  text-wrap: balance;
}
.final-cta h2 .mark { color: var(--accent); font-style: normal; }
.final-cta p {
  max-width: 640px;
  margin: 0 auto 40px;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.6;
  color: rgba(255,255,255,0.8);
}
.final-cta-ctas { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
.final-cta .phone-line {
  display: block;
  margin-top: 32px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
.final-cta .phone-line a {
  color: var(--accent);
  border-bottom: 1px solid var(--accent);
  padding-bottom: 2px;
}

/* =============================================================================
   FOOTER
   ============================================================================= */
.site-footer {
  background: var(--ink);
  color: rgba(255,255,255,0.6);
  padding: 40px 0;
  border-top: 1px solid rgba(255,255,255,0.1);
}
.footer-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 16px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
}
.footer-inner a:hover { color: var(--accent); }

/* =============================================================================
   LENIS — Smooth-Scroll-Hooks
   ============================================================================= */
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: clip; }
.lenis.lenis-smooth iframe { pointer-events: none; }

/* =============================================================================
   REVEAL on scroll — mit Richtungs- und Blur-Varianten
   Nutzbar: .reveal, .reveal-left, .reveal-right, .reveal-scale, .reveal-blur,
            .reveal-up-big  + optional data-delay="1..6"
   ============================================================================= */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  filter: blur(0);
  transition: opacity .75s var(--ease-out),
              transform .75s var(--ease-out),
              filter .75s var(--ease-out);
  will-change: transform, opacity;
}
.reveal.in { opacity: 1; transform: translateY(0) translateX(0) scale(1); filter: blur(0); }

.reveal-left   { transform: translateX(-56px); }
.reveal-right  { transform: translateX(56px); }
.reveal-scale  { transform: scale(0.94); }
.reveal-blur   { transform: translateY(32px); filter: blur(14px); }
.reveal-up-big { transform: translateY(72px); }

.reveal[data-delay="1"] { transition-delay: .08s; }
.reveal[data-delay="2"] { transition-delay: .16s; }
.reveal[data-delay="3"] { transition-delay: .24s; }
.reveal[data-delay="4"] { transition-delay: .32s; }
.reveal[data-delay="5"] { transition-delay: .40s; }
.reveal[data-delay="6"] { transition-delay: .48s; }

@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal-left, .reveal-right, .reveal-scale, .reveal-blur, .reveal-up-big {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
  }
}

/* ================= Emergency CTA 24/7 ================= */
.emergency-cta {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 9px 16px 9px 14px;
  background: #111;
  border: 1px solid rgba(255,255,255,0.12);
  text-decoration: none;
  font-family: 'Space Grotesk', sans-serif;
  transition: border-color .18s ease, background .18s ease, transform .18s ease;
  line-height: 1;
}
.emergency-cta:hover {
  border-color: var(--accent);
  background: #1a1a1a;
  transform: translateY(-1px);
}
.emergency-cta-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 0 0 rgba(34,197,94,0.65);
  animation: emergencyPulse 2s ease-out infinite;
  flex-shrink: 0;
}
@keyframes emergencyPulse {
  0%   { box-shadow: 0 0 0 0 rgba(34,197,94,0.65); }
  70%  { box-shadow: 0 0 0 10px rgba(34,197,94,0); }
  100% { box-shadow: 0 0 0 0 rgba(34,197,94,0); }
}
.emergency-cta-text { display: flex; flex-direction: column; gap: 3px; }
.emergency-cta-main {
  font-size: 13px; font-weight: 600; color: #fff;
  letter-spacing: -0.005em;
}
.emergency-cta-sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--accent); font-weight: 500;
}
@media (prefers-reduced-motion: reduce) { .emergency-cta-dot { animation: none; } }
@media (max-width: 820px) {
  .emergency-cta { display: none !important; }
}

/* ============ Mobile Dock — fixed bottom bar ============ */
.mobile-dock { display: none; }
@media (max-width: 820px) {
  body { padding-bottom: 68px; }
  .mobile-dock {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: var(--ink);
    border-top: 2px solid var(--accent);
    z-index: 999;
    padding-bottom: env(safe-area-inset-bottom, 0);
    box-shadow: 0 -8px 24px -12px rgba(0,0,0,0.35);
  }
  .mobile-dock a {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 4px;
    padding: 10px 4px 12px;
    color: #fff;
    text-decoration: none;
    font-family: 'Inter', sans-serif;
    font-size: 10.5px; font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border-right: 1px solid rgba(255,255,255,0.1);
    transition: background .15s ease, color .15s ease;
  }
  .mobile-dock a:last-child { border-right: none; }
  .mobile-dock a:active { background: rgba(255,107,53,0.15); color: var(--accent); }
  .mobile-dock a svg { width: 22px; height: 22px; }
  .mobile-dock a.is-phone svg { color: var(--accent); }
  .mobile-dock a.is-whatsapp {
    position: relative;
  }
  .mobile-dock a.is-whatsapp svg { color: #22c55e; }
  .mobile-dock a.is-whatsapp::after {
    content: '';
    position: absolute;
    top: 10px; right: 28%;
    width: 7px; height: 7px; border-radius: 50%;
    background: #22c55e;
    box-shadow: 0 0 0 0 rgba(34,197,94,0.6);
    animation: emergencyPulse 2s ease-out infinite;
  }
  .mobile-dock a.is-email svg { color: #fff; }
  .mobile-dock a span { line-height: 1; }
}

/* ============ Theme Manager Widget ============ */
.tm-toggle {
  position: fixed;
  bottom: 20px; right: 20px;
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  border: none;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 16px 32px -12px rgba(255,107,53,0.55), 0 4px 10px rgba(0,0,0,0.15);
  cursor: pointer;
  z-index: 998;
  transition: transform .25s ease, box-shadow .25s ease;
}
.tm-toggle svg { width: 22px; height: 22px; }
.tm-toggle:hover { transform: translateY(-2px) rotate(12deg); box-shadow: 0 20px 40px -14px rgba(255,107,53,0.7); }
@media (max-width: 820px) {
  .tm-toggle { bottom: 88px; right: 16px; width: 44px; height: 44px; }
  .tm-toggle svg { width: 18px; height: 18px; }
}

.tm-panel {
  position: fixed;
  bottom: 84px; right: 20px;
  width: 300px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 24px 64px -20px rgba(0,0,0,0.3), 0 4px 12px rgba(0,0,0,0.08);
  padding: 22px;
  z-index: 999;
  display: flex; flex-direction: column; gap: 18px;
  animation: tmIn .2s ease;
  color: #1a1a1c;
}
@keyframes tmIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
@media (max-width: 820px) {
  .tm-panel { bottom: 140px; right: 12px; width: calc(100vw - 24px); max-width: 320px; }
}

.tm-head {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}
.tm-head strong {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 16px; font-weight: 700;
  letter-spacing: -0.01em;
  color: #1a1a1c;
}
.tm-close {
  width: 28px; height: 28px;
  background: transparent;
  border: 1px solid var(--line);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  color: #5a5a5c;
  transition: border-color .15s, color .15s;
}
.tm-close svg { width: 14px; height: 14px; }
.tm-close:hover { border-color: var(--accent); color: var(--accent); }

.tm-group { display: flex; flex-direction: column; gap: 10px; }
.tm-label {
  font-family: 'Inter', sans-serif;
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #5a5a5c;
}

.tm-row { display: flex; gap: 8px; flex-wrap: wrap; }
.tm-row.tm-col { flex-direction: column; gap: 6px; }

.tm-pill {
  flex: 1;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid var(--line);
  font-family: 'Inter', sans-serif;
  font-size: 13px; font-weight: 500;
  color: #1a1a1c;
  cursor: pointer;
  text-align: left;
  transition: border-color .15s, background .15s, color .15s;
}
.tm-pill em { color: #9a9a9c; font-style: normal; font-size: 11px; margin-left: 4px; }
.tm-pill:hover { border-color: var(--accent); color: var(--accent); }
.tm-pill.is-active {
  border-color: var(--accent);
  background: rgba(255,107,53,0.08);
  color: var(--accent);
}
.tm-pill.is-active em { color: var(--accent); opacity: 0.75; }

.tm-swatches { display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; }
.tm-swatch {
  aspect-ratio: 1;
  background: var(--c);
  border: 2px solid transparent;
  outline: 1px solid var(--line);
  outline-offset: -1px;
  cursor: pointer;
  padding: 0;
  transition: transform .15s ease, outline-color .15s;
  border-radius: 0;
}
.tm-swatch:hover { transform: scale(1.08); }
.tm-swatch.is-active {
  border-color: #fff;
  outline: 2px solid var(--c);
  outline-offset: 2px;
}

.tm-reset {
  margin-top: 4px;
  padding: 10px;
  background: transparent;
  border: 1px solid var(--line);
  color: #5a5a5c;
  font-family: 'Inter', sans-serif;
  font-size: 12px; font-weight: 500;
  cursor: pointer;
  transition: all .15s;
}
.tm-reset:hover { border-color: var(--accent); color: var(--accent); }

/* Dark mode overrides */
/* Hell-Modus: Header + Nav werden hell (Default bleibt aktueller Look mit dunklem Header) */
html[data-theme="light"] .site-header {
  background: rgba(255, 255, 255, 0.92) !important;
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(10px);
}
html[data-theme="light"] .site-header .logo-text-main,
html[data-theme="light"] .site-header .nav a,
html[data-theme="light"] .site-header .nav-trigger { color: var(--ink) !important; text-shadow: none !important; }
html[data-theme="light"] .site-header .mobile-toggle { color: var(--ink); }
html[data-theme="light"] .nav-dropdown { background: #fff; border-color: var(--line); }
html[data-theme="light"] .nav-dropdown-item { color: var(--ink) !important; }
html[data-theme="light"] .nav-dropdown-title { color: var(--ink); }
html[data-theme="light"] .nav-dropdown-sub { color: var(--text-mid); }
html[data-theme="light"] .nav-dropdown-num { color: var(--accent); }
html[data-theme="light"] .nav.mobile-open { background: #fff !important; }
html[data-theme="light"] .nav.mobile-open a { color: var(--ink) !important; border-bottom-color: var(--line) !important; }

/* ----- Light-Modus: dunkle Sections invertieren ----- */
html[data-theme="light"] .site-footer { background: #f5f5f2 !important; color: #5a5a5c !important; border-top: 1px solid var(--line); }
html[data-theme="light"] .site-footer span,
html[data-theme="light"] .site-footer a { color: #5a5a5c !important; }
html[data-theme="light"] .site-footer a:hover { color: var(--accent) !important; }

/* section--dark (generic dark section) */
html[data-theme="light"] .section--dark { background: #f5f5f2 !important; color: #1a1a1c !important; }
html[data-theme="light"] .section--dark h1,
html[data-theme="light"] .section--dark h2,
html[data-theme="light"] .section--dark h3,
html[data-theme="light"] .section--dark h4,
html[data-theme="light"] .section--dark strong { color: #0a0a0b !important; }
html[data-theme="light"] .section--dark p,
html[data-theme="light"] .section--dark li,
html[data-theme="light"] .section--dark span:not(.mark):not([class*="accent"]) { color: #5a5a5c !important; }
html[data-theme="light"] .section--dark .eyebrow--light { color: var(--accent) !important; }
html[data-theme="light"] .section--dark .process-step { border-color: #d8d8d5 !important; }
html[data-theme="light"] .section--dark .process-step .num { color: var(--accent) !important; }

/* final-cta */
html[data-theme="light"] .final-cta { background: #f5f5f2 !important; color: #1a1a1c !important; }
html[data-theme="light"] .final-cta h1,
html[data-theme="light"] .final-cta h2,
html[data-theme="light"] .final-cta h3 { color: #0a0a0b !important; }
html[data-theme="light"] .final-cta p { color: #5a5a5c !important; }
html[data-theme="light"] .final-cta .eyebrow--light { color: var(--accent) !important; }
html[data-theme="light"] .final-cta .phone-line { color: #5a5a5c !important; }

/* Contact-Aside (dark card) */
html[data-theme="light"] .contact-aside { background: #f5f5f2 !important; color: #1a1a1c !important; border: 1px solid var(--line); }
html[data-theme="light"] .contact-aside h3 { color: #0a0a0b !important; }
html[data-theme="light"] .contact-info { border-top-color: #d8d8d5 !important; }
html[data-theme="light"] .contact-info-row { border-bottom-color: #d8d8d5 !important; }
html[data-theme="light"] .contact-info-row .label { color: #5a5a5c !important; }
html[data-theme="light"] .contact-info-row .value { color: #0a0a0b !important; }
html[data-theme="light"] .contact-info-row .value a { color: #0a0a0b !important; border-bottom-color: #d8d8d5 !important; }

/* Featured stat-tile (DGUV) */
html[data-theme="light"] .stat-tile--featured { background: #fff !important; color: #1a1a1c !important; border-color: var(--line) !important; }
html[data-theme="light"] .stat-tile--featured .stat-value,
html[data-theme="light"] .stat-tile--featured .stat-label { color: #0a0a0b !important; }
html[data-theme="light"] .stat-tile--featured .stat-sub { color: #5a5a5c !important; }

/* AP-Metric dark card (Jahreswartung) */
html[data-theme="light"] .ap-metric--dark { background: #f5f5f2 !important; border-color: var(--line) !important; color: #1a1a1c !important; }
html[data-theme="light"] .ap-metric--dark .ap-metric-label { color: var(--accent) !important; }
html[data-theme="light"] .ap-metric--dark .ap-metric-chips span { background: #fff !important; color: #1a1a1c !important; border-color: var(--line) !important; }
html[data-theme="light"] .ap-metric--dark .ap-metric-star { background: rgba(255,107,53,0.12) !important; color: var(--accent) !important; }

/* Mobile-Dock */
html[data-theme="light"] .mobile-dock { background: #fff !important; border-top-color: var(--accent); }
html[data-theme="light"] .mobile-dock a { color: #0a0a0b !important; border-right-color: var(--line); }
html[data-theme="light"] .mobile-dock a.is-email svg { color: #0a0a0b !important; }

/* Hero dark CTA-block (Anlage steht? …) */
html[data-theme="light"] [style*="background:var(--ink)"]:not(.nav) { background: #f5f5f2 !important; color: #1a1a1c !important; }

/* Manifest + Contact Section (Startseite) */
html[data-theme="light"] .manifest,
html[data-theme="light"] .contact { background: #f5f5f2 !important; color: #1a1a1c !important; }
html[data-theme="light"] .manifest h1,
html[data-theme="light"] .manifest h2,
html[data-theme="light"] .manifest h3,
html[data-theme="light"] .contact h1,
html[data-theme="light"] .contact h2,
html[data-theme="light"] .contact h3,
html[data-theme="light"] .manifest strong,
html[data-theme="light"] .contact strong { color: #0a0a0b !important; }
html[data-theme="light"] .manifest p,
html[data-theme="light"] .contact p,
html[data-theme="light"] .manifest li,
html[data-theme="light"] .contact li { color: #5a5a5c !important; }
html[data-theme="light"] .manifest-kicker,
html[data-theme="light"] .contact .eyebrow { color: var(--accent) !important; }
html[data-theme="light"] .contact-row,
html[data-theme="light"] .contact-row-label,
html[data-theme="light"] .contact-row-value,
html[data-theme="light"] .contact-row-value a { color: #1a1a1c !important; border-color: #d8d8d5 !important; }
html[data-theme="light"] .contact-row-label { color: #5a5a5c !important; }

/* ============ Header-Varianten ============ */
html[data-header="solid-dark"] .site-header {
  background: #0a0a0b !important;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: none;
}
html[data-header="solid-dark"] .site-header .nav a,
html[data-header="solid-dark"] .site-header .nav-trigger { color: #fff !important; text-shadow: none !important; }

html[data-header="solid-light"] .site-header {
  background: #ffffff !important;
  border-bottom: 1px solid var(--line);
  backdrop-filter: none;
}
html[data-header="solid-light"] .site-header .logo-text-main,
html[data-header="solid-light"] .site-header .nav a,
html[data-header="solid-light"] .site-header .nav-trigger { color: #0a0a0b !important; text-shadow: none !important; }
html[data-header="solid-light"] .site-header .mobile-toggle { color: #0a0a0b; }

html[data-header="accent"] .site-header {
  background: var(--accent) !important;
  border-bottom: none;
  backdrop-filter: none;
}
html[data-header="accent"] .site-header .nav a,
html[data-header="accent"] .site-header .nav-trigger,
html[data-header="accent"] .site-header .logo-text-main,
html[data-header="accent"] .site-header .mobile-toggle { color: #fff !important; text-shadow: none !important; }
html[data-header="accent"] .site-header .btn-primary { background: #fff; color: var(--accent); }

/* ============ Header-Layouts ============ */
/* [2] Zentriert — Logo absolut mittig */
html[data-layout="centered"] .header-inner { grid-template-columns: 1fr auto 1fr !important; display: grid !important; align-items: center; }
html[data-layout="centered"] .logo { justify-self: center; grid-column: 2; }
html[data-layout="centered"] .nav { grid-column: 1; justify-self: start; }
html[data-layout="centered"] .header-cta { grid-column: 3; justify-self: end; }
@media (max-width: 820px) {
  html[data-layout="centered"] .header-inner { grid-template-columns: 1fr auto 1fr !important; }
}

/* [3] Minimal — nur Logo + Burger, Desktop-Nav weg */
html[data-layout="minimal"] .nav { display: none !important; }
html[data-layout="minimal"] .desktop-cta { display: none !important; }
html[data-layout="minimal"] .mobile-toggle { display: inline-flex !important; }
html[data-layout="minimal"] .header-inner { justify-content: space-between; }
html[data-layout="minimal"] .site-header { height: 68px; }
html[data-layout="minimal"] .logo-img { height: 48px; }

/* [4] Kompakt — kleinerer Header, alles tighter */
html[data-layout="compact"] .site-header { height: 56px !important; }
html[data-layout="compact"] .logo-img { height: 36px !important; }
html[data-layout="compact"] .nav a,
html[data-layout="compact"] .nav-trigger { font-size: 13px; padding: 6px 12px; }
html[data-layout="compact"] .desktop-cta { padding: 8px 14px; font-size: 13px; }

/* [5] Mega — zweizeilig, Logo groß oben, Nav unten */
html[data-layout="mega"] .site-header { height: auto !important; padding: 12px 0; }
html[data-layout="mega"] .header-inner {
  flex-direction: column !important;
  gap: 14px;
  align-items: center !important;
  height: auto !important;
  padding: 4px 32px !important;
}
html[data-layout="mega"] .logo { order: 1; }
html[data-layout="mega"] .logo-img { height: 72px !important; }
html[data-layout="mega"] .nav {
  order: 2; width: 100%;
  justify-content: center !important;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,0.12);
}
html[data-layout="mega"] .header-cta { position: absolute; top: 18px; right: 32px; order: 0; }
@media (max-width: 820px) {
  html[data-layout="mega"] .header-inner { flex-direction: row !important; }
  html[data-layout="mega"] .nav { display: none; }
}

/* ============ Hero-/Header-Design-Varianten ============ */
/* Ziel-Selektoren: alle Hero-Wrapper auf allen Seiten */
/* [1] Standard = aktueller Look (nichts zu tun) */

/* [2] Minimal — creme Background, dunkler Text, kein Image/Overlay */
html[data-hero="minimal"] .lp-hero,
html[data-hero="minimal"] .about-hero,
html[data-hero="minimal"] .karriere-hero,
html[data-hero="minimal"] .kontakt-hero,
html[data-hero="minimal"] .lp-index-hero {
  background: #fafaf7 !important;
  color: #0a0a0b !important;
  border-top: 3px solid var(--accent);
  min-height: auto !important;
}
html[data-hero="minimal"] .lp-hero-bg,
html[data-hero="minimal"] .lp-hero-overlay,
html[data-hero="minimal"] .about-hero::before,
html[data-hero="minimal"] .about-hero::after,
html[data-hero="minimal"] .karriere-hero::before,
html[data-hero="minimal"] .karriere-hero::after,
html[data-hero="minimal"] .kontakt-hero::before,
html[data-hero="minimal"] .kontakt-hero::after,
html[data-hero="minimal"] .lp-index-hero::before,
html[data-hero="minimal"] .lp-index-hero::after { display: none !important; }
html[data-hero="minimal"] .lp-hero-title,
html[data-hero="minimal"] .about-hero-title,
html[data-hero="minimal"] .karriere-hero-title,
html[data-hero="minimal"] .kontakt-hero-title,
html[data-hero="minimal"] .lp-index-title { color: #0a0a0b !important; }
html[data-hero="minimal"] .about-hero-title .hero-ein,
html[data-hero="minimal"] .about-hero-title .hero-word { color: #0a0a0b !important; }
html[data-hero="minimal"] .lp-hero-lead,
html[data-hero="minimal"] .about-hero-lead,
html[data-hero="minimal"] .karriere-hero-lead,
html[data-hero="minimal"] .kontakt-hero-lead,
html[data-hero="minimal"] .lp-index-lead { color: #5a5a5c !important; }
html[data-hero="minimal"] .lp-hero-kicker { color: var(--accent) !important; }
html[data-hero="minimal"] .lp-hero-num { color: rgba(255,107,53,0.12) !important; }

/* [3] Center — alles zentriert */
html[data-hero="center"] .lp-hero-inner,
html[data-hero="center"] .about-hero-inner,
html[data-hero="center"] .karriere-hero-inner,
html[data-hero="center"] .kontakt-hero-inner,
html[data-hero="center"] .lp-index-hero-inner { text-align: center !important; }
html[data-hero="center"] .lp-hero-content,
html[data-hero="center"] .about-hero-inner > *,
html[data-hero="center"] .karriere-hero-inner > *,
html[data-hero="center"] .kontakt-hero-inner > * { margin-left: auto !important; margin-right: auto !important; }
html[data-hero="center"] .lp-hero-ctas,
html[data-hero="center"] .lp-hero-body,
html[data-hero="center"] .karriere-hero-inner .karriere-hero-lead,
html[data-hero="center"] .kontakt-hero-inner .kontakt-hero-lead { justify-content: center; text-align: center; }
html[data-hero="center"] .about-hero-title { justify-content: center; }
html[data-hero="center"] .lp-hero-title,
html[data-hero="center"] .karriere-hero-title,
html[data-hero="center"] .kontakt-hero-title,
html[data-hero="center"] .lp-index-title { text-align: center; max-width: 100%; }

/* [4] Akzent — Akzentfarbe als Background */
html[data-hero="accent"] .lp-hero,
html[data-hero="accent"] .about-hero,
html[data-hero="accent"] .karriere-hero,
html[data-hero="accent"] .kontakt-hero,
html[data-hero="accent"] .lp-index-hero {
  background: var(--accent) !important;
  color: #fff !important;
  border-top: none !important;
}
html[data-hero="accent"] .lp-hero-bg,
html[data-hero="accent"] .lp-hero-overlay,
html[data-hero="accent"] .about-hero::before,
html[data-hero="accent"] .about-hero::after,
html[data-hero="accent"] .karriere-hero::before,
html[data-hero="accent"] .karriere-hero::after,
html[data-hero="accent"] .kontakt-hero::before,
html[data-hero="accent"] .kontakt-hero::after,
html[data-hero="accent"] .lp-index-hero::before,
html[data-hero="accent"] .lp-index-hero::after { display: none !important; }
html[data-hero="accent"] .lp-hero-kicker { color: rgba(255,255,255,0.85) !important; }
html[data-hero="accent"] .lp-hero-num { color: rgba(255,255,255,0.18) !important; }

/* [5] Full-Bleed — größer, Overlay-Gradient dramatischer */
html[data-hero="fullbleed"] .lp-hero,
html[data-hero="fullbleed"] .about-hero,
html[data-hero="fullbleed"] .karriere-hero,
html[data-hero="fullbleed"] .kontakt-hero,
html[data-hero="fullbleed"] .lp-index-hero {
  min-height: 88vh !important;
  padding-top: 220px !important;
}
html[data-hero="fullbleed"] .lp-hero-overlay {
  background: linear-gradient(180deg, rgba(10,10,11,0.1) 0%, rgba(10,10,11,0.7) 60%, rgba(10,10,11,0.95) 100%) !important;
}
html[data-hero="fullbleed"] .lp-hero-title,
html[data-hero="fullbleed"] .about-hero-title,
html[data-hero="fullbleed"] .karriere-hero-title,
html[data-hero="fullbleed"] .kontakt-hero-title,
html[data-hero="fullbleed"] .lp-index-title { font-size: clamp(56px, 10vw, 160px) !important; }

