/* =============================================================================
   BOND Restauration — Layout Module v2
   Konzept: Dringlichkeit mit Würde · Creator-Archetype · Editorial-Restraint

   RHYTHM MAP:
   S1 Hero       BREATHING  Ivory   type-statement (kein Bild — BRUCH)
   S2 Problem    DENSE      Ivory   type-display Jahres-Anker · Broadsheet-Timeline
   S3 Denkmal    LOUD       Forge   type-h1 · ein Satz · harter Schnitt
   S4 Förderung  DENSE      Ivory   type-display % · Finanzjournalismus-Tradition
   S5 Wege       SPLIT      Ivory   50/50 · hairline Trennlinie
   S6 Referenz   BREATHING  Ivory   Captions ÜBER Bildern (Print-Tradition)
   S7 Prozess    DENSE      Forge   Sticky Schrittnummer links
   S8 CTA        LOUD       Forge   Große Headline + Formular
   S9 FAQ        DENSE      Ivory   Hairline-Zeilen · 4/6 Split

   GRID: 10-Spalten editorial intern.
   REGEL: NUR CSS-Variablen. Keine Typografie. Keine hardcodierten Werte.
   ============================================================================= */


/* =============================================================================
   IMAGE STRIPE
   ============================================================================= */

.rest-stripe {
  width:    100%;
  overflow: hidden;
}

.rest-stripe__track {
  display:  flex;
  animation: stripe-scroll 20s linear 1 forwards;
}

@media (prefers-reduced-motion: reduce) {
  .rest-stripe__track { animation: none; }
}

.rest-stripe__slide {
  flex:         0 0 25vw;
  aspect-ratio: 3 / 2;
  overflow:     hidden;
}

.rest-stripe__slide img {
  display:    block;
  width:      100%;
  height:     100%;
  object-fit: cover;
}

@keyframes stripe-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-500vw); }
}


/* =============================================================================
   PAGE BASE
   ============================================================================= */

.rest-page {
  padding-top: calc(3rem + var(--space-md));
}


/* =============================================================================
   BUTTONS
   ============================================================================= */

.rest-btn {
  display:         inline-flex;
  align-items:     center;
  padding:         0.75em 1.5em;
  cursor:          pointer;
  white-space:     nowrap;
  transition:
    background   var(--dur-quick) var(--ease-material),
    color        var(--dur-quick) var(--ease-material),
    border-color var(--dur-quick) var(--ease-material);
}

.rest-btn--solid {
  background:   var(--color-forge);
  color:        var(--color-ivory);
  border:       var(--border-hairline) solid var(--color-forge);
}

.rest-btn--solid:hover {
  background: transparent;
  color:      var(--color-forge);
}

.rest-btn--outline {
  background:   transparent;
  color:        var(--color-fg);
  border:       var(--border-hairline) solid var(--color-border-strong);
}

.rest-btn--outline:hover {
  background:   var(--color-fg);
  color:        var(--color-bg);
  border-color: var(--color-fg);
}

.rest-link {
  text-decoration:       underline;
  text-decoration-color: var(--color-border-strong);
  text-underline-offset: 0.2em;
  transition: text-decoration-color var(--dur-quick) var(--ease-material);
}

.rest-link:hover {
  text-decoration-color: var(--color-fg);
}


/* =============================================================================
   S1 — HERO  (BREATHING · IVORY · HUGE)
   Kein Bild. Statement-Typografie dominiert. BRUCH vs. Markt.
   min-height 100vh abzgl. Nav.
   ============================================================================= */

.rest-hero {
  min-height:      calc(100vh - 3rem - var(--space-md));
  padding-inline:  var(--page-margin);
  padding-block:   var(--space-lg);
  display:         flex;
  flex-direction:  column;
  justify-content: flex-start;
  gap:             var(--space-xl);
}

.rest-hero__text {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-xs);
}

.rest-hero__eyebrow {
  display:        block;
  color:          var(--color-fg);
  letter-spacing: var(--ls-heading);   /* 0.1rem */
}

/* Meta-Headlines / Section-Labels: IMMER solid fg (weiss auf grau) + 0.1rem */
.rest-section__header .type-label {
  color:          var(--color-fg);
  letter-spacing: var(--ls-heading);
}

.rest-hero__statement {
  hyphens:   none;
  font-size: clamp(2.5rem, 5.5vw, 6rem);
}

.rest-hero__logos {
  display:       flex;
  gap:           var(--space-lg);
  align-items:   center;
  padding-block: var(--space-md);
}

.rest-hero__logo {
  height:  var(--space-lg);
  width:   auto;
  display: block;
  filter:  grayscale(1);
  opacity: 0.4;
}

.rest-hero__sub--standalone {
  max-width: 55ch;
}

.rest-hero__foot {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   var(--space-xl);
  align-items:           end;
  border-top:            var(--border-hairline) solid var(--color-border);
  padding-top:           var(--space-md);
  margin-top:            auto;
}

.rest-hero__ctas {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-sm);
  align-items:    flex-end;
}


/* =============================================================================
   SECTION BASE — Ivory-Sektionen
   ============================================================================= */

.rest-section {
  padding-block:  var(--section-gap);
  padding-inline: var(--page-margin);
}

.rest-section__header {
  border-top:    var(--border-hairline) solid var(--color-border);
  padding-top:   var(--space-md);
  margin-bottom: var(--space-xl);
}


/* =============================================================================
   S2 — PROBLEM  (DENSE · IVORY)
   Broadsheet-Timeline. Jahres-Anker in type-display links.
   Hairline-Trenner oben pro Zeile.
   ============================================================================= */

.rest-paper {
  width:         75%;
  margin-inline: auto;
  /* Blatt Papier — IMMER weiss + dunkle Schrift, in beiden Modi.
     fg-Tokens lokal auf dunkel gepinnt -> alle Kindtexte erben dunkel. */
  --color-fg:        var(--grey-900);
  --color-fg-muted:  var(--grey-700);
  --color-fg-subtle: var(--grey-600);
  background:    var(--grey-0);
  color:         var(--color-fg-muted);
  padding:       var(--space-lg);
}
/* Dark-Override entfaellt — bg-paper + Tokens adaptieren automatisch */

.rest-problem__intro {
  display:               grid;
  grid-template-columns: 3fr 7fr;
  gap:                   var(--space-lg);
  margin-bottom:         var(--space-xl);
}

.rest-problem__lead {
  /* type-h2 in HTML */
  grid-column: 2;
  color:       var(--color-fg);
}

.rest-frist {
  display:               grid;
  grid-template-columns: 3fr 7fr;
  gap:                   var(--space-lg);
  align-items:           start;
  border-top:            var(--border-hairline) solid var(--color-border);
  padding-top:           var(--space-md);
  padding-bottom:        var(--space-lg);
}

.rest-frist__year {
  /* type-display in HTML — Jahres-Anker, muted */
  color:       var(--color-fg-muted);
  line-height: var(--lh-display);
}

.rest-frist__info {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-sm);
}


/* =============================================================================
   S3 — DENKMAL  (LOUD · FORGE)
   Full-bleed dunkel. Harter Schnitt. Nur ein Satz.
   ============================================================================= */

.rest-denkmal {
  background:     var(--color-bg);
  color:          var(--color-fg);
  padding-inline: var(--page-margin);
  padding-block:  var(--space-xl);
}

.rest-denkmal__inner {
  border-top:  var(--border-hairline) solid var(--color-border);
  padding-top: var(--space-md);
}

.rest-denkmal__label {
  color:          var(--color-fg);
  letter-spacing: var(--ls-heading);
}

.rest-denkmal__statement {
  /* type-h1 in HTML */
  grid-column: 1 / -1;
  max-width:   22ch;
  margin-block: var(--space-xl) var(--space-lg);
}

.rest-denkmal__body {
  /* type-body in HTML */
  opacity: 0.65;
}


/* =============================================================================
   S4 — FÖRDERUNG  (DENSE · IVORY)
   Überraschungs-Element: Prozentsätze in type-display.
   Finanzjournalismus-Tradition — kein anderes Büro im Denkmal-Markt tut das.
   Programm-Name + Details links, % rechts in großer Schrift.
   ============================================================================= */

.rest-foerderung {
  /* inherits rest-section */
}

.rest-foerderung__grid {
  display:         flex;
  justify-content: center;
  gap:             var(--space-md);
  margin-bottom:   var(--space-xl);
}

/* Programm = weisse Card, IMMER weiss + dunkle Schrift (beide Modi).
   Headline oben, Logo unten. Inhalt zentriert. */
.rest-program {
  flex:           0 0 25%;
  display:        flex;
  flex-direction: column;
  align-items:    center;
  text-align:     center;
  gap:            var(--space-sm);
  /* fg-Tokens lokal dunkel gepinnt -> Kindtexte erben dunkel */
  --color-fg:        var(--grey-900);
  --color-fg-muted:  var(--grey-700);
  --color-fg-subtle: var(--grey-600);
  background:     var(--grey-0);
  padding:        var(--space-md);
}

.rest-program__label {
  color:          var(--color-fg);
  letter-spacing: var(--ls-heading);   /* 0.1rem */
  min-height:     2.6em;               /* 2 Zeilen bei lh 1.3 */
}

.rest-program__title {
  color:          var(--color-fg-muted);
  min-height:     3.9em;               /* 3 Zeilen bei lh 1.3 */
}

.rest-program__pct {
  /* type-display — % als typografischer Anker, zentriert. Alle einzeilig. */
  line-height: var(--lh-display);
  color:       var(--color-fg-muted);
}


/* Logo ganz unten, zentriert — ALLE gleich hoch (Hoehe normalisiert,
   keine max-width-Kappe -> Breite folgt, Hoehe bleibt konstant) */
.rest-program__logo {
  display:     block;
  height:      var(--space-md);   /* einheitlich 32px auf allen Cards */
  width:       auto;
  max-width:   100%;
  object-fit:  contain;
  object-position: center;
  margin-top:  auto;       /* schiebt Logo an den Card-Boden */
  filter:      grayscale(1);
  opacity:     0.45;
}

.rest-foerderung__note {
  border-top:  var(--border-hairline) solid var(--color-border);
  padding-top: var(--space-md);
  margin-top:  var(--space-md);
}


/* =============================================================================
   S5 — WEGE  (SPLIT · IVORY)
   50/50 mit vertikaler Hairline. Badge-Labels. Zwei Wege.
   ============================================================================= */

.rest-wege {
  /* inherits rest-section */
}

.rest-wege__split {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   0;
  border-top:            var(--border-hairline) solid var(--color-border);
}

.rest-weg {
  padding-block:  var(--space-lg);
  display:        flex;
  flex-direction: column;
  gap:            var(--space-md);
}

.rest-weg:first-child {
  padding-right: var(--space-xl);
  border-right:  var(--border-hairline) solid var(--color-border);
}

.rest-weg:last-child {
  padding-left: var(--space-xl);
}

.rest-weg__badge {
  display:        inline-block;
  align-self:     flex-start;
  color:          var(--color-fg);
  letter-spacing: var(--ls-heading);
}

.rest-weg__linie {
  margin-top:     auto;
  padding-top:    var(--space-md);
  color:          var(--color-fg);
  letter-spacing: var(--ls-heading);
}

.rest-wege__note {
  border-top:  var(--border-hairline) solid var(--color-border);
  padding-top: var(--space-md);
  margin-top:  var(--space-xl);
}


/* =============================================================================
   S6 — REFERENZ  (BREATHING · IVORY)
   Captions ÜBER Bildern — Print-Tradition (editorial-restraint.md).
   2fr main / 1fr side-Stapel.
   ============================================================================= */

.rest-referenz {
  text-align: center;
}

.rest-referenz__images {
  display:               grid;
  grid-template-columns: 2fr 1fr;
  gap:                   var(--space-md);
  margin-block:          var(--space-xl);
  align-items:           start;
}

.rest-referenz__img-group {
  display:        flex;
  flex-direction: column;
}

/* Caption ÜBER Bild — Bringhurst/Tufte Print-Tradition */
.rest-referenz__caption {
  display:        block;
  padding-bottom: var(--space-xs);
  margin-bottom:  var(--space-xs);
  border-bottom:  var(--border-hairline) solid var(--color-border);
}

.rest-referenz__img-wrap {
  overflow: hidden;
  width:    100%;
}

.rest-referenz__img-wrap--main {
  aspect-ratio: 4/3;
}

.rest-referenz__img-wrap--side {
  aspect-ratio: 3/4;
}

.rest-referenz__side {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-md);
}

.rest-referenz__img {
  display:    block;
  width:      100%;
  height:     100%;
  object-fit: cover;
}

.rest-referenz__body {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   var(--space-lg);
  margin-top:            0;
  border-top:            var(--border-hairline) solid var(--color-border);
}

.rest-referenz__col-label {
  display:       block;
  margin-bottom: var(--space-xs);
}

/* Weitere Projekte — Hairline-Zeilen unter dem Hauptprojekt */
.rest-referenz__projects {
  margin-top:  var(--space-xl);
  border-top:  var(--border-hairline) solid var(--color-border);
  padding-top: var(--space-md);
}

.rest-referenz__project {
  display:               grid;
  grid-template-columns: 3fr 7fr;
  gap:                   var(--space-lg);
  border-bottom:         var(--border-hairline) solid var(--color-border);
  padding-block:         var(--space-md);
  align-items:           baseline;
}

.rest-referenz__project-meta {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-xs);
}


/* =============================================================================
   S7 — PROZESS  (DENSE · FORGE)
   CSS sticky: Schrittnummer bleibt links stehen, Inhalt scrollt rechts.
   min-height 45vh auf Content-Spalte gibt dem sticky Raum.
   ============================================================================= */

.rest-prozess {
  background:     var(--color-bg);
  color:          var(--color-fg);
  padding-inline: var(--page-margin);
  padding-block:  var(--space-xl);
}

.rest-prozess__header {
  border-top:    var(--border-hairline) solid var(--color-border);
  padding-top:   var(--space-md);
  margin-bottom: var(--space-xl);
  display:       flex;
  flex-direction: column;
  gap:           var(--space-sm);
  text-align:    center;
}

.rest-prozess__label {
  color:          var(--color-fg);
  letter-spacing: var(--ls-heading);
}

.rest-prozess__steps {
  display:               grid;
  grid-template-columns: 2fr 8fr;
  gap:                   var(--space-sm);
}

/* Linke Spalte: Nummer — sticky innerhalb der Grid-Zeilen-Höhe */
.rest-prozess__num {
  /* type-display in HTML */
  position:      sticky;
  top:           calc(3rem + var(--space-xl));
  align-self:    start;
  color:         var(--color-fg-subtle);
  line-height:   var(--lh-display);
  padding-block: var(--space-xl);
  border-top:    var(--border-hairline) solid var(--color-border);
}

/* Rechte Spalte: Inhalt — gibt Raum für sticky-Effekt */
.rest-prozess__content {
  padding-block:  var(--space-xl);
  border-top:     var(--border-hairline) solid var(--color-border);
  display:        flex;
  flex-direction: column;
  gap:            var(--space-md);
  min-height:     45vh;
}

.rest-prozess__cost {
  /* type-small in HTML */
  color: var(--color-fg-muted);
}

.rest-prozess__body {
  /* type-body in HTML */
  color:     var(--color-fg-muted);
  max-width: 55ch;
}


/* =============================================================================
   S8 — CTA / FÖRDER-CHECK  (LOUD · FORGE)
   Dunkel direkt nach S7 — kein visueller Bruch.
   Große Headline. Bottom-border-only Inputs.
   ============================================================================= */

.rest-cta {
  /* Helle Insel — IMMER weisser Hintergrund + dunkle/graue Schrift (beide Modi).
     Tokens lokal gepinnt, damit auch der Solid-Button dunkel bleibt. */
  --color-fg:          var(--grey-900);
  --color-fg-muted:    var(--grey-700);
  --color-fg-subtle:   var(--grey-600);
  --color-bg-inverse:  var(--grey-900);
  --color-fg-inverse:  var(--grey-0);
  --color-border:      var(--grey-200);
  --color-border-strong: var(--grey-300);
  background:     var(--grey-0);
  color:          var(--color-fg-muted);
  padding-inline: var(--page-margin);
  padding-block:  var(--space-xl);
}

.rest-cta__header {
  border-top:    var(--border-hairline) solid var(--color-border);
  padding-top:   var(--space-md);
  display:       grid;
  grid-template-columns: 7fr 3fr;
  gap:           var(--space-xl);
  align-items:   end;
  margin-bottom: var(--space-xl);
}

.rest-cta__sub {
  /* type-body in HTML */
  opacity:        0.65;
  padding-bottom: var(--space-xs);
}

.rest-form {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-lg);
  border-top:     var(--border-hairline) solid var(--color-border);
  padding-top:    var(--space-xl);
}

.rest-form__row {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   var(--space-xl);
}

.rest-form__field {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-xs);
}

.rest-form__label {
  color: var(--color-fg-muted);
  /* type-label in HTML */
  color: var(--color-fg-muted);
}

.rest-form__input {
  background:    transparent;
  border:        none;
  border-bottom: var(--border-hairline) solid var(--color-border-strong);
  padding-block: var(--space-sm);
  color:         var(--color-fg);
  outline:       none;
  font-family:   inherit;
  font-size:     inherit;
  transition:    border-color var(--dur-quick) var(--ease-material);
}

.rest-form__input::placeholder {
  color: var(--color-fg-subtle);
}

.rest-form__input:focus {
  border-bottom-color: var(--color-fg);
}

.rest-form__input--textarea {
  resize:     vertical;
  min-height: var(--space-xl);
}

.rest-form__submit {
  padding-top: var(--space-sm);
}

.rest-form__recaptcha-note {
  margin-top:  var(--space-sm);
  color:       var(--color-fg-subtle);
  opacity:     0.7;
}

/* reCAPTCHA v3 Badge global ausgeblendet — Pflichttext im Formular vorhanden */
.grecaptcha-badge {
  visibility: hidden !important;
}

.rest-form__msg {
  padding-top:  var(--space-sm);
  color:        var(--color-fg-muted);
}

.rest-form__msg[data-type="success"] {
  color: var(--color-fg);
}

.rest-form__msg[data-type="error"] {
  color: var(--state-error-fg);
}


/* =============================================================================
   S9 — FAQ  (DENSE · IVORY)
   Harter Schnitt von Dunkel zurück zu Ivory.
   details display:grid — Frage links (4/10), Antwort rechts (6/10).
   Native details/summary — kein JS.
   ============================================================================= */

.rest-faq {
  /* inherits rest-section */
}

.rest-faq__list {
  border-top: var(--border-hairline) solid var(--color-border);
}

.rest-faq__item {
  border-bottom: var(--border-hairline) solid var(--color-border);
}

.rest-faq__item details {
  display:               grid;
  grid-template-columns: 4fr 6fr;
  gap:                   var(--space-xl);
}

.rest-faq__q {
  /* type-h3 in HTML, inside <summary> */
  padding-block:   var(--space-lg);
  cursor:          pointer;
  list-style:      none;
  display:         flex;
  align-items:     flex-start;
  justify-content: space-between;
  gap:             var(--space-md);
}

.rest-faq__q::-webkit-details-marker {
  display: none;
}

.rest-faq__q::after {
  content:    '+';
  flex-shrink: 0;
  color:       var(--color-fg-muted);
}

.rest-faq__item details[open] .rest-faq__q::after {
  content: '−';
}

.rest-faq__a {
  /* type-body in HTML */
  padding-block: var(--space-lg);
  align-self:    start;
}


/* =============================================================================
   DARK MODE
   ============================================================================= */

/* Programm-Logo NICHT invertieren — sitzt auf weisser Card (beide Modi) */
[data-theme="dark"] .rest-hero__logo {
  filter:  brightness(0) invert(1);
  opacity: 0.7;
}

/* Solid-Button Dark-Override entfaellt — forge/ivory sind Inverse-Paar, invertieren automatisch */


/* =============================================================================
   RESPONSIVE  (Desktop-First)
   ============================================================================= */

@media (max-width: 1024px) {

  .rest-hero__foot {
    grid-template-columns: 1fr;
    gap:                   var(--space-lg);
  }

  .rest-hero__ctas {
    justify-content: flex-start;
  }

  .rest-problem__intro {
    grid-template-columns: 1fr;
  }

  .rest-problem__lead {
    grid-column: 1;
  }

  .rest-frist {
    grid-template-columns: 2fr 8fr;
    gap:                   var(--space-md);
  }

  .rest-denkmal__inner {
    grid-template-columns: 1fr;
    gap:                   var(--space-md);
  }

  .rest-foerderung__grid {
    flex-wrap: wrap;
  }
  .rest-program {
    flex: 1 1 40%;
  }

  .rest-referenz__body {
    grid-template-columns: 1fr 1fr;
  }

  .rest-cta__header {
    grid-template-columns: 1fr;
    gap:                   var(--space-md);
  }

  .rest-form__row {
    grid-template-columns: 1fr;
    gap:                   var(--space-lg);
  }

  .rest-faq__item details {
    grid-template-columns: 1fr;
  }

  .rest-faq__a {
    padding-top: 0;
  }
}

@media (max-width: 768px) {

  /* ── SPACING: xl → lg auf Mobile ── */
  .rest-hero               { gap: var(--space-lg); }
  .rest-section__header    { margin-bottom: var(--space-lg); }
  .rest-denkmal__statement { margin-block: var(--space-lg) var(--space-md); }
  .rest-form               { padding-top: var(--space-lg); gap: var(--space-md); }
  .rest-form__row          { gap: var(--space-md); }
  .rest-prozess            { padding-block: var(--space-lg); }
  .rest-cta                { padding-block: var(--space-lg); }
  .rest-wege__note         { margin-top: var(--space-lg); }
  .rest-referenz__images   { margin-block: var(--space-lg); }
  .rest-referenz__projects { margin-top: var(--space-lg); }

  /* ── PAPER: full width auf Mobile ── */
  .rest-paper {
    width:   100%;
    padding: var(--space-md);
  }

  /* ── SLIDER: full width auf Mobile ── */
  .rest-slider__nav-paper {
    width: 100%;
  }

  .rest-slider__nav-paper .rest-slider {
    padding: var(--space-sm) var(--space-sm) 0;
  }

  /* ── FOERDERUNG GRID ── */
  .rest-foerderung__grid { gap: var(--space-sm); }

  .rest-frist {
    grid-template-columns: 1fr;
  }

  .rest-frist__year {
    padding-bottom: var(--space-xs);
  }

  .rest-wege__split {
    grid-template-columns: 1fr;
  }

  .rest-weg:first-child {
    border-right:   none;
    border-bottom:  var(--border-hairline) solid var(--color-border);
    padding-right:  0;
    padding-bottom: var(--space-lg);
  }

  .rest-weg:last-child {
    padding-left: 0;
  }

  .rest-referenz__images {
    grid-template-columns: 1fr;
  }

  .rest-referenz__side {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   var(--space-md);
  }

  .rest-referenz__img-wrap--side {
    aspect-ratio: 1/1;
  }

  .rest-referenz__body {
    grid-template-columns: 1fr;
    gap:                   var(--space-md);
  }

  .rest-referenz__project {
    grid-template-columns: 1fr;
    gap:                   var(--space-sm);
  }

  .rest-prozess__steps {
    grid-template-columns: 1fr;
  }

  .rest-prozess__num {
    position:      static;
    padding-block: var(--space-md) var(--space-xs);
  }

  .rest-prozess__content {
    border-top: none;
    padding-top: 0;
    min-height:  unset;
  }

  .rest-program {
    flex: 1 1 100%;
  }

  /* Hero: Statement-Größe auf Mobile — !important überschreibt .type-statement aus globals.css */
  .rest-hero__statement {
    font-size:   var(--text-h1) !important;
    align-items: flex-start;
  }

  /* Hero-Logos: wrap + gap reduzieren */
  .rest-hero__logos {
    flex-wrap: wrap;
    gap:       var(--space-md);
  }

  /* Hero-Foot: Single Column */
  .rest-hero__foot {
    grid-template-columns: 1fr;
    gap:                   var(--space-md);
  }

  /* CTA Header: Stack */
  .rest-cta__header {
    grid-template-columns: 1fr;
    gap:                   var(--space-md);
  }
}

/* ── SLIDER REFERENZ ── */
.rest-slider-ref {
  padding-top: var(--space-lg);
  text-align:  center;
}

.rest-slider {
  position:      relative;
  width:         1000px;
  max-width:     100%;
  margin-inline: auto;
  margin-top:    var(--space-lg);
  margin-bottom: var(--space-md);
}

.rest-slider__track {
  display:          flex;
  overflow-x:       scroll;
  scroll-snap-type: x mandatory;
  scroll-behavior:  smooth;
  scrollbar-width:  none;
  gap:              0;
}
.rest-slider__track::-webkit-scrollbar { display: none; }

.rest-slider__slide {
  flex:              0 0 100%;
  scroll-snap-align: start;
  aspect-ratio:      16 / 9;
  background:        var(--color-bg);
}

.rest-slider__slide img {
  display:    block;
  width:      100%;
  height:     100%;
  object-fit: cover;
}

.rest-slider__nav-paper {
  width:             75%;
  margin-inline:     auto;
  margin-top:        var(--space-md);
  margin-bottom:     0;
  background:        var(--grey-0);
  --color-fg:        var(--grey-900);
  --color-fg-muted:  var(--grey-700);
  --color-border-strong: var(--grey-300);
}

.rest-slider__nav-paper .rest-slider {
  width:         100%;
  margin:        0;
  padding:       1.5rem 1.5rem 0;
}

.rest-slider__nav-paper .rest-slider__nav {
  padding: var(--space-sm) var(--space-md);
}

.rest-slider__nav {
  display:         flex;
  align-items:     center;
  justify-content: center;
  gap:             var(--space-sm);
}

.rest-slider__btn {
  background:   none;
  border:       var(--border-hairline) solid var(--color-border-strong);
  color:        var(--color-fg);
  padding:      0.4rem var(--space-sm);
  cursor:       pointer;
  font-family:  var(--font-sans);
  font-size:    13px;
  letter-spacing: 0.06em;
  transition:   border-color 0.2s;
}
.rest-slider__btn:hover {
  border-color: var(--color-fg);
}

.rest-slider__count {
  font-family:    var(--font-sans);
  font-size:      11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--color-fg-muted);
}

/* ── HERO STRIPE (scroll-driven) ── */
.rest-hero__stripe {
  margin-inline: calc(-1 * var(--page-margin));
  overflow:      hidden;
}

.rest-hero__stripe-track {
  display:     flex;
  will-change: transform;
}

.rest-hero__stripe-slide {
  flex:         0 0 25vw;
  aspect-ratio: 3 / 2;
  overflow:     hidden;
}

.rest-hero__stripe-slide img {
  display:    block;
  width:      100%;
  height:     100%;
  object-fit: cover;
}
