
/* =========================================================
   VAM PERFORMANCE — THEME "V3" (Stahl + Carbon + Rot)
   Global, wird NACH styles.css geladen.
   Carbon-Basis, gebürstete Metall-Akzente, Bebas-Display in Stahl-
   Verlauf, Inter-Fließtext, rotes Signal. Motorsport × Edel.
   ========================================================= */

:root {
  --v3-bg: #0f1115;
  --v3-bg2: #15171b;
  --v3-panel: linear-gradient(160deg, #23262c, #15171b);
  --v3-line: rgba(255, 255, 255, 0.10);
  --v3-line2: rgba(255, 255, 255, 0.16);
  --v3-red: #e10600;
  --v3-red-dark: #9b0505;
  --v3-text: #f3f4f6;
  --v3-muted: #9aa0a8;
  --v3-steel: #cfd3da;
  --v3-metal: linear-gradient(160deg, #d7dbe2, #8b9098);
  --v3-steeltext: linear-gradient(180deg, #ffffff 0%, #aeb4c0 100%);
}

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
  line-height: 1.62;
  letter-spacing: 0;
  color: var(--v3-text);
  background:
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 54px),
    repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 54px),
    linear-gradient(180deg, #14161a 0%, #0f1115 60%, #0c0d10 100%) !important;
  background-attachment: fixed !important;
}

body::before {
  display: none !important;
}

/* --- Flächen flach in Carbon --- */
.section-dark,
.section-light,
.configurator,
.services-v3,
.stages-v3,
.seo-hub,
.reviews,
.fileservice,
.seo-page,
.seo-page-section,
.partner-page,
.motorsport-page,
.legal-page,
.contact-location {
  background: transparent !important;
}

.configurator::before,
.seo-hub::before,
.seo-page-section::before {
  display: none !important;
}

/* --- Display-Typografie: Bebas in Stahl-Verlauf --- */
h1, h2,
.accordion-title,
.map-card strong {
  font-family: 'Bebas Neue', 'Inter', sans-serif !important;
  font-weight: 400 !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
  background: var(--v3-steeltext);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

h3, h4,
.stage-top strong,
.result-title h3 {
  font-family: 'Bebas Neue', 'Inter', sans-serif !important;
  font-weight: 400 !important;
  letter-spacing: 0.03em !important;
  text-transform: uppercase !important;
  color: var(--v3-text) !important;
}

.hero-v3-content h1 {
  font-size: clamp(46px, 7vw, 104px) !important;
  line-height: 0.92 !important;
}

.accent {
  background: none !important;
  -webkit-text-fill-color: var(--v3-red) !important;
  color: var(--v3-red) !important;
}

p, li, .intro-copy, .hero-copy {
  font-family: 'Inter', system-ui, sans-serif;
}

p { color: var(--v3-muted); }

/* --- Eyebrow --- */
.eyebrow {
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 12px !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: var(--v3-red) !important;
  background: none !important;
  -webkit-text-fill-color: var(--v3-red) !important;
  clip-path: none !important;
  padding: 0 !important;
}

/* --- Buttons --- */
.button {
  transform: none !important;
  clip-path: none !important;
  border-radius: 9px !important;
  border: 1px solid var(--v3-line2);
  background: var(--v3-bg2);
  color: var(--v3-text);
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  box-shadow: none !important;
}

.button::before,
.button::after { display: none !important; }

.button.primary {
  background: linear-gradient(135deg, #ff2a1f, var(--v3-red) 55%, #8f0303) !important;
  border-color: rgba(255, 90, 80, 0.5) !important;
  color: #fff !important;
}

.button.primary:hover:not(:disabled) {
  filter: brightness(1.08);
  transform: none !important;
}

.button.ghost { background: transparent !important; }

.button:hover:not(:disabled) {
  transform: none !important;
  box-shadow: none !important;
  border-color: var(--v3-line2) !important;
}

/* --- Header --- */
.site-header {
  background: rgba(14, 16, 20, 0.74) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  transition: background 220ms ease, border-color 220ms ease, backdrop-filter 220ms ease;
}

.site-header.is-scrolled {
  background: rgba(13, 14, 18, 0.95) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--v3-line);
}

/* Header-Schrift etwas größer */
.site-header .language-current { font-size: 14px; }
.site-header .header-cta { font-size: 15px; padding: 13px 20px; }
.main-nav a { font-size: 16px; }

.brand-logo { filter: none; }

.main-nav {
  background: #15171b !important;
  border-color: var(--v3-line2) !important;
  border-radius: 12px;
}

.main-nav a {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  text-transform: none;
  color: var(--v3-steel);
}

.main-nav a:hover { background: #21252b; color: #fff; }

.language-toggle, .nav-toggle {
  border-radius: 9px;
  border-color: var(--v3-line2);
  background: #1b1e23;
}

.language-toggle:hover, .nav-toggle:hover,
.language-toggle:focus-visible, .nav-toggle:focus-visible {
  background: #15171b;
  box-shadow: none;
  transform: none;
  border-color: var(--v3-line2);
}

.language-current, .language-option {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  letter-spacing: 0;
}

.language-menu { border-radius: 9px; border-color: var(--v3-line2); background: #15171b; }
.language-option:hover, .language-option[aria-selected="true"] { background: #21252b; }

/* --- Hero --- */
.hero-v3 { background: transparent !important; background-image: none !important; }
.hero-v3-tag { font-family: 'Inter', sans-serif; text-transform: none; letter-spacing: 0.04em; color: rgba(255,255,255,.7); }
.hero-v3-visual::after { display: none; }
.hero-v3-visual::before {
  background:
    repeating-linear-gradient(135deg, rgba(225,6,0,.10) 0 2px, transparent 2px 16px),
    linear-gradient(180deg, rgba(15,17,21,0) 55%, rgba(15,17,21,.55) 100%) !important;
}

@media (min-width: 981px) {
  .hero-v3-visual {
    clip-path: none !important;
    margin: clamp(20px, 3vw, 44px);
    margin-left: 0;
    border: 1px solid var(--v3-line);
    border-radius: 14px;
    overflow: hidden;
  }
}

/* --- Metall-Icon Utility --- */
.v3-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 9px;
  background: var(--v3-metal);
  color: #15171b;
  flex: 0 0 auto;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 2px 6px rgba(0,0,0,.4);
}

.v3-ico svg {
  width: 23px; height: 23px;
  fill: none; stroke: currentColor; stroke-width: 1.8;
  stroke-linecap: round; stroke-linejoin: round;
}

/* --- Navigations-Buttons (Startseite) --- */
.v3nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.v3nav-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 150px;
  padding: 22px;
  border: 1px solid var(--v3-line);
  border-radius: 12px;
  background: var(--v3-panel);
  overflow: hidden;
  transition: border-color 160ms ease, transform 160ms ease;
}

.v3nav-card::after {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--v3-red), transparent 70%);
  opacity: 0;
  transition: opacity 160ms ease;
}

.v3nav-card:hover {
  border-color: var(--v3-line2);
  transform: translateY(-3px);
}

.v3nav-card:hover::after { opacity: 1; }

.v3nav-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 26px;
  letter-spacing: 0.03em;
  color: #fff;
  margin-top: 4px;
}

.v3nav-title .arr { color: var(--v3-red); }

.v3nav-card p {
  margin: 0;
  font-size: 15px;
  color: var(--v3-muted);
}

.v3nav-card .v3-go {
  margin-top: auto;
  font-size: 13px;
  font-weight: 600;
  color: var(--v3-steel);
}

@media (max-width: 860px) {
  .v3nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 560px) {
  .v3nav { grid-template-columns: 1fr; }
}

/* --- Konfigurator-Innenleben ruhig + carbon --- */
.tuning-form, .tuning-result {
  border: 1px solid var(--v3-line) !important;
  border-radius: 14px !important;
  background: var(--v3-bg2) !important;
  box-shadow: none !important;
}

.tuning-form::after, .tuning-result::after { display: none !important; }

.tuning-form::before {
  border-color: var(--v3-line) !important;
  background: #21252b !important;
  color: var(--v3-muted) !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  text-transform: none !important;
}

.select-grid label {
  border: 1px solid var(--v3-line) !important;
  border-radius: 10px !important;
  background: #21252b !important;
  color: var(--v3-muted) !important;
  font-family: 'Inter', sans-serif !important;
  text-transform: none !important;
  letter-spacing: 0.03em !important;
}

.select-grid label::before {
  border-color: var(--v3-line) !important;
  background: #15171b !important;
  color: var(--v3-red) !important;
}

.select-grid label::after { display: none !important; }

.tuning-form select, .tuning-form input {
  border: 1px solid var(--v3-line) !important;
  border-radius: 8px !important;
  background: #0e1014 !important;
  color: #fff !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 500 !important;
}

.tuning-form select:focus, .tuning-form input:focus {
  border-color: var(--v3-red) !important;
  box-shadow: 0 0 0 3px rgba(225,6,0,.18) !important;
}

.result-title span, .gain-line strong { color: var(--v3-red) !important; }

.stage-switch { border-color: var(--v3-line) !important; background: #21252b !important; box-shadow: none !important; }

.stage-choice,
.stage-choice[data-stage-choice="stage2"],
.stage-choice[data-stage-choice="modifications-only"] {
  transform: none !important;
  border-radius: 8px !important;
  border-color: transparent !important;
  background: transparent !important;
  box-shadow: none !important;
}

.stage-choice span { transform: none !important; font-family: 'Inter', sans-serif !important; font-weight: 600 !important; text-transform: none !important; letter-spacing: 0 !important; }
.stage-choice.is-active { transform: none !important; border-color: var(--v3-red) !important; background: var(--v3-red) !important; box-shadow: none !important; }

.power-tile { border: 1px solid var(--v3-line) !important; border-radius: 10px !important; background: #21252b !important; box-shadow: none !important; }
.power-tile.stage-one { background: #21252b !important; box-shadow: inset 0 0 0 1px var(--v3-red) !important; }
.power-tile strong { font-family: 'Bebas Neue', sans-serif !important; -webkit-text-fill-color: #fff !important; color: #fff !important; text-shadow: none !important; }
.power-tile span { text-transform: none !important; letter-spacing: 0.02em; font-weight: 500; }

.price-box { border: 1px solid var(--v3-line) !important; border-radius: 14px !important; background: #21252b !important; box-shadow: none !important; }
.price-box::before, .price-box::after { display: none !important; }
.price-copy span { background: var(--v3-red) !important; font-family: 'Inter', sans-serif !important; text-transform: none !important; }
.price-row strong { font-family: 'Bebas Neue', sans-serif !important; -webkit-text-fill-color: #fff !important; color: #fff !important; text-shadow: none !important; }
.config-note { color: var(--v3-muted); }

/* --- Listen-/Karten-Komponenten (Unterseiten) --- */
.seo-link-grid article,
.seo-topic-grid article,
.faq-grid details,
.review-card,
.stage-card,
.partner-benefit-grid article,
.motorsport-note-grid article {
  background: var(--v3-panel) !important;
  border: 1px solid var(--v3-line) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
}

.stage-card.featured,
.review-card.featured-review {
  border-color: rgba(225,6,0,.35) !important;
}

.seo-link-grid span,
.seo-topic-grid span,
.service-band span,
.partner-process span {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 18px;
  color: var(--v3-red);
}

.check-list li { color: var(--v3-steel); font-family: 'Inter', sans-serif; }
.check-list li::before {
  clip-path: none !important;
  border-radius: 50% !important;
  width: 7px !important; height: 7px !important;
  top: 11px !important;
  background: var(--v3-red) !important;
  transform: none !important;
  box-shadow: none !important;
}

.stars { color: #f5b942 !important; }
.review-head span {
  transform: none !important;
  border-radius: 50% !important;
  background: var(--v3-metal) !important;
  color: #15171b !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
}

.faq-grid summary { font-family: 'Inter', sans-serif !important; font-weight: 600 !important; }
.faq-grid summary::marker { color: var(--v3-red); }

/* --- Kontaktformular --- */
.contact-form-panel {
  background: var(--v3-bg2) !important;
  border: 1px solid var(--v3-line) !important;
  border-radius: 14px;
  box-shadow: none !important;
}

.contact-form input, .contact-form textarea {
  border: 1px solid var(--v3-line) !important;
  border-left: 1px solid var(--v3-line) !important;
  border-radius: 8px !important;
  background: #0e1014 !important;
  color: #fff !important;
  font-family: 'Inter', sans-serif !important;
}

.contact-form input:focus, .contact-form textarea:focus {
  border-color: var(--v3-red) !important;
  box-shadow: 0 0 0 3px rgba(225,6,0,.18) !important;
}

.contact-form label span {
  color: var(--v3-muted) !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  text-transform: none !important;
  letter-spacing: 0.02em !important;
}

.form-consent span { color: var(--v3-muted); font-weight: 400; }
.mail-link, .mail-link.dark-link { color: #fff !important; font-weight: 600; }

.map-frame { border: 1px solid var(--v3-line) !important; border-radius: 12px; overflow: hidden; }
.map-canvas { position: absolute; inset: 0; width: 100%; height: 100%; background: #0a0c0f; }
.map-frame .map-card { z-index: 2; }
.leaflet-container { background: #0a0c0f; font-family: 'Inter', sans-serif; }
.leaflet-popup-content strong { font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: .03em; }
.map-card { background: rgba(15,17,21,.92) !important; border-color: var(--v3-line2) !important; }
.location-copy p:not(.eyebrow) { color: var(--v3-steel) !important; }

/* --- Footer --- */
.site-footer { background: #0b0c0f !important; border-top: 1px solid var(--v3-line); }
.site-footer__brand { -webkit-text-fill-color: #fff; color: #fff !important; font-family: 'Inter', sans-serif !important; text-transform: none !important; }
.site-footer a:hover { color: var(--v3-red); }

/* --- Cookie-Banner: ruhig + Buttons sofort sichtbar --- */
.cookie-consent { background: #15171b !important; border: 1px solid var(--v3-line2) !important; border-radius: 14px; }
.cookie-consent .button.button--reveal {
  --button-x: 0px !important;
  --button-y: 0px !important;
  opacity: 1 !important;
  transition-delay: 0ms !important;
}

/* --- Seiten-Hero (Unterseiten) --- */
.seo-page-hero,
.partner-hero,
.motorsport-hero {
  background:
    linear-gradient(105deg, rgba(15,17,21,.92) 0%, rgba(15,17,21,.6) 55%, rgba(15,17,21,.3) 100%),
    linear-gradient(0deg, #0f1115 0%, rgba(15,17,21,0) 45%),
    url("hero-werkstatt-vam.jpeg?v=94") center / cover no-repeat !important;
}

.legal-page {
  background:
    linear-gradient(180deg, #15171b 0%, #0f1115 55%, #0c0d10 100%) !important;
}

.legal-page::before { opacity: 0.16 !important; }
.legal-content { background: rgba(21,23,27,.72) !important; border-color: var(--v3-line) !important; }
.legal-content h2 { -webkit-text-fill-color: #fff; color: #fff !important; }

/* --- Hero-Headline: saubere Zeilen, kein hässlicher Umbruch --- */
.hero .hero-content h1 {
  font-size: clamp(34px, 5vw, 68px) !important;
  line-height: 0.96 !important;
  max-width: 16em;
  text-wrap: balance;
}

.hero .hero-content .hero-br { display: none; }

@media (min-width: 760px) {
  .hero .hero-content .hero-br { display: block; }
}

/* --- Fileservice-Demobilder: groß, gestapelt --- */
.fs-show {
  display: grid;
  gap: clamp(18px, 3vw, 28px);
  margin: clamp(28px, 4vw, 46px) auto 0;
  max-width: 1040px;
}

.fs-show figure {
  margin: 0;
  border: 1px solid var(--v3-line);
  border-radius: 14px;
  overflow: hidden;
  background: var(--v3-panel);
}

.fs-show img {
  display: block;
  width: 100%;
  height: auto;
  background: #0a0c0f;
}

.fs-show figcaption {
  padding: 14px 20px 18px;
}

.fs-show figcaption strong {
  display: block;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 21px;
  letter-spacing: 0.03em;
  color: #fff;
}

.fs-show figcaption span {
  display: block;
  margin-top: 3px;
  font-size: 14px;
  line-height: 1.45;
  color: var(--v3-muted);
}

/* --- Urlaubs-Popup --- */
.urlaub-popup {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(8, 9, 11, 0.78);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
}

.urlaub-popup.is-open { display: flex; }
body.urlaub-lock { overflow: hidden; }

.urlaub-card {
  position: relative;
  width: min(560px, 100%);
  max-height: calc(100dvh - 40px);
  overflow: auto;
  background: linear-gradient(160deg, #23262c, #15171b);
  border: 1px solid var(--v3-line2);
  border-radius: 16px;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.6);
}

.urlaub-media { position: relative; line-height: 0; }
.urlaub-media img { display: block; width: 100%; height: auto; }

.urlaub-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: clamp(22px, 3vw, 30px);
}

.urlaub-body h2 { margin: 0; font-size: clamp(30px, 4vw, 42px); }
.urlaub-body p { margin: 0; color: var(--v3-steel); font-size: 15px; line-height: 1.55; }
.urlaub-body strong { color: #fff; }
.urlaub-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; }

.urlaub-close {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 3;
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  border: 1px solid var(--v3-line2);
  background: rgba(8, 9, 11, 0.62);
  color: #fff;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  transition: background 150ms ease, border-color 150ms ease;
}

.urlaub-close:hover {
  background: var(--v3-red);
  border-color: var(--v3-red);
}

@media (max-width: 620px) {
  .urlaub-body { padding: 20px; }
}

/* Zurück-zur-Startseite Leiste */
.v3-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--v3-steel);
}
.v3-back .arr { color: var(--v3-red); }
.v3-back:hover { color: #fff; }

/* --- Hero fast bildschirmfüllend (Desktop) --- */
@media (min-width: 921px) {
  .hero.hero-compact {
    min-height: 94vh;
    align-items: center;
    padding-top: 130px;
    padding-bottom: clamp(50px, 7vw, 96px);
  }
  .hero.hero-compact .hero-content h1 {
    font-size: clamp(56px, 6.9vw, 98px) !important;
  }
  .hero.hero-compact .hero-content .hero-copy {
    font-size: 20px;
    max-width: 640px;
  }
  .hero.hero-compact .hero-content .eyebrow { font-size: 14px; }
}

/* Hero-Text präsenter über dem Video (Desktop & Mobil) */
.hero .hero-content .accent { text-shadow: 0 0 26px rgba(225, 6, 0, 0.45), 0 2px 16px rgba(0, 0, 0, 0.5); }
.hero .hero-content .hero-copy { text-shadow: 0 1px 14px rgba(0, 0, 0, 0.55); }

/* Wrapper wirken nur auf Mobil – auf Desktop transparent für das Layout */
.hero-top, .hero-bottom { display: contents; }

@media (max-width: 620px) {
  .hero .hero-content h1 { font-size: clamp(34px, 9.5vw, 42px) !important; }
  .hero .hero-content .hero-copy { font-size: 17px; }
  .hero .hero-content .eyebrow { font-size: 13px; }

  /* Mobil: Überschrift oben (tiefer), restlicher Text unten – je mit dunkler Maske */
  .hero.hero-compact {
    min-height: 86vh;
    align-items: stretch;
    padding-top: 120px;
    padding-bottom: clamp(28px, 7vw, 50px);
  }
  .hero.hero-compact .hero-content {
    display: flex;
    flex-direction: column;
  }
  .hero.hero-compact .hero-top,
  .hero.hero-compact .hero-bottom {
    display: block;
    position: relative;
    isolation: isolate;
    padding: 6px 2px;
  }
  /* weicher, verschwommener dunkler Nebel hinter dem Text (kein Kasten) */
  .hero.hero-compact .hero-top::before,
  .hero.hero-compact .hero-bottom::before {
    content: "";
    position: absolute;
    inset: -20px -16px;
    z-index: -1;
    pointer-events: none;
    background: radial-gradient(120% 90% at 50% 50%, rgba(5, 6, 9, 0.72) 0%, rgba(5, 6, 9, 0.44) 46%, rgba(5, 6, 9, 0) 80%);
    filter: blur(16px);
  }
  .hero.hero-compact .hero-content h1 { text-shadow: 0 2px 20px rgba(0, 0, 0, 0.7); }
  .hero.hero-compact .hero-bottom { margin-top: auto; }
  .hero.hero-compact .hero-overlay {
    background: linear-gradient(180deg, rgba(7, 8, 10, 0.42) 0%, rgba(7, 8, 10, 0) 30%, rgba(7, 8, 10, 0) 62%, rgba(7, 8, 10, 0.4) 100%) !important;
  }
}

/* --- Weicher Übergang Hero -> Konfigurator (langer Verlauf, keine harte Kante) --- */
.hero.hero-compact .hero-media-video::after {
  height: clamp(200px, 30vh, 340px) !important;
  background: linear-gradient(180deg, rgba(20, 22, 26, 0) 0%, rgba(20, 22, 26, 0.6) 45%, #14161a 100%) !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
}

.hero.hero-compact::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: clamp(180px, 26vh, 300px);
  z-index: 4;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(20, 22, 26, 0) 0%, rgba(20, 22, 26, 0.55) 55%, #14161a 100%);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 62%);
  mask-image: linear-gradient(180deg, transparent 0%, #000 62%);
}

/* Konfigurator oben ebenfalls in denselben Ton auslaufen lassen */
.configurator {
  background: linear-gradient(180deg, #14161a 0%, rgba(20, 22, 26, 0) 22%) !important;
}

/* Mobil: kein Blur über den Buttons — nur sanfter Farbverlauf, kürzer */
@media (max-width: 920px) {
  .hero.hero-compact::after {
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
    height: clamp(60px, 10vh, 110px);
    background: linear-gradient(180deg, rgba(20, 22, 26, 0) 0%, #14161a 100%);
    -webkit-mask-image: none;
    mask-image: none;
  }
  .hero.hero-compact .hero-media-video::after {
    height: clamp(90px, 14vh, 150px) !important;
  }
}
