/* ==========================================================================
   infinora.online — Stylesheet
   Studio · Produktion · Schnitt  |  Berlin
   Farbwelt nach dem Studio: Studioschwarz + Ember-Orange + Stahl
   ========================================================================== */

:root {
  /* Flächen */
  --stage:     #0b0b0d;
  --stage-2:   #101013;
  --panel:     #141417;
  --panel-2:   #1c1c21;
  --rule:      #2c2c33;
  --rule-soft: #232328;

  /* Text */
  --signal: #f5f2ec;
  --mute:   #a4a2a8;
  --faint:  #6c6a72;

  /* Akzente */
  --ember:        #ff5a1e;
  --ember-bright: #ff7a3c;
  --ember-deep:   #c0380c;
  --ember-glow:   rgba(255, 90, 30, .22);
  --steel:        #9aa0a8;

  /* Maße */
  --bar-h: 64px;
  --wrap:  1200px;
  --gut:   clamp(20px, 5vw, 64px);
  --radius: 4px;

  /* Schrift */
  --display: "Archivo", system-ui, sans-serif;
  --body:    "Hanken Grotesk", system-ui, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, monospace;
}

/* --- Reset (knapp gehalten) ------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  background: var(--stage);
  color: var(--signal);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
ul { list-style: none; margin: 0; padding: 0; }

h1, h2, h3, h4 {
  font-family: var(--display);
  font-weight: 800;
  line-height: 1.04;
  letter-spacing: -0.015em;
  margin: 0;
}

::selection { background: var(--ember); color: #0b0b0d; }

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

/* --- Layout-Helfer --------------------------------------------------------- */
.wrap { width: min(100% - 2*var(--gut), var(--wrap)); margin-inline: auto; }
.section { padding-block: clamp(64px, 9vw, 128px); }
.section--tight { padding-block: clamp(48px, 6vw, 88px); }
.divider { border: 0; height: 1px; background: var(--rule-soft); margin: 0; }

/* "Super" – die kleine Broadcast-Bauchbinde über jedem Abschnitt */
.super {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--mute);
  margin: 0 0 22px;
}
.super::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--ember);
  box-shadow: 0 0 0 4px var(--ember-glow);
}

.lead {
  font-size: clamp(19px, 2.2vw, 22px);
  color: var(--mute);
  max-width: 56ch;
  line-height: 1.6;
}

/* ==========================================================================
   Topbar — die Sendeleiste
   ========================================================================== */
.topbar {
  position: sticky;
  top: 0;
  z-index: 60;
  height: var(--bar-h);
  display: flex;
  align-items: center;
  gap: 24px;
  padding-inline: var(--gut);
  background: rgba(11, 11, 13, .82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule);
}

.brand {
  display: inline-flex;
  align-items: baseline;
  gap: 1px;
  font-family: var(--display);
  font-weight: 800;
  font-size: 20px;
  letter-spacing: -0.02em;
  white-space: nowrap;
}
.brand b { color: var(--signal); font-weight: 800; }
.brand span { color: var(--ember); }

/* Navigation */
.nav { margin-left: auto; }
.nav ul { display: flex; gap: 4px; }
.nav a {
  display: block;
  padding: 9px 14px;
  font-size: 14.5px;
  font-weight: 500;
  color: var(--mute);
  border-radius: var(--radius);
  transition: color .15s, background .15s;
}
.nav a:hover { color: var(--signal); background: var(--panel-2); }
.nav a[aria-current="page"] { color: var(--signal); }
.nav a[aria-current="page"]::after {
  content: "";
  display: block;
  height: 2px;
  margin-top: 6px;
  background: var(--ember);
  border-radius: 2px;
}

/* Timecode rechts außen */
.tc {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 13px;
  color: var(--faint);
  padding-left: 20px;
  border-left: 1px solid var(--rule);
}
.tc .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #e5392f;
  animation: blink 1.4s steps(1) infinite;
}
@keyframes blink { 50% { opacity: .25; } }
.tc time { letter-spacing: .04em; }

/* Burger */
.burger {
  display: none;
  margin-left: auto;
  width: 44px; height: 44px;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  background: var(--panel);
  position: relative;
}
.burger span,
.burger span::before,
.burger span::after {
  content: "";
  position: absolute;
  left: 50%; top: 50%;
  width: 18px; height: 2px;
  background: var(--signal);
  transform: translate(-50%, -50%);
  transition: transform .22s ease, opacity .15s;
}
.burger span::before { transform: translate(-50%, -7px); }
.burger span::after  { transform: translate(-50%, 5px); }
.burger[aria-expanded="true"] span { background: transparent; }
.burger[aria-expanded="true"] span::before { transform: translate(-50%, -50%) rotate(45deg); }
.burger[aria-expanded="true"] span::after  { transform: translate(-50%, -50%) rotate(-45deg); }

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  font-family: var(--body);
  font-weight: 600;
  font-size: 15.5px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  transition: transform .14s ease, background .15s, border-color .15s, color .15s;
}
.btn:active { transform: translateY(1px); }

.btn--fill {
  background: var(--ember);
  color: #120601;
  box-shadow: 0 0 0 0 var(--ember-glow);
}
.btn--fill:hover { background: var(--ember-bright); box-shadow: 0 8px 30px -10px var(--ember-glow); }

.btn--ghost {
  background: transparent;
  color: var(--signal);
  border-color: var(--rule);
}
.btn--ghost:hover { border-color: var(--steel); background: var(--panel); }

.btn svg { width: 18px; height: 18px; }

/* ==========================================================================
   Hero
   ========================================================================== */
.hero {
  position: relative;
  min-height: clamp(560px, 86vh, 820px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  border-bottom: 1px solid var(--rule);
}
.hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__media video,
.hero__media img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.hero__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(11,11,13,.55) 0%, rgba(11,11,13,.10) 30%, rgba(11,11,13,.78) 78%, var(--stage) 100%),
    radial-gradient(120% 80% at 80% 10%, rgba(255,90,30,.12), transparent 55%);
}
.hero__inner {
  position: relative;
  z-index: 2;
  padding-block: clamp(40px, 7vw, 84px);
}

/* Bauchbinde / Lower-Third */
.lowerthird {
  border-left: 3px solid var(--ember);
  padding-left: 20px;
  margin-bottom: 30px;
  max-width: 760px;
}
.lowerthird h1 {
  font-size: clamp(40px, 7.4vw, 86px);
  font-weight: 900;
  letter-spacing: -0.03em;
}
.lowerthird h1 .em { color: var(--ember); }
.lowerthird p {
  margin: 16px 0 0;
  font-size: clamp(17px, 2.1vw, 21px);
  color: var(--mute);
  max-width: 50ch;
}
.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; }

/* Live-Marker oben rechts im Hero */
.onair {
  position: absolute;
  top: clamp(20px, 4vw, 36px);
  right: var(--gut);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--signal);
  padding: 8px 13px;
  background: rgba(11,11,13,.55);
  border: 1px solid var(--rule);
  border-radius: 100px;
  backdrop-filter: blur(6px);
}
.onair::before {
  content: "";
  width: 8px; height: 8px; border-radius: 50%;
  background: #e5392f;
  box-shadow: 0 0 10px #e5392f;
  animation: blink 1.4s steps(1) infinite;
}

/* Kennzahlen-Leiste unter dem Hero */
.specs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--rule);
}
.specs div {
  padding: 26px var(--gut);
  border-right: 1px solid var(--rule);
}
.specs div:last-child { border-right: 0; }
.specs dt {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--faint);
}
.specs dd {
  margin: 8px 0 0;
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(22px, 3vw, 30px);
}
.specs dd small { color: var(--mute); font-size: 14px; font-weight: 500; font-family: var(--body); }

/* ==========================================================================
   Abschnittskopf
   ========================================================================== */
.head { max-width: 760px; margin-bottom: clamp(36px, 5vw, 56px); }
.head h2 { font-size: clamp(30px, 4.6vw, 50px); }
.head p { margin-top: 18px; }

/* ==========================================================================
   Leistungen (Karten)
   ========================================================================== */
.grid3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.lcard {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--panel);
  border: 1px solid var(--rule);
  border-radius: 6px;
  padding: 30px 28px 32px;
  overflow: hidden;
  transition: border-color .2s, transform .2s;
}
.lcard:hover { border-color: #3a3a42; transform: translateY(-3px); }
.lcard::after {
  content: "";
  position: absolute;
  left: 0; top: 0;
  width: 100%; height: 3px;
  background: var(--ember);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s ease;
}
.lcard:hover::after { transform: scaleX(1); }
.lcard .no {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--faint);
  letter-spacing: .14em;
}
.lcard h3 {
  margin: 14px 0 12px;
  font-size: 25px;
  font-weight: 700;
}
.lcard p { color: var(--mute); font-size: 15.5px; margin: 0; }
.lcard ul { margin: 18px 0 0; display: grid; gap: 9px; }
.lcard li {
  position: relative;
  padding-left: 20px;
  font-size: 14.5px;
  color: var(--mute);
}
.lcard li::before {
  content: "";
  position: absolute; left: 0; top: 9px;
  width: 7px; height: 7px;
  background: var(--ember);
  transform: rotate(45deg);
}

/* ==========================================================================
   Bild + Text (Studio im Betrieb)
   ========================================================================== */
.split {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
}
.split--rev { grid-template-columns: 1fr 1.15fr; }
.split--rev .split__media { order: 2; }
.frame {
  position: relative;
  border: 1px solid var(--rule);
  border-radius: 6px;
  overflow: hidden;
  background: var(--panel);
}
.frame img { width: 100%; aspect-ratio: 16/10; object-fit: cover; }
.frame figcaption {
  position: absolute;
  left: 14px; bottom: 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--signal);
  background: rgba(11,11,13,.7);
  border: 1px solid var(--rule);
  padding: 6px 11px;
  border-radius: 3px;
  backdrop-filter: blur(4px);
}
.split__body h3 { font-size: clamp(26px, 3.4vw, 38px); margin-bottom: 18px; }
.split__body p { color: var(--mute); margin: 0 0 16px; }
.checklist { margin-top: 22px !important; display: grid; gap: 12px; }
.checklist li { display: flex; gap: 12px; align-items: flex-start; color: var(--signal); font-size: 15.5px; }
.checklist svg { flex: 0 0 auto; width: 20px; height: 20px; margin-top: 2px; color: var(--ember); }

/* ==========================================================================
   Ausstattung (Raster)
   ========================================================================== */
.rig {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.rig figure {
  margin: 0;
  position: relative;
  border: 1px solid var(--rule);
  border-radius: 6px;
  overflow: hidden;
  background: var(--panel);
}
.rig img {
  width: 100%;
  aspect-ratio: 3/2;
  object-fit: cover;
  transition: transform .5s ease, filter .4s;
  filter: saturate(.95);
}
.rig figure:hover img { transform: scale(1.05); filter: saturate(1.08); }
.rig figcaption {
  position: absolute;
  inset: auto 0 0 0;
  padding: 28px 16px 14px;
  font-weight: 600;
  font-size: 15px;
  background: linear-gradient(transparent, rgba(11,11,13,.92));
}
.rig figcaption small {
  display: block;
  font-family: var(--mono);
  font-weight: 400;
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ember-bright);
  margin-bottom: 3px;
}

/* ==========================================================================
   Team
   ========================================================================== */
.teamshot {
  border: 1px solid var(--rule);
  border-radius: 6px;
  overflow: hidden;
}
.teamshot img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }

.director {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: clamp(28px, 5vw, 56px);
  align-items: center;
  margin-top: clamp(40px, 6vw, 72px);
}
.director__photo {
  border: 1px solid var(--rule);
  border-radius: 6px;
  overflow: hidden;
  background: var(--panel);
}
.director__photo img { width: 100%; aspect-ratio: 4/5; object-fit: cover; object-position: top center; }
.director__body .role {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ember-bright);
}
.director__body h3 { font-size: clamp(28px, 3.6vw, 40px); margin: 10px 0 18px; }
.director__body p { color: var(--mute); margin: 0 0 16px; }
.sign {
  margin-top: 22px;
  font-family: var(--display);
  font-weight: 700;
  font-size: 22px;
  color: var(--signal);
  font-style: italic;
}

/* Werte-Liste */
.values { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 8px; }
.value { border-top: 2px solid var(--rule); padding-top: 18px; }
.value .k { font-family: var(--mono); font-size: 12px; color: var(--ember-bright); letter-spacing: .14em; }
.value h4 { font-family: var(--display); font-size: 19px; margin: 10px 0 8px; }
.value p { color: var(--mute); font-size: 14.5px; margin: 0; }

/* ==========================================================================
   CTA-Band
   ========================================================================== */
.cta {
  position: relative;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  background:
    radial-gradient(80% 140% at 100% 0%, rgba(255,90,30,.14), transparent 60%),
    var(--stage-2);
  overflow: hidden;
}
.cta__in {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  padding-block: clamp(48px, 7vw, 84px);
}
.cta h2 { font-size: clamp(28px, 4.2vw, 46px); max-width: 18ch; }
.cta p { color: var(--mute); margin: 14px 0 0; max-width: 44ch; }
.cta__btns { display: flex; flex-wrap: wrap; gap: 14px; }

/* ==========================================================================
   Kontakt
   ========================================================================== */
.contact {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 5vw, 56px);
  align-items: start;
}
.field { margin-bottom: 18px; }
.field label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .02em;
  margin-bottom: 8px;
  color: var(--signal);
}
.field label .opt { color: var(--faint); font-weight: 400; }
.field input,
.field textarea,
.field select {
  width: 100%;
  padding: 13px 15px;
  background: var(--panel);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  color: var(--signal);
  font-family: var(--body);
  font-size: 15.5px;
  transition: border-color .15s, background .15s;
}
.field textarea { resize: vertical; min-height: 138px; }
.field input::placeholder,
.field textarea::placeholder { color: var(--faint); }
.field input:focus,
.field textarea:focus,
.field select:focus {
  outline: none;
  border-color: var(--ember);
  background: var(--stage-2);
}
.field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

.consent {
  display: flex;
  gap: 11px;
  align-items: flex-start;
  font-size: 13.5px;
  color: var(--mute);
  margin: 6px 0 22px;
}
.consent input { margin-top: 3px; accent-color: var(--ember); width: 16px; height: 16px; flex: 0 0 auto; }
.consent a { color: var(--ember-bright); text-decoration: underline; text-underline-offset: 2px; }

.formnote {
  margin-top: 16px;
  font-size: 14px;
  padding: 12px 15px;
  border-radius: var(--radius);
  display: none;
}
.formnote.ok  { display: block; background: rgba(40,160,90,.12); border: 1px solid rgba(60,180,110,.4); color: #87e0ad; }
.formnote.err { display: block; background: rgba(200,60,40,.12); border: 1px solid rgba(220,80,60,.4); color: #f0a290; }

/* Kontakt-Infokarte */
.info { display: grid; gap: 2px; }
.info__row {
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 14px;
  align-items: start;
  padding: 18px 0;
  border-bottom: 1px solid var(--rule-soft);
}
.info__row:first-child { padding-top: 0; }
.info__ico {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  color: var(--ember);
}
.info__ico svg { width: 18px; height: 18px; }
.info__row .k { font-family: var(--mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--faint); }
.info__row .v { font-size: 16px; margin-top: 3px; }
.info__row .v a:hover { color: var(--ember-bright); }

/* Karte / Map (Consent-gesteuert) */
.map {
  margin-top: 28px;
  border: 1px solid var(--rule);
  border-radius: 6px;
  overflow: hidden;
  background: var(--panel);
}
.map iframe { display: block; width: 100%; height: 340px; border: 0; filter: grayscale(.25) contrast(1.05); }
.map__hold {
  height: 340px;
  display: grid;
  place-content: center;
  text-align: center;
  gap: 14px;
  padding: 28px;
  background:
    repeating-linear-gradient(45deg, var(--panel), var(--panel) 14px, var(--stage-2) 14px, var(--stage-2) 28px);
}
.map__hold p { color: var(--mute); font-size: 14.5px; max-width: 38ch; margin: 0 auto; }

/* ==========================================================================
   Footer — Sendeablauf / Rundown
   ========================================================================== */
.foot {
  background: var(--stage-2);
  border-top: 1px solid var(--rule);
  padding-block: clamp(48px, 6vw, 72px) 28px;
}
.foot__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: 36px;
}
.foot h4 {
  font-family: var(--mono);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--faint);
  margin: 0 0 16px;
}
.foot .brand { font-size: 22px; margin-bottom: 14px; }
.foot p { color: var(--mute); font-size: 14.5px; margin: 0 0 8px; max-width: 34ch; }
.foot ul { display: grid; gap: 10px; }
.foot a { color: var(--mute); font-size: 14.5px; transition: color .15s; }
.foot a:hover { color: var(--signal); }
.foot__bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 24px;
  align-items: center;
  justify-content: space-between;
  margin-top: 44px;
  padding-top: 22px;
  border-top: 1px solid var(--rule);
  font-size: 13px;
  color: var(--faint);
}
.foot__bar nav { display: flex; gap: 18px; flex-wrap: wrap; }

/* ==========================================================================
   Cookie-Banner
   ========================================================================== */
.cookie {
  position: fixed;
  left: 16px; right: 16px; bottom: 16px;
  z-index: 80;
  max-width: 760px;
  margin-inline: auto;
  background: var(--panel-2);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: 22px 24px;
  box-shadow: 0 24px 60px -20px rgba(0,0,0,.7);
  display: none;
}
.cookie.show { display: block; animation: rise .35s ease both; }
@keyframes rise { from { transform: translateY(16px); opacity: 0; } }
.cookie h4 { font-family: var(--display); font-size: 18px; margin: 0 0 8px; }
.cookie p { color: var(--mute); font-size: 14px; margin: 0 0 16px; }
.cookie p a { color: var(--ember-bright); text-decoration: underline; text-underline-offset: 2px; }
.cookie__btns { display: flex; flex-wrap: wrap; gap: 10px; }
.cookie .btn { padding: 11px 20px; font-size: 14px; }

/* ==========================================================================
   Fließtext für Rechtsseiten
   ========================================================================== */
.prose { max-width: 760px; }
.prose h2 { font-size: clamp(22px, 3vw, 30px); margin: 44px 0 14px; }
.prose h3 { font-family: var(--display); font-size: 19px; margin: 28px 0 10px; }
.prose p, .prose li { color: var(--mute); font-size: 16px; line-height: 1.7; }
.prose p { margin: 0 0 14px; }
.prose ul { list-style: none; margin: 0 0 16px; display: grid; gap: 8px; }
.prose ul li { position: relative; padding-left: 20px; }
.prose ul li::before {
  content: ""; position: absolute; left: 0; top: 10px;
  width: 6px; height: 6px; background: var(--ember); transform: rotate(45deg);
}
.prose a { color: var(--ember-bright); text-decoration: underline; text-underline-offset: 2px; }
.prose strong { color: var(--signal); }
.prose .meta { font-family: var(--mono); font-size: 13px; color: var(--faint); }
.pagehead { padding-block: clamp(48px, 7vw, 92px) 0; }
.pagehead h1 { font-size: clamp(34px, 5.5vw, 62px); }
.pagehead p { margin-top: 16px; }

/* Tabelle für Impressum/Datenschutz */
.dl { display: grid; grid-template-columns: 200px 1fr; gap: 2px 24px; margin: 0 0 8px; }
.dl dt { color: var(--faint); font-size: 15px; padding: 7px 0; }
.dl dd { color: var(--signal); font-size: 15px; margin: 0; padding: 7px 0; }

/* Scroll-Reveal */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .tc .dot, .onair::before, .cookie.show { animation: none; }
}

/* ==========================================================================
   Responsiv
   ========================================================================== */
@media (max-width: 940px) {
  .grid3, .rig { grid-template-columns: repeat(2, 1fr); }
  .split, .split--rev, .contact, .director { grid-template-columns: 1fr; }
  .split--rev .split__media { order: 0; }
  .director { gap: 28px; }
  .director__photo { max-width: 320px; }
  .foot__grid { grid-template-columns: 1fr 1fr; gap: 30px; }
  .values { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  body { font-size: 16px; }
  .tc { display: none; }
  .nav {
    position: fixed;
    inset: var(--bar-h) 0 auto 0;
    margin: 0;
    background: var(--stage);
    border-bottom: 1px solid var(--rule);
    transform: translateY(-130%);
    transition: transform .28s ease;
    box-shadow: 0 24px 50px -20px rgba(0,0,0,.8);
  }
  .nav.open { transform: translateY(0); }
  .nav ul { flex-direction: column; gap: 0; padding: 10px var(--gut) 20px; }
  .nav a { padding: 14px 6px; font-size: 16px; border-bottom: 1px solid var(--rule-soft); border-radius: 0; }
  .nav a[aria-current="page"]::after { display: none; }
  .burger { display: block; }
  .specs { grid-template-columns: 1fr; }
  .specs div { border-right: 0; border-bottom: 1px solid var(--rule); }
  .grid3, .rig { grid-template-columns: 1fr; }
  .field--row { grid-template-columns: 1fr; }
  .foot__grid { grid-template-columns: 1fr; }
  .cta__in { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 380px) {
  .lowerthird h1 { font-size: 38px; }
}

/* ============================================================
   Buchung / Anzahlung / Zahlung  (ergänzt für Buchungsstrecke)
   ============================================================ */
.deposit{
  border:1px solid var(--rule);
  border-left:3px solid var(--ember);
  background:var(--panel);
  border-radius:var(--radius);
  padding:26px 28px;
  margin:28px 0;
}
.deposit h3{font-size:22px;margin:0 0 8px}
.deposit .amount{
  font-family:var(--mono);
  font-size:30px;color:var(--ember-bright);
  font-weight:700;letter-spacing:.5px;margin:4px 0 10px
}
.deposit p{color:var(--mute);max-width:62ch;margin:0 0 6px}
.deposit small{color:var(--faint)}

.pay{display:none;margin-top:14px}
.pay.show{display:block}
.pay__btns{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px}
.pay__btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:var(--radius);
  font-family:var(--display);font-weight:700;font-size:15px;
  border:1px solid var(--rule);background:var(--panel-2);color:var(--signal);
  transition:border-color .15s,transform .15s
}
.pay__btn:hover{border-color:var(--ember);transform:translateY(-1px)}
.pay__btn--stripe{background:#635bff;border-color:#635bff;color:#fff}
.pay__btn--paypal{background:#ffc439;border-color:#ffc439;color:#11193a}
.pay__btn[aria-disabled="true"]{opacity:.5;pointer-events:none}
.pay__hint{margin-top:12px;font-size:13px;color:var(--faint)}

.notice{
  border:1px solid var(--rule-soft);background:var(--stage-2);
  border-radius:var(--radius);padding:14px 16px;margin:18px 0;
  font-size:14px;color:var(--mute)
}
.notice strong{color:var(--signal)}
