/* ==========================================================================
   RB MOTORSPORT — styles.css
   Dunkel · cineastisch · schnell.  Eine Datei, alle Seiten.
   --------------------------------------------------------------------------
   INHALT
   1. Eigene Schrift einbinden  (kein Google Font)
   2. Design-Tokens (Farben, Typo, Maße)
   3. Reset & Basis
   4. Typografie & Layout-Helfer
   5. Buttons
   6. Header / Navigation
   7. Hero + Startampel-Intro
   8. Sektions-Bausteine (Eyebrow, Stats, ...)
   9. Rennkalender (Timing-Board)
   10. Das Auto (Datenblatt)
   11. Galerie + Lightbox
   12. Team
   13. Partner
   14. CTA-Band
   15. Footer
   16. Subhero (Unterseiten) + Fließtext/Recht
   17. Kontaktformular
   18. Reveal-Animationen / Reduced Motion
   19. Responsive
   ========================================================================== */

/* 1. EIGENE SCHRIFT ------------------------------------------------------- */
/* >>> HIER deine Schrift einsetzen.  Lege die Dateien in /fonts ab und
   entkommentiere die passenden Blöcke. Formate woff2 + woff empfohlen.
   Solange nichts geladen ist, greift automatisch der Fallback-Stack unten. */
/*
@font-face {
  font-family: "RB Display";
  src: url("fonts/RBDisplay.woff2") format("woff2"),
       url("fonts/RBDisplay.woff")  format("woff");
  font-weight: 700 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RB Text";
  src: url("fonts/RBText.woff2") format("woff2"),
       url("fonts/RBText.woff")  format("woff");
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}
*/

/* 2. DESIGN-TOKENS -------------------------------------------------------- */
:root {
  /* Nicht-ganz-Schwarz (kühl, leichter Blaustich) */
  --ink:      #0A0C11;
  --ink-2:    #0E121A;
  --steel:    #141925;
  --steel-2:  #19202E;
  --line:     #232b3a;
  --line-2:   #303a4f;

  /* Schimmerndes Blau */
  --blue-deep:   #112258;
  --blue:        #1E45C0;
  --blue-bright: #4470F4;
  --blue-glow:   rgba(50, 100, 244, .45);

  /* Gedämpftes, dunkles Rot */
  --red:      #C42B36;
  --red-soft: #d8434e;
  --red-deep: #7c1a22;

  /* Text */
  --paper:  #EEF1F8;
  --mist:   #939cb1;
  --mist-2: #626c80;

  /* Schriften — eigene Schrift steht zuerst, dann robuste Fallbacks */
  --font-display: "RB Display", "Arial Black", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --font-body:    "RB Text", "Helvetica Neue", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-mono:    ui-monospace, "SF Mono", "Cascadia Mono", "Roboto Mono", Menlo, Consolas, monospace;

  /* Effekte */
  --sheen: linear-gradient(115deg,
            var(--blue-deep) 0%, var(--blue) 40%,
            var(--blue-bright) 50%, var(--blue) 60%, var(--blue-deep) 100%);
  --sheen-text: linear-gradient(100deg,
            #9fb6ff 0%, #eaf0ff 12%, #6f93ff 30%, #cdd9ff 50%, #6f93ff 70%, #9fb6ff 100%);

  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 3px;
  --ease: cubic-bezier(.22, 1, .36, 1);

  /* Feine Körnung für Tiefe */
  --grain: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
}

/* 3. RESET & BASIS -------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: var(--font-body);
  background: var(--ink);
  color: var(--paper);
  line-height: 1.6;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
body::before { /* Körnung über allem, dezent */
  content: "";
  position: fixed; inset: 0;
  background-image: var(--grain);
  opacity: .035; pointer-events: none; z-index: 9999;
  mix-blend-mode: overlay;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
:focus-visible {
  outline: 2px solid var(--blue-bright);
  outline-offset: 3px;
  border-radius: 1px;
}
::selection { background: var(--blue); color: #fff; }

/* 4. TYPOGRAFIE & LAYOUT -------------------------------------------------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }

.display {
  font-family: var(--font-display);
  font-weight: 900;
  line-height: .9;
  letter-spacing: -.01em;
  text-transform: uppercase;
}
h1, h2, h3 { font-family: var(--font-display); font-weight: 900; text-transform: uppercase; line-height: .95; }
h2 { font-size: clamp(2rem, 5.2vw, 3.9rem); letter-spacing: -.01em; }
h3 { font-size: clamp(1.2rem, 2.4vw, 1.7rem); letter-spacing: .01em; }

p { color: var(--mist); }
strong { color: var(--paper); font-weight: 700; }

.section { padding-block: clamp(72px, 11vw, 148px); position: relative; }
.section--tight { padding-block: clamp(56px, 8vw, 104px); }

/* Eyebrow: kleines Mono-Label mit Livery-Strich */
.eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-mono);
  font-size: .74rem; letter-spacing: .28em; text-transform: uppercase;
  color: var(--mist); margin-bottom: 22px;
}
.eyebrow::before {
  content: ""; width: 30px; height: 7px; border-radius: 1px;
  background: var(--sheen); background-size: 200% 100%;
  box-shadow: inset -6px 0 0 var(--red);
}
.eyebrow--center { justify-content: center; }

.lead { font-size: clamp(1.05rem, 1.8vw, 1.3rem); color: var(--paper); line-height: 1.55; max-width: 60ch; }
.muted { color: var(--mist); }

.head { max-width: 760px; }
.head--center { margin-inline: auto; text-align: center; }

/* Livery-Doppellinie als wiederkehrendes Element */
.rule {
  height: 3px; width: 100%; border-radius: 2px;
  background: linear-gradient(90deg, var(--blue) 0 72%, var(--red) 72% 100%);
}

/* 5. BUTTONS -------------------------------------------------------------- */
.btn {
  --bg: var(--blue);
  position: relative; display: inline-flex; align-items: center; gap: .7em;
  font-family: var(--font-display); font-weight: 800; text-transform: uppercase;
  letter-spacing: .08em; font-size: .92rem;
  padding: 1.02em 1.7em; border: 0; cursor: pointer; overflow: hidden;
  color: #fff; background: var(--bg);
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 9px), calc(100% - 9px) 100%, 0 100%);
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
  isolation: isolate;
}
.btn::after { /* Sheen-Sweep */
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(115deg, transparent 35%, rgba(255,255,255,.35) 50%, transparent 65%);
  transform: translateX(-120%); transition: transform .6s var(--ease);
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 14px 34px -12px var(--blue-glow); }
.btn:hover::after { transform: translateX(120%); }
.btn--red { --bg: var(--red); }
.btn--red:hover { box-shadow: 0 14px 34px -12px rgba(196,43,54,.55); }
.btn--ghost {
  background: transparent; color: var(--paper);
  box-shadow: inset 0 0 0 1.5px var(--line-2);
}
.btn--ghost:hover { box-shadow: inset 0 0 0 1.5px var(--blue-bright); }
.btn svg { width: 1.05em; height: 1.05em; }

/* 6. HEADER / NAV --------------------------------------------------------- */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 1000;
  transition: background .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s var(--ease);
  border-bottom: 1px solid transparent;
}
.site-header.is-scrolled {
  background: rgba(8, 10, 15, .82);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom-color: var(--line);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 78px; }
.brand { display: inline-flex; align-items: center; gap: 12px; font-family: var(--font-display); font-weight: 900; text-transform: uppercase; letter-spacing: .02em; font-size: 1.18rem; }
/* Logo-Slot: zeigt img/logo.svg sobald vorhanden, sonst den Schriftzug-Fallback */
.brand__logo { display: none; height: 56px; width: auto; max-width: 280px; object-fit: contain; }
.brand__fallback { display: inline-flex; align-items: center; gap: 12px; }
.site-footer .brand__logo { height: 46px; }
@media (max-width: 560px) { .brand__logo { height: 44px; max-width: 200px; } }
.brand__mark {
  width: 34px; height: 34px; display: grid; place-items: center; flex: 0 0 auto;
  background: var(--sheen); background-size: 200% 100%; color: #fff;
  font-size: .92rem; font-weight: 900;
  clip-path: polygon(0 0, 100% 0, 100% 72%, 72% 100%, 0 100%);
  box-shadow: inset -3px 0 0 var(--red);
}
.brand__mark span { transform: skewX(-7deg); }
.brand b { color: var(--paper); }
.brand i { color: var(--mist-2); font-style: normal; font-weight: 400; font-family: var(--font-mono); font-size: .82rem; letter-spacing: .12em; }

.nav__links { display: flex; align-items: center; gap: 34px; }
.nav__links a {
  font-family: var(--font-mono); font-size: .78rem; letter-spacing: .16em;
  text-transform: uppercase; color: var(--mist); position: relative; padding: 6px 0;
  transition: color .25s;
}
.nav__links a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; height: 2px; width: 0;
  background: var(--red); transition: width .3s var(--ease);
}
.nav__links a:hover, .nav__links a[aria-current="page"] { color: var(--paper); }
.nav__links a:hover::after, .nav__links a[aria-current="page"]::after { width: 100%; }
.nav__cta { margin-left: 6px; }
.nav__cta .btn { padding: .72em 1.25em; font-size: .82rem; }

.nav__toggle {
  display: none; width: 46px; height: 40px; background: none; border: 1px solid var(--line-2);
  border-radius: 2px; cursor: pointer; position: relative;
}
.nav__toggle span, .nav__toggle span::before, .nav__toggle span::after {
  content: ""; position: absolute; left: 50%; top: 50%; width: 20px; height: 2px;
  background: var(--paper); transform: translate(-50%, -50%); transition: .3s var(--ease);
}
.nav__toggle span::before { transform: translate(-50%, -7px); }
.nav__toggle span::after  { transform: translate(-50%,  7px); }
.nav.is-open .nav__toggle span { background: transparent; }
.nav.is-open .nav__toggle span::before { transform: translate(-50%, 0) rotate(45deg); }
.nav.is-open .nav__toggle span::after  { transform: translate(-50%, 0) rotate(-45deg); }

/* 7. HERO + STARTAMPEL ---------------------------------------------------- */
.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; overflow: hidden; }
.hero__bg { position: absolute; inset: 0; z-index: 0; background: var(--ink); }
.hero__bg::before { /* blauer Glow + Speed-Linien */
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(120% 80% at 78% -10%, rgba(40,90,240,.30), transparent 55%),
    radial-gradient(90% 70% at 10% 110%, rgba(196,43,54,.16), transparent 60%),
    repeating-linear-gradient(115deg, rgba(255,255,255,.018) 0 2px, transparent 2px 9px);
}
.hero__bg::after { /* tiefes Vignette unten für Lesbarkeit */
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(8,10,15,.55) 70%, var(--ink) 100%);
}
/* driftende Lichtspuren */
.streak { position: absolute; height: 2px; width: 60vw; opacity: .5; filter: blur(.4px);
  background: linear-gradient(90deg, transparent, var(--blue-bright), transparent);
  animation: streak 9s var(--ease) infinite; }
.streak.s1 { top: 38%; animation-delay: 0s; }
.streak.s2 { top: 58%; width: 40vw; opacity: .35; background: linear-gradient(90deg, transparent, var(--red-soft), transparent); animation-duration: 11s; animation-delay: 2.4s; }
.streak.s3 { top: 72%; width: 70vw; opacity: .25; animation-duration: 13s; animation-delay: 1.2s; }
@keyframes streak { 0% { transform: translateX(-110%); } 55%,100% { transform: translateX(160%); } }

.hero__media { /* Großes Start-/Action-Bild (img/hero.*) — erscheint automatisch */
  position: absolute; inset: 0; z-index: 1;
  background-size: cover; background-position: center;
  opacity: 0; transition: opacity .9s var(--ease);
}
.hero__media.has-img { opacity: 1; }
.hero__media.has-img::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(8,10,15,.5) 0%, rgba(8,10,15,.25) 38%, rgba(8,10,15,.9) 100%);
}

.hero__inner { position: relative; z-index: 2; width: 100%; padding-bottom: clamp(48px, 9vh, 120px); padding-top: 120px; }
.hero__tag {
  display: inline-flex; align-items: center; gap: 12px; margin-bottom: 28px;
  font-family: var(--font-mono); font-size: .76rem; letter-spacing: .24em; text-transform: uppercase; color: var(--mist);
}
.hero__tag .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--red); box-shadow: 0 0 0 0 rgba(196,43,54,.6); animation: pulse 2.4s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(196,43,54,.55); } 70% { box-shadow: 0 0 0 10px rgba(196,43,54,0); } 100% { box-shadow: 0 0 0 0 rgba(196,43,54,0); } }

.hero__title { font-size: clamp(2.6rem, 9.5vw, 8.2rem); letter-spacing: -.02em; }
.hero__title .ln { display: block; overflow: hidden; }
.hero__title .ln span { display: block; transform: translateY(105%); animation: rise .9s var(--ease) forwards; }
.hero__title .ln:nth-child(2) span { animation-delay: .1s; }
.hero__title .accent {
  background: var(--sheen-text); -webkit-background-clip: text; background-clip: text; color: transparent;
  background-size: 220% 100%; animation: rise .9s var(--ease) forwards, shimmer 6s linear infinite 1s;
}
@keyframes rise { to { transform: translateY(0); } }
@keyframes shimmer { to { background-position: 220% 0; } }

.hero__sub { margin-top: 26px; max-width: 46ch; font-size: clamp(1rem, 1.7vw, 1.22rem); color: var(--paper); opacity: 0; animation: fade .8s var(--ease) .5s forwards; }
.hero__actions { margin-top: 36px; display: flex; flex-wrap: wrap; gap: 14px; opacity: 0; animation: fade .8s var(--ease) .65s forwards; }
@keyframes fade { to { opacity: 1; } }

.hero__meta {
  margin-top: 54px; display: flex; flex-wrap: wrap; gap: clamp(28px, 5vw, 64px);
  border-top: 1px solid var(--line); padding-top: 26px; opacity: 0; animation: fade .8s var(--ease) .8s forwards;
}
.hero__meta .m { display: flex; flex-direction: column; gap: 4px; }
.hero__meta .m b { font-family: var(--font-display); font-size: clamp(1.6rem, 3vw, 2.4rem); color: var(--paper); line-height: 1; }
.hero__meta .m span { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: var(--mist-2); }

.scrollcue {
  position: absolute; right: var(--gutter); bottom: 34px; z-index: 3;
  display: flex; align-items: center; gap: 12px; writing-mode: vertical-rl;
  font-family: var(--font-mono); font-size: .68rem; letter-spacing: .26em; text-transform: uppercase; color: var(--mist-2);
}
.scrollcue .bar { writing-mode: horizontal-tb; width: 1px; height: 46px; background: linear-gradient(var(--blue-bright), transparent); }

/* Startampel-Intro (nur Startseite) */
#intro {
  position: fixed; inset: 0; z-index: 5000; background: #05060a;
  display: grid; place-items: center; transition: opacity .7s var(--ease), visibility .7s;
}
#intro.is-done { opacity: 0; visibility: hidden; }
.intro__stage { display: flex; flex-direction: column; align-items: center; gap: clamp(26px, 5vw, 52px); }
.intro__logo { display: grid; place-items: center; min-height: clamp(84px, 17vw, 190px); }
.intro__logo-img, .intro__logo-fallback {
  grid-area: 1 / 1; opacity: 0; transform: scale(1.12);
  transition: opacity .6s var(--ease), transform .75s var(--ease); will-change: opacity, transform;
}
.intro__logo-img { display: none; height: clamp(84px, 17vw, 190px); width: auto; max-width: 78vw; }
.intro__logo-fallback {
  font-family: var(--font-display); font-weight: 900; text-transform: uppercase;
  font-size: clamp(2.2rem, 8.5vw, 5.4rem); letter-spacing: -.01em; line-height: 1; color: var(--paper); white-space: nowrap;
}
.intro__logo-fallback b { background: var(--sheen-text); -webkit-background-clip: text; background-clip: text; color: transparent; background-size: 220% 100%; }
#intro.show-logo .intro__logo-img, #intro.show-logo .intro__logo-fallback { opacity: 1; transform: scale(1); }
#intro.shrink-logo .intro__logo-img, #intro.shrink-logo .intro__logo-fallback { transform: scale(.52); }
.lights { display: flex; gap: clamp(10px, 2.4vw, 22px); }
.lights .pod { display: flex; flex-direction: column; gap: clamp(8px, 1.6vw, 14px); padding: clamp(8px,1.6vw,14px); background: #0b0d13; border: 1px solid #1a1f2b; border-radius: 4px; }
.lights .bulb { width: clamp(22px, 4.4vw, 40px); height: clamp(22px, 4.4vw, 40px); border-radius: 50%; background: #1a0608; box-shadow: inset 0 0 0 2px #220a0c; transition: all .25s; }
.lights .pod.on .bulb { background: radial-gradient(circle at 35% 30%, #ff5a63, var(--red) 60%, #5e1219); box-shadow: 0 0 22px 2px rgba(196,43,54,.7), inset 0 0 6px rgba(255,255,255,.4); }
.intro__label { position: absolute; bottom: 12%; font-family: var(--font-mono); font-size: .72rem; letter-spacing: .3em; text-transform: uppercase; color: var(--mist-2); }

/* 8. SEKTIONS-BAUSTEINE --------------------------------------------------- */
.split { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(32px, 6vw, 84px); align-items: center; }
.split--media-first { grid-template-columns: .95fr 1.05fr; }

/* Bild-Platzhalter: sieht bewusst nach Design-System aus */
.media {
  position: relative; overflow: hidden; background: var(--ink-2); border: 1px solid var(--line);
  border-radius: var(--radius); aspect-ratio: 4 / 3;
  background-image: var(--ph-img, none); background-size: cover; background-position: center;
}
.media::before { /* atmosphärischer Verlauf, falls kein Bild gesetzt */
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(80% 70% at 70% 0%, rgba(40,90,240,.22), transparent 60%),
    repeating-linear-gradient(118deg, rgba(255,255,255,.02) 0 2px, transparent 2px 11px),
    linear-gradient(160deg, #0d121d, #0a0c11);
}
.media.has-img::before { display: none; }
.media__tag {
  position: absolute; left: 14px; bottom: 14px; z-index: 2;
  font-family: var(--font-mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--mist); background: rgba(8,10,15,.6); border: 1px solid var(--line);
  padding: 6px 10px; border-radius: 2px; backdrop-filter: blur(6px);
}
.media__tag::before { content: "▣  "; color: var(--blue-bright); }
.media__corner { position: absolute; right: 0; top: 0; width: 64px; height: 64px; z-index: 2;
  background: linear-gradient(135deg, transparent 50%, rgba(196,43,54,.9) 50%); }
.media--tall { aspect-ratio: 3 / 4; }
.media--wide { aspect-ratio: 16 / 9; }

.prose-block p + p { margin-top: 1.1em; }
.prose-block .lead + p { margin-top: 1.3em; }

/* Stats / Counter */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.stat { background: var(--ink-2); padding: clamp(22px, 3vw, 36px); position: relative; }
.stat::after { content: ""; position: absolute; left: 0; top: 0; width: 3px; height: 100%; background: var(--sheen); background-size: 100% 200%; opacity: .8; }
.stat b { display: block; font-family: var(--font-display); font-size: clamp(2.2rem, 5vw, 3.6rem); line-height: 1; color: var(--paper); }
.stat b .u { color: var(--red-soft); font-size: .5em; vertical-align: super; margin-left: 2px; }
.stat span { display: block; margin-top: 10px; font-family: var(--font-mono); font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--mist); }

/* 9. RENNKALENDER (TIMING-BOARD) ----------------------------------------- */
.calendar { border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; background: var(--ink-2); }
.cal__next {
  display: grid; grid-template-columns: auto 1fr auto; gap: clamp(18px, 4vw, 48px); align-items: center;
  padding: clamp(24px, 4vw, 40px); background: linear-gradient(120deg, var(--steel), var(--ink-2));
  border-bottom: 1px solid var(--line); position: relative;
}
.cal__next::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--red); }
.cal__next .tag { font-family: var(--font-mono); font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: var(--red-soft); }
.cal__next h3 { margin-top: 6px; font-size: clamp(1.4rem, 3vw, 2.1rem); }
.cal__next .where { margin-top: 6px; font-family: var(--font-mono); font-size: .82rem; color: var(--mist); letter-spacing: .04em; }
.countdown { display: flex; gap: 14px; }
.countdown .c { text-align: center; min-width: 58px; }
.countdown .c b { font-family: var(--font-mono); font-size: clamp(1.5rem, 3vw, 2.2rem); color: var(--paper); line-height: 1; font-variant-numeric: tabular-nums; }
.countdown .c span { display: block; margin-top: 6px; font-family: var(--font-mono); font-size: .62rem; letter-spacing: .18em; text-transform: uppercase; color: var(--mist-2); }
.countdown .sep { align-self: flex-start; color: var(--line-2); font-size: 1.6rem; line-height: 1; }

.cal__row {
  display: grid; grid-template-columns: 64px 132px 1fr auto 120px; gap: clamp(12px, 2.4vw, 28px);
  align-items: center; padding: 18px clamp(20px, 4vw, 40px);
  border-bottom: 1px solid var(--line); font-family: var(--font-mono); transition: background .25s;
}
.cal__row:last-child { border-bottom: 0; }
.cal__row:hover { background: var(--steel); }
.cal__row .rnd { color: var(--mist-2); font-size: .78rem; letter-spacing: .08em; }
.cal__row .date { color: var(--paper); font-size: .92rem; font-variant-numeric: tabular-nums; }
.cal__row .date small { display: block; color: var(--mist-2); font-size: .72rem; }
.cal__row .track { font-family: var(--font-body); color: var(--paper); font-weight: 600; letter-spacing: 0; }
.cal__row .track em { display: block; font-style: normal; color: var(--mist); font-size: .82rem; font-weight: 400; }
.cal__row .series { color: var(--mist); font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; }
.cal__row .res { justify-self: end; }
.badge {
  font-family: var(--font-mono); font-size: .72rem; letter-spacing: .08em; padding: 5px 11px; border-radius: 2px;
  border: 1px solid var(--line-2); color: var(--mist);
}
.badge--p1 { color: #ffd76a; border-color: rgba(255,215,106,.4); background: rgba(255,215,106,.08); }
.badge--podium { color: #cfd9ff; border-color: rgba(68,112,244,.5); background: rgba(68,112,244,.1); }
.badge--next { color: var(--red-soft); border-color: rgba(196,43,54,.5); background: rgba(196,43,54,.1); }

/* 10. DAS AUTO (DATENBLATT) ---------------------------------------------- */
.car { position: relative; }
.car__bg { position: absolute; inset: 0; background: radial-gradient(70% 60% at 50% 40%, rgba(40,90,240,.14), transparent 70%); z-index: 0; }
.spec { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.spec .row { background: var(--ink-2); padding: 18px 22px; display: flex; flex-direction: column; gap: 6px; }
.spec .row .k { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; color: var(--mist-2); }
.spec .row .v { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.1rem, 2vw, 1.5rem); color: var(--paper); text-transform: uppercase; letter-spacing: .01em; }
.spec .row .v small { font-family: var(--font-mono); font-weight: 400; font-size: .58em; color: var(--mist); letter-spacing: .06em; margin-left: 4px; text-transform: none; }
.chip-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.chip { font-family: var(--font-mono); font-size: .74rem; letter-spacing: .08em; color: var(--mist); border: 1px solid var(--line-2); padding: 7px 13px; border-radius: 2px; }
.chip::before { content: "› "; color: var(--blue-bright); }

/* 11. GALERIE + LIGHTBOX -------------------------------------------------- */
.gallery { display: grid; grid-template-columns: repeat(12, 1fr); gap: 14px; }
.shot { position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); cursor: pointer; background: var(--ink-2); aspect-ratio: 4/3; }
.shot.has-img { background-size: cover; background-position: center; }
.shot::before { content: ""; position: absolute; inset: 0; background: radial-gradient(70% 70% at 60% 20%, rgba(40,90,240,.18), transparent), linear-gradient(150deg, #0d121d, #0a0c11); transition: transform .6s var(--ease); }
.shot.has-img::before { display: none; }
.shot::after { content: attr(data-label); position: absolute; left: 12px; bottom: 12px; font-family: var(--font-mono); font-size: .66rem; letter-spacing: .12em; text-transform: uppercase; color: var(--mist); z-index: 2; }
.shot .zoom { position: absolute; inset: 0; z-index: 3; opacity: 0; display: grid; place-items: center; background: rgba(8,10,15,.35); transition: opacity .3s; }
.shot .zoom svg { width: 30px; height: 30px; color: #fff; }
.shot:hover .zoom { opacity: 1; }
.shot:hover::before { transform: scale(1.06); }
.shot.is-img:hover { /* falls Bild gesetzt: leichter Zoom über Hintergrundbild */ }
.shot.span-6 { grid-column: span 6; }
.shot.span-4 { grid-column: span 4; }
.shot.span-8 { grid-column: span 8; aspect-ratio: 16/9; }
.shot.span-12 { grid-column: span 12; aspect-ratio: 21/9; }

.lightbox { position: fixed; inset: 0; z-index: 4000; background: rgba(5,6,10,.92); backdrop-filter: blur(8px); display: none; place-items: center; padding: 24px; }
.lightbox.is-open { display: grid; }
.lightbox__stage { position: relative; width: min(1100px, 92vw); aspect-ratio: 16/9; border: 1px solid var(--line-2); border-radius: var(--radius); overflow: hidden; background: #0a0c11; background-size: cover; background-position: center; }
.lightbox__stage::before { content: ""; position: absolute; inset: 0; background: radial-gradient(60% 60% at 50% 30%, rgba(40,90,240,.2), transparent), linear-gradient(150deg, #11161f, #0a0c11); }
.lightbox__stage.has-img::before { display: none; }
.lightbox__cap { position: absolute; left: 16px; bottom: 14px; z-index: 2; font-family: var(--font-mono); font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; color: var(--paper); }
.lb-btn { position: absolute; z-index: 3; width: 52px; height: 52px; display: grid; place-items: center; background: rgba(8,10,15,.6); border: 1px solid var(--line-2); color: #fff; cursor: pointer; border-radius: 2px; transition: .25s; }
.lb-btn:hover { background: var(--blue); border-color: var(--blue); }
.lb-prev { left: -8px; top: 50%; transform: translateY(-50%); }
.lb-next { right: -8px; top: 50%; transform: translateY(-50%); }
.lb-close { top: -64px; right: 0; }
.lb-btn svg { width: 20px; height: 20px; }

/* 12. TEAM ---------------------------------------------------------------- */
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.member { position: relative; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; background: var(--ink-2); transition: transform .4s var(--ease), border-color .4s var(--ease); }
.member:hover { transform: translateY(-6px); border-color: var(--line-2); }
.member__img { aspect-ratio: 3/4; position: relative; background-size: cover; background-position: center; }
.member__img::before { content: ""; position: absolute; inset: 0; background: radial-gradient(70% 60% at 50% 10%, rgba(40,90,240,.18), transparent), linear-gradient(160deg, #11161f, #0a0c11); }
.member__img.has-img::before { display: none; }
.member__img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 45%, rgba(10,12,17,.92)); }
.member__no { position: absolute; top: 14px; left: 14px; z-index: 2; font-family: var(--font-display); font-weight: 900; font-size: 1.4rem; color: rgba(255,255,255,.14); }
.member__body { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: 18px 20px; }
.member__role { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: var(--red-soft); }
.member__name { font-family: var(--font-display); font-weight: 900; text-transform: uppercase; font-size: 1.3rem; margin-top: 4px; line-height: 1; }
.member__line { width: 28px; height: 3px; margin-top: 10px; background: var(--sheen); background-size: 200% 100%; box-shadow: inset -5px 0 0 var(--red); }
.member--lead { grid-column: span 1; }
.member--lead .member__img { aspect-ratio: 3/4; }

/* 13. PARTNER ------------------------------------------------------------- */
.partners { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.partner { background: var(--ink-2); aspect-ratio: 5/2; display: grid; place-items: center; transition: background .3s; }
.partner:hover { background: var(--steel); }
.partner span { font-family: var(--font-mono); font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--mist-2); }
.partner img { max-height: 46px; width: auto; opacity: .85; filter: grayscale(1) brightness(1.4); transition: .3s; }
.partner:hover img { opacity: 1; filter: none; }

/* 14. CTA-BAND ------------------------------------------------------------ */
.cta {
  position: relative; overflow: hidden; border-radius: var(--radius);
  background: linear-gradient(120deg, var(--blue-deep), #0c1430 60%, var(--ink-2));
  border: 1px solid var(--line-2); padding: clamp(40px, 7vw, 88px);
}
.cta::before { content: ""; position: absolute; right: -10%; top: -40%; width: 60%; height: 180%; background: radial-gradient(closest-side, var(--blue-glow), transparent); }
.cta::after { content: ""; position: absolute; left: 0; bottom: 0; height: 4px; width: 100%; background: linear-gradient(90deg, var(--blue) 0 70%, var(--red) 70% 100%); }
.cta__inner { position: relative; z-index: 2; max-width: 720px; }
.cta h2 { font-size: clamp(2rem, 5vw, 3.4rem); }
.cta p { margin-top: 16px; color: #cfd6e8; font-size: 1.08rem; }
.cta .hero__actions { animation: none; opacity: 1; }

/* 15. FOOTER -------------------------------------------------------------- */
.site-footer { border-top: 1px solid var(--line); background: var(--ink-2); padding-block: clamp(48px, 7vw, 84px) 28px; }
.footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: clamp(28px, 4vw, 56px); }
.footer__brand .brand { font-size: 1.3rem; margin-bottom: 16px; }
.footer__brand p { max-width: 34ch; font-size: .94rem; }
.footer__col h4 { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--mist-2); margin-bottom: 16px; }
.footer__col a { display: block; color: var(--mist); padding: 5px 0; font-size: .95rem; transition: color .2s; }
.footer__col a:hover { color: var(--paper); }
.socials { display: flex; gap: 10px; margin-top: 18px; }
.socials a { width: 40px; height: 40px; display: grid; place-items: center; border: 1px solid var(--line-2); border-radius: 2px; color: var(--mist); transition: .25s; }
.socials a:hover { color: #fff; border-color: var(--blue); background: var(--blue); }
.socials svg { width: 18px; height: 18px; }
.footer__bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 14px; align-items: center; margin-top: clamp(36px, 5vw, 56px); padding-top: 22px; border-top: 1px solid var(--line); }
.footer__bottom p, .footer__bottom a { font-family: var(--font-mono); font-size: .74rem; letter-spacing: .06em; color: var(--mist-2); }
.footer__bottom a:hover { color: var(--paper); }
.footer__legal { display: flex; gap: 20px; }

/* 16. SUBHERO + FLIESSTEXT/RECHT ----------------------------------------- */
.subhero { position: relative; padding-top: 168px; padding-bottom: clamp(40px, 7vw, 84px); overflow: hidden; }
.subhero__bg { position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(90% 80% at 85% -20%, rgba(40,90,240,.22), transparent 55%),
    repeating-linear-gradient(115deg, rgba(255,255,255,.015) 0 2px, transparent 2px 10px),
    var(--ink); }
.subhero__bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, var(--ink)); }
.subhero__inner { position: relative; z-index: 2; }
.subhero .eyebrow { margin-bottom: 18px; }
.subhero h1 { font-size: clamp(2.6rem, 8vw, 6rem); letter-spacing: -.02em; }
.subhero h1 .accent { background: var(--sheen-text); -webkit-background-clip: text; background-clip: text; color: transparent; background-size: 220% 100%; }
.subhero p { margin-top: 22px; max-width: 56ch; font-size: clamp(1rem, 1.7vw, 1.2rem); color: var(--paper); }
.crumbs { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--mist-2); margin-bottom: 26px; }
.crumbs a:hover { color: var(--paper); }
.crumbs span { color: var(--mist); }

.prose { max-width: 760px; }
.prose h2 { font-size: clamp(1.5rem, 3.4vw, 2.2rem); margin-top: 2.2em; margin-bottom: .7em; }
.prose h2:first-child { margin-top: 0; }
.prose h3 { font-size: 1.15rem; margin-top: 1.8em; margin-bottom: .5em; color: var(--paper); }
.prose p { margin-bottom: 1.1em; }
.prose ul.dash { margin: 0 0 1.2em; }
ul.dash { list-style: none; padding: 0; }
ul.dash li { position: relative; padding-left: 22px; margin-bottom: .5em; color: var(--mist); }
ul.dash li::before { content: ""; position: absolute; left: 0; top: .72em; width: 12px; height: 2px; background: var(--red); }
.prose a.link { color: var(--blue-bright); text-decoration: underline; text-underline-offset: 3px; }
.prose a.link:hover { color: #fff; }
.prose .meta-card { border: 1px solid var(--line); border-radius: var(--radius); background: var(--ink-2); padding: 24px 26px; margin-bottom: 1.6em; font-family: var(--font-mono); font-size: .9rem; color: var(--mist); }
.prose .meta-card strong { color: var(--paper); }
.legal-note { font-family: var(--font-mono); font-size: .8rem; color: var(--mist-2); border-left: 3px solid var(--line-2); padding-left: 16px; margin-top: 2.4em; }

/* 17. KONTAKTFORMULAR ----------------------------------------------------- */
.contact-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(32px, 5vw, 64px); align-items: start; }
.form { display: grid; gap: 18px; }
.field { display: grid; gap: 8px; }
.field label { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--mist); }
.field input, .field textarea, .field select {
  width: 100%; background: var(--ink-2); border: 1px solid var(--line); border-radius: 2px;
  color: var(--paper); font-family: var(--font-body); font-size: 1rem; padding: 14px 16px;
  transition: border-color .25s, box-shadow .25s; resize: vertical;
}
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--blue-bright); box-shadow: 0 0 0 3px rgba(68,112,244,.18); }
.field textarea { min-height: 150px; }
.field--row { grid-template-columns: 1fr 1fr; gap: 18px; }
.hp { position: absolute; left: -9999px; opacity: 0; }
.form__consent { display: flex; gap: 12px; align-items: flex-start; font-size: .88rem; color: var(--mist); }
.form__consent input { width: 18px; height: 18px; margin-top: 3px; accent-color: var(--blue); flex: 0 0 auto; }
.form__consent a { color: var(--blue-bright); text-decoration: underline; }
.form__status { font-family: var(--font-mono); font-size: .82rem; padding: 12px 14px; border-radius: 2px; display: none; }
.form__status.ok { display: block; color: #b9f5cf; background: rgba(34,160,90,.12); border: 1px solid rgba(34,160,90,.4); }
.form__status.err { display: block; color: #ffc2c7; background: rgba(196,43,54,.12); border: 1px solid rgba(196,43,54,.4); }

.contact-aside { border: 1px solid var(--line); border-radius: var(--radius); background: var(--ink-2); padding: clamp(24px, 3vw, 34px); }
.contact-aside h3 { font-size: 1.3rem; margin-bottom: 18px; }
.contact-item { display: flex; gap: 14px; padding: 16px 0; border-bottom: 1px solid var(--line); }
.contact-item:last-child { border-bottom: 0; }
.contact-item .ico { width: 40px; height: 40px; flex: 0 0 auto; display: grid; place-items: center; border: 1px solid var(--line-2); border-radius: 2px; color: var(--blue-bright); }
.contact-item .ico svg { width: 18px; height: 18px; }
.contact-item .t { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--mist-2); }
.contact-item .d { color: var(--paper); margin-top: 3px; }
.contact-item .d a:hover { color: var(--blue-bright); }

/* 18. REVEAL / REDUCED MOTION -------------------------------------------- */
[data-reveal] { opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal].in { opacity: 1; transform: none; }
[data-reveal-stagger] > * { opacity: 0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
[data-reveal-stagger].in > * { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  .hero__title .ln span, .hero__sub, .hero__actions, .hero__meta { transform: none !important; opacity: 1 !important; }
  [data-reveal], [data-reveal-stagger] > * { opacity: 1 !important; transform: none !important; }
  .streak { display: none; }
  #intro { display: none !important; }
}

/* 19. RESPONSIVE ---------------------------------------------------------- */
@media (max-width: 1080px) {
  .gallery .shot.span-6, .gallery .shot.span-4 { grid-column: span 6; }
  .gallery .shot.span-8 { grid-column: span 12; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 900px) {
  .nav__links, .nav__cta { display: none; }
  .nav__toggle { display: block; }
  .nav.is-open .nav__links {
    display: flex; flex-direction: column; gap: 0; position: absolute; top: 78px; left: 0; right: 0;
    background: rgba(8,10,15,.97); backdrop-filter: blur(16px); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
    padding: 8px var(--gutter) 22px;
  }
  .nav.is-open .nav__links a { padding: 16px 0; font-size: .92rem; border-bottom: 1px solid var(--line); }
  .nav.is-open .nav__cta { display: block; margin: 16px var(--gutter) 0; }
  .nav.is-open .nav__cta .btn { width: 100%; justify-content: center; }
  .split, .split--media-first, .contact-grid { grid-template-columns: 1fr; }
  .split--media-first .media { order: -1; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .team-grid { grid-template-columns: repeat(2, 1fr); }
  .partners { grid-template-columns: repeat(3, 1fr); }
  .spec { grid-template-columns: 1fr; }
  .cal__next { grid-template-columns: 1fr; text-align: left; }
  .cal__next .countdown { justify-content: flex-start; }
  .cal__row { grid-template-columns: 48px 1fr auto; row-gap: 4px; }
  .cal__row .series { display: none; }
  .cal__row .date small { display: inline; margin-left: 6px; }
}
@media (max-width: 560px) {
  body { font-size: 16px; }
  .stats, .partners, .team-grid { grid-template-columns: 1fr 1fr; }
  .field--row { grid-template-columns: 1fr; }
  .hero__meta { gap: 22px; }
  .countdown .c { min-width: 46px; }
  .footer__grid { grid-template-columns: 1fr; }
  .footer__legal { flex-direction: column; gap: 8px; }
}
