/* ============================================================
 * reveal.css
 * Sektion und Children Reveal Effekte mit IntersectionObserver.
 * Bidirektional. Reduced Motion safe. NoScript safe.
 *
 * Aktivierung pro Sektion: data-reveal-effect="<name>".
 * Children optional: data-reveal-child plus inline --idx (auto).
 *
 * Effekt CSS wird Etappe fuer Etappe ergaenzt.
 * Cohesion Tokens werden hier zentral gesetzt.
 * ============================================================ */

/* Reduced Motion. Hoechste Prioritaet, vor allen Effekten. */
@media (prefers-reduced-motion: reduce) {
  html.js-reveal [data-reveal-effect],
  html.js-reveal [data-reveal-effect] [data-reveal-child],
  html.js-reveal [data-reveal-effect] *[style*="--idx"] {
    opacity: 1 !important;
    transform: none !important;
    transition: opacity 200ms linear !important;
  }
}

/* NoScript Fallback. Ohne JavaScript: alles sichtbar. */
html:not(.js-reveal) [data-reveal-effect],
html:not(.js-reveal) [data-reveal-child] {
  opacity: 1;
  transform: none;
}

/* Cohesion Tokens auf Sektionsebene.
 * --reveal-ease     einheitliche Easing Kurve
 * --reveal-duration Hauptelement Dauer
 * --reveal-child    Children Dauer
 * --reveal-stagger  Versatz zwischen Children
 * --reveal-distance Translate Distanz                       */
html.js-reveal [data-reveal-effect] {
  --reveal-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --reveal-duration: 1800ms;
  --reveal-child: 1400ms;
  --reveal-stagger: 200ms;
  --reveal-distance: 24px;
  will-change: opacity, transform;
}

html.js-reveal [data-reveal-effect].is-revealed {
  will-change: auto;
}

/* ===========================================================
 * Effekt Definitionen werden hier ergaenzt:
 *   cards-stagger    Etappe 3
 *   split-meet       Etappe 4
 *   image-curtain    Etappe 5
 *   parallax-reveal  Etappe 6
 *   curtain-stage    Etappe 7
 *   cards-flip       Etappe 8
 *   scale-pop        Etappe 9
 * =========================================================== */

/* ============================================================
 * EFFEKT cards-stagger
 * Eyebrow und H2 fade up zuerst, dann Cards staggered.
 * Genutzt fuer Sektionen mit grid-3 plus .card Children.
 * ============================================================ */

/* Initial States */
html.js-reveal [data-reveal-effect="cards-stagger"] .eyebrow,
html.js-reveal [data-reveal-effect="cards-stagger"] h2,
html.js-reveal [data-reveal-effect="cards-stagger"] [data-reveal-child] {
  opacity: 0;
  transform: translateY(var(--reveal-distance));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
}

/* Eyebrow zuerst */
html.js-reveal [data-reveal-effect="cards-stagger"] .eyebrow {
  transition-delay: 0ms;
}

/* H2 leicht versetzt */
html.js-reveal [data-reveal-effect="cards-stagger"] h2 {
  transition-delay: 150ms;
}

/* Cards mit Stagger nach Headline */
html.js-reveal [data-reveal-effect="cards-stagger"] [data-reveal-child] {
  transition-duration: var(--reveal-child);
  transition-delay: calc(320ms + var(--idx, 0) * var(--reveal-stagger));
}

/* Reveal States */
html.js-reveal [data-reveal-effect="cards-stagger"].is-revealed .eyebrow,
html.js-reveal [data-reveal-effect="cards-stagger"].is-revealed h2,
html.js-reveal [data-reveal-effect="cards-stagger"].is-revealed [data-reveal-child] {
  opacity: 1;
  transform: translateY(0);
}


/* ============================================================
 * EFFEKT split-meet
 * Text und Bildblock kommen aus entgegengesetzten Seiten.
 * Leichter Overshoot fuer frischen Eindruck.
 * ============================================================ */
html.js-reveal [data-reveal-effect="split-meet"] .split > * {
  opacity: 0;
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) cubic-bezier(0.22, 1.12, 0.36, 1);
}
html.js-reveal [data-reveal-effect="split-meet"] .split > *:first-child {
  transform: translateX(calc(-1 * var(--reveal-distance) * 2));
}
html.js-reveal [data-reveal-effect="split-meet"] .split > *:nth-child(2) {
  transform: translateX(calc(var(--reveal-distance) * 2));
  transition-delay: 120ms;
}
html.js-reveal [data-reveal-effect="split-meet"].is-revealed .split > * {
  opacity: 1;
  transform: translateX(0);
}


/* ============================================================
 * EFFEKT image-curtain
 * Bild Vorhang von oben nach unten, Text fliegt von hinten ein.
 * ============================================================ */
html.js-reveal [data-reveal-effect="image-curtain"] .picture-wrap {
  clip-path: inset(0 0 100% 0);
  transition: clip-path 2100ms var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="image-curtain"].is-revealed .picture-wrap {
  clip-path: none;
}
html.js-reveal [data-reveal-effect="image-curtain"] .stack-lg > * {
  opacity: 0;
  transform: translateX(calc(var(--reveal-distance) * 1.5));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
  transition-delay: 450ms;
}
html.js-reveal [data-reveal-effect="image-curtain"].is-revealed .stack-lg > * {
  opacity: 1;
  transform: translateX(0);
}


/* ============================================================
 * EFFEKT parallax-reveal
 * Bild kommt mit 3D Tilt rein, Text mit Blur Reveal.
 * Edel und ruhig fuer Pension Sektion.
 * ============================================================ */
html.js-reveal [data-reveal-effect="parallax-reveal"] .picture-wrap {
  opacity: 0;
  transform: perspective(800px) rotateY(-8deg) translateY(var(--reveal-distance));
  transform-origin: right center;
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="parallax-reveal"] .stack-lg > * {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="parallax-reveal"] .stack-lg > *:nth-child(1) { transition-delay: 200ms; }
html.js-reveal [data-reveal-effect="parallax-reveal"] .stack-lg > *:nth-child(2) { transition-delay: 350ms; }
html.js-reveal [data-reveal-effect="parallax-reveal"].is-revealed .picture-wrap {
  opacity: 1;
  transform: perspective(800px) rotateY(0) translateY(0);
}
html.js-reveal [data-reveal-effect="parallax-reveal"].is-revealed .stack-lg > * {
  opacity: 1;
  transform: translateY(0);
}


/* ============================================================
 * EFFEKT curtain-stage
 * Bordeaux Hintergrund oeffnet sich von Mitte nach aussen.
 * Headline plus Eyebrow danach, dann Quote Cards staggered.
 * ============================================================ */
html.js-reveal [data-reveal-effect="curtain-stage"] {
  clip-path: inset(0 50% 0 50%);
  transition: clip-path 2000ms var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="curtain-stage"].is-revealed {
  clip-path: inset(0 0 0 0);
}
html.js-reveal [data-reveal-effect="curtain-stage"] .eyebrow,
html.js-reveal [data-reveal-effect="curtain-stage"] h2,
html.js-reveal [data-reveal-effect="curtain-stage"] .lead {
  opacity: 0;
  transform: translateY(var(--reveal-distance));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
  transition-delay: 450ms;
}
html.js-reveal [data-reveal-effect="curtain-stage"] [data-reveal-child] {
  opacity: 0;
  transform: translateY(calc(var(--reveal-distance) * 1.5));
  transition:
    opacity var(--reveal-child) var(--reveal-ease),
    transform var(--reveal-child) var(--reveal-ease);
  transition-delay: calc(750ms + var(--idx, 0) * var(--reveal-stagger));
}
html.js-reveal [data-reveal-effect="curtain-stage"].is-revealed .eyebrow,
html.js-reveal [data-reveal-effect="curtain-stage"].is-revealed h2,
html.js-reveal [data-reveal-effect="curtain-stage"].is-revealed .lead,
html.js-reveal [data-reveal-effect="curtain-stage"].is-revealed [data-reveal-child] {
  opacity: 1;
  transform: translateY(0);
}


/* ============================================================
 * EFFEKT cards-flip
 * Cards klappen aus 3D Tiefe nach vorn. Headline davor.
 * ============================================================ */
html.js-reveal [data-reveal-effect="cards-flip"] .section-head > * {
  opacity: 0;
  transform: translateY(var(--reveal-distance));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="cards-flip"] .section-head > *:nth-child(2) { transition-delay: 120ms; }
html.js-reveal [data-reveal-effect="cards-flip"] .section-head > *:nth-child(3) { transition-delay: 240ms; }
html.js-reveal [data-reveal-effect="cards-flip"] .grid {
  perspective: 1200px;
}
html.js-reveal [data-reveal-effect="cards-flip"] [data-reveal-child] {
  opacity: 0;
  transform: rotateY(-25deg) translateZ(-100px);
  transform-origin: left center;
  transition:
    opacity var(--reveal-child) var(--reveal-ease),
    transform var(--reveal-child) var(--reveal-ease);
  transition-delay: calc(380ms + var(--idx, 0) * var(--reveal-stagger));
}
html.js-reveal [data-reveal-effect="cards-flip"].is-revealed .section-head > *,
html.js-reveal [data-reveal-effect="cards-flip"].is-revealed [data-reveal-child] {
  opacity: 1;
  transform: rotateY(0) translateZ(0) translateY(0);
}


/* ============================================================
 * EFFEKT scale-pop
 * Headline fade up, dann CTAs scale pop.
 * ============================================================ */
html.js-reveal [data-reveal-effect="scale-pop"] .eyebrow,
html.js-reveal [data-reveal-effect="scale-pop"] h2,
html.js-reveal [data-reveal-effect="scale-pop"] .lead {
  opacity: 0;
  transform: translateY(var(--reveal-distance));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="scale-pop"] h2 { transition-delay: 120ms; }
html.js-reveal [data-reveal-effect="scale-pop"] .lead { transition-delay: 240ms; }
html.js-reveal [data-reveal-effect="scale-pop"] [data-reveal-child] {
  opacity: 0;
  transform: scale(0.88);
  transition:
    opacity var(--reveal-child) var(--reveal-ease),
    transform var(--reveal-child) cubic-bezier(0.22, 1.12, 0.36, 1);
  transition-delay: calc(420ms + var(--idx, 0) * var(--reveal-stagger));
}
html.js-reveal [data-reveal-effect="scale-pop"].is-revealed .eyebrow,
html.js-reveal [data-reveal-effect="scale-pop"].is-revealed h2,
html.js-reveal [data-reveal-effect="scale-pop"].is-revealed .lead {
  opacity: 1;
  transform: translateY(0);
}
html.js-reveal [data-reveal-effect="scale-pop"].is-revealed [data-reveal-child] {
  opacity: 1;
  transform: scale(1);
}


/* ============================================================
 * Hardening Override
 * NoScript und Reduced Motion neutralisieren auch
 * clip-path und filter zusaetzlich zu opacity und transform.
 * Steht ans Ende, damit Spezifitaet siegt.
 * ============================================================ */
html:not(.js-reveal) [data-reveal-effect],
html:not(.js-reveal) [data-reveal-effect] *,
html:not(.js-reveal) [data-reveal-child] {
  clip-path: none !important;
  filter: none !important;
}

@media (prefers-reduced-motion: reduce) {
  html.js-reveal [data-reveal-effect],
  html.js-reveal [data-reveal-effect] * {
    clip-path: none !important;
    filter: none !important;
  }
}


/* ============================================================
 * EFFEKT footer-stage
 * Drei Cols choreografiert.
 * Links Kontakt von links, Mitte Oeffnungszeiten aus Hintergrund,
 * Rechts Folgen Sie uns von rechts.
 * Tagline und Copyright zeitversetzt nach.
 * ============================================================ */
html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__col {
  opacity: 0;
  transition:
    opacity 800ms var(--reveal-ease),
    transform 800ms var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__col:nth-child(1) {
  transform: translateX(calc(-1 * var(--reveal-distance) * 2.5));
  transition-delay: 150ms;
}
html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__col:nth-child(2) {
  transform: scale(0.78) translateY(40px);
  transition-duration: 1100ms;
  transition-delay: 0ms;
}
html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__col:nth-child(3) {
  transform: translateX(calc(var(--reveal-distance) * 2.5));
  transition-delay: 250ms;
}
html.js-reveal [data-reveal-effect="footer-stage"].is-revealed .site-footer__col {
  opacity: 1;
  transform: translateX(0) translateY(0) scale(1);
}

html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__closer,
html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__bottom {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 600ms var(--reveal-ease),
    transform 600ms var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__closer { transition-delay: 700ms; }
html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__bottom { transition-delay: 900ms; }
html.js-reveal [data-reveal-effect="footer-stage"].is-revealed .site-footer__closer,
html.js-reveal [data-reveal-effect="footer-stage"].is-revealed .site-footer__bottom {
  opacity: 1;
  transform: translateY(0);
}


/* ============================================================
 * SCROLL PROGRESS BAR
 * Hauchduenner Goldstreifen am oberen Rand.
 * ============================================================ */
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  z-index: 100;
  pointer-events: none;
  background: linear-gradient(90deg,
    var(--vr-gold) 0%,
    var(--vr-gold-hell, #d4a857) 50%,
    var(--vr-gold) 100%);
  transform: scaleX(0);
  transform-origin: left center;
  will-change: transform;
}

@media (prefers-reduced-motion: reduce) {
  .scroll-progress { display: none; }
}


/* ============================================================
 * STIMMEN POLISH
 * Bordeaux Gradient mit subtilem Glow oben.
 * 3D Text Shadow auf Eyebrow, H2, Lead.
 * Quote Cards mit alternierendem Hover Tilt.
 * ============================================================ */
.section-burgund {
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255, 230, 200, 0.10) 0%, transparent 55%),
    radial-gradient(ellipse at 20% 100%, rgba(0, 0, 0, 0.22) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 100%, rgba(0, 0, 0, 0.16) 0%, transparent 55%),
    linear-gradient(165deg, var(--vr-burgund, #6E1A24) 0%, #5A1119 100%) !important;
}

.section-burgund .eyebrow,
.section-burgund h2,
.section-burgund .lead {
  text-shadow:
    0 1px 0 rgba(0, 0, 0, 0.35),
    0 2px 0 rgba(0, 0, 0, 0.25),
    0 4px 10px rgba(0, 0, 0, 0.40),
    0 14px 28px rgba(0, 0, 0, 0.30);
}

.section-burgund .quote-card {
  transition:
    transform 600ms var(--reveal-ease, cubic-bezier(0.22, 1, 0.36, 1)),
    box-shadow 600ms var(--reveal-ease, cubic-bezier(0.22, 1, 0.36, 1));
  transform-origin: center bottom;
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.18),
    0 12px 28px rgba(0, 0, 0, 0.22);
}

@media (hover: hover) {
  .section-burgund .quote-card:hover {
    transform: translateY(-8px) scale(1.015);
    box-shadow:
      0 4px 8px rgba(0, 0, 0, 0.20),
      0 20px 48px rgba(0, 0, 0, 0.32),
      0 8px 18px rgba(0, 0, 0, 0.20);
  }
  .section-burgund .quote-card:nth-child(odd):hover  { transform: translateY(-8px) scale(1.015) rotate(-0.6deg); }
  .section-burgund .quote-card:nth-child(even):hover { transform: translateY(-8px) scale(1.015) rotate(0.6deg);  }
}

@media (prefers-reduced-motion: reduce) {
  .section-burgund .quote-card:hover {
    transform: none !important;
  }
  main .picture-wrap:hover {
    transform: none !important;
  }
}


/* ============================================================
 * MOBILE HORIZONTAL SCROLL LOCK
 * Body fix, Translate Effekte ragen nicht raus.
 * ============================================================ */
html {
  overflow-x: clip;
}
body {
  overflow-x: clip;
  position: relative;
  width: 100%;
  max-width: 100vw;
}


/* ============================================================
 * MOBILE TUNING fuer Reveal Effekte
 * Translate Distanzen stark reduziert.
 * 3D Effekte zahmer.
 * Performance Killer auf Mobile aus.
 * ============================================================ */
@media (max-width: 768px) {
  html.js-reveal [data-reveal-effect] {
    --reveal-distance: 16px;
    --reveal-duration: 1550ms;
    --reveal-child: 1200ms;
    --reveal-stagger: 170ms;
  }

  html.js-reveal [data-reveal-effect="split-meet"] .split > *:first-child {
    transform: translateX(-24px);
  }
  html.js-reveal [data-reveal-effect="split-meet"] .split > *:nth-child(2) {
    transform: translateX(24px);
  }
  html.js-reveal [data-reveal-effect="image-curtain"] .stack-lg > * {
    transform: translateX(18px);
  }
  html.js-reveal [data-reveal-effect="parallax-reveal"] .picture-wrap {
    transform: translateY(18px);
  }
  html.js-reveal [data-reveal-effect="cards-flip"] [data-reveal-child] {
    transform: rotateY(-10deg) translateZ(-20px);
  }
  html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__col:nth-child(1) {
    transform: translateX(-32px);
  }
  html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__col:nth-child(3) {
    transform: translateX(32px);
  }
  html.js-reveal [data-reveal-effect="footer-stage"] .site-footer__col:nth-child(2) {
    transform: scale(0.88) translateY(20px);
  }
  html.js-reveal [data-reveal-effect="curtain-stage"] {
    clip-path: inset(0 20% 0 20%);
  }

  /* Performance Killer aus auf Mobile */
  .scroll-progress { display: none !important; }
  .hero__media { transform: none !important; }
}


/* ============================================================
 * STIMMEN EFFEKT v2, deutlich staerker
 * 3D Headline mit echter Schichtschatten Treppe.
 * Quote Cards mit Hairline plus Tiefe.
 * ============================================================ */
.section-burgund .eyebrow {
  text-shadow:
    0 1px 0 rgba(0, 0, 0, 0.45),
    0 2px 6px rgba(0, 0, 0, 0.50) !important;
}

.section-burgund h2 {
  text-shadow:
    0 1px 0 rgba(0, 0, 0, 0.45),
    0 2px 0 rgba(0, 0, 0, 0.40),
    0 3px 0 rgba(0, 0, 0, 0.35),
    0 4px 0 rgba(0, 0, 0, 0.30),
    0 5px 0 rgba(0, 0, 0, 0.25),
    0 8px 14px rgba(0, 0, 0, 0.55),
    0 18px 36px rgba(0, 0, 0, 0.45),
    0 36px 60px rgba(0, 0, 0, 0.30) !important;
}

.section-burgund .lead {
  text-shadow:
    0 1px 0 rgba(0, 0, 0, 0.40),
    0 2px 4px rgba(0, 0, 0, 0.45) !important;
}

.section-burgund .quote-card {
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.10),
    0 4px 8px rgba(0, 0, 0, 0.22),
    0 18px 40px rgba(0, 0, 0, 0.32),
    0 40px 80px rgba(0, 0, 0, 0.24) !important;
}


/* ============================================================
 * GOOGLE RATING HEADER
 * ============================================================ */
.google-rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin: 32px auto 56px;
  color: var(--vr-creme);
}

.google-rating__value {
  font-family: var(--vr-font-display, 'Fraunces', serif);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 700;
  color: var(--vr-gold-hell, #d4a857);
  text-shadow:
    0 2px 0 rgba(0, 0, 0, 0.40),
    0 4px 0 rgba(0, 0, 0, 0.30),
    0 8px 18px rgba(0, 0, 0, 0.50),
    0 24px 40px rgba(0, 0, 0, 0.35);
  line-height: 1;
}

.google-rating__stars {
  display: flex;
  gap: 4px;
  color: var(--vr-gold-hell, #d4a857);
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.40));
}
.google-star { fill: currentColor; }
.google-star--empty { color: rgba(255, 255, 255, 0.18); }

.google-rating__count {
  font-size: 1rem;
  opacity: 0.92;
  margin: 0;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

.google-rating__cta {
  color: var(--vr-gold-hell, #d4a857);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding: 4px 0;
  transition: opacity 200ms;
}
.google-rating__cta:hover { opacity: 0.7; }


/* ============================================================
 * REVIEWS MARQUEE SLIDESHOW
 * ============================================================ */
.reviews-marquee {
  position: relative;
  overflow: hidden;
  margin: 0 calc(-1 * var(--vr-space-md, 16px));
  padding: 24px 0 32px;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 14%, #000 86%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0%, #000 14%, #000 86%, transparent 100%);
}

.reviews-marquee__track {
  display: flex;
  gap: 24px;
  width: max-content;
  animation: reviews-scroll 60s linear infinite;
  animation-play-state: paused;
}

.reviews-marquee.is-running .reviews-marquee__track {
  animation-play-state: running;
}

.reviews-marquee:hover .reviews-marquee__track,
.reviews-marquee:focus-within .reviews-marquee__track {
  animation-play-state: paused;
}

@keyframes reviews-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.review-card {
  flex: 0 0 auto;
  width: clamp(280px, 32vw, 380px);
  background: var(--vr-creme, #f5efe3);
  color: var(--vr-text, #1d1614);
  padding: 28px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.40);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.10),
    0 6px 14px rgba(0, 0, 0, 0.22),
    0 22px 48px rgba(0, 0, 0, 0.32);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: transform 400ms var(--reveal-ease, cubic-bezier(0.22, 1, 0.36, 1));
}

@media (hover: hover) {
  .review-card:hover {
    transform: translateY(-4px);
  }
}

.review-card__stars {
  display: flex;
  gap: 2px;
  color: var(--vr-gold, #c08c2e);
}
.review-star { fill: currentColor; }
.review-star--empty { color: rgba(0, 0, 0, 0.10); }

.review-card__text {
  font-style: italic;
  line-height: 1.5;
  margin: 0;
}

.review-card__author {
  font-style: normal;
  font-weight: 600;
  font-size: 0.9rem;
  opacity: 0.78;
  margin-top: auto;
}

@media (prefers-reduced-motion: reduce) {
  .reviews-marquee__track { animation: none !important; }
  .reviews-marquee { mask-image: none !important; -webkit-mask-image: none !important; }
}

@media (max-width: 768px) {
  .reviews-marquee__track { animation-duration: 45s; }
  .review-card { width: 84vw; padding: 22px; }
}




/* ============================================================
 * STICKY HEADER mit Scroll Compaction
 * Bleibt oben kleben, schrumpft beim Scrollen, Glas Effekt.
 * ============================================================ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 90;
  background: rgba(245, 239, 227, 0.78);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
          backdrop-filter: saturate(140%) blur(12px);
  transition:
    box-shadow 350ms cubic-bezier(0.22, 1, 0.36, 1),
    background 350ms cubic-bezier(0.22, 1, 0.36, 1);
}

.site-header.is-scrolled {
  background: rgba(245, 239, 227, 0.94);
  box-shadow:
    0 1px 0 rgba(40, 18, 18, 0.06),
    0 12px 28px rgba(40, 18, 18, 0.10);
}

.site-header__inner {
  transition: padding 350ms cubic-bezier(0.22, 1, 0.36, 1);
}
.site-header.is-scrolled .site-header__inner {
  padding-top: 8px;
  padding-bottom: 8px;
}

.site-header__logo {
  transition: transform 350ms cubic-bezier(0.22, 1, 0.36, 1);
  transform-origin: left center;
}
.site-header.is-scrolled .site-header__logo {
  transform: scale(0.82);
}

/* Scroll Progress Bar bleibt sichtbar oben */
.scroll-progress {
  z-index: 100;
}

/* Anchor Links nicht hinter Sticky verstecken */
section[id] {
  scroll-margin-top: 96px;
}

@media (max-width: 768px) {
  section[id] { scroll-margin-top: 72px; }
}

@media (prefers-reduced-motion: reduce) {
  .site-header,
  .site-header__inner,
  .site-header__logo {
    transition: none !important;
    transform: none !important;
  }
}


/* ============================================================
 * CARD SHADOW v2
 * Drei Dinge Karten, Anfahrt Cards, Quote Cards.
 * Sichtbarer Schatten, klar abgehoben.
 * ============================================================ */
.section-creme .card,
.section-papier .card {
  border: 1px solid rgba(40, 18, 18, 0.06);
  box-shadow:
    0 1px 2px rgba(40, 18, 18, 0.06),
    0 6px 14px rgba(40, 18, 18, 0.10),
    0 18px 36px rgba(40, 18, 18, 0.14);
  transition:
    transform 300ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 300ms cubic-bezier(0.22, 1, 0.36, 1);
}

@media (hover: hover) {
  .section-creme .card:hover,
  .section-papier .card:hover {
    transform: translateY(-4px);
    box-shadow:
      0 2px 4px rgba(40, 18, 18, 0.08),
      0 10px 22px rgba(40, 18, 18, 0.16),
      0 28px 56px rgba(40, 18, 18, 0.22);
  }
}


/* ============================================================
 * LIGHTBOX
 * Klick auf Bild oeffnet vollformat Modal mit dunklem Backdrop.
 * Esc oder Click ausserhalb schliesst.
 * ============================================================ */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(20, 12, 10, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 250ms cubic-bezier(0.22, 1, 0.36, 1);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
}

.lightbox.is-open {
  opacity: 1;
  pointer-events: auto;
}

.lightbox__img {
  max-width: 92vw;
  max-height: 88vh;
  border-radius: 16px;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.15),
    0 30px 80px rgba(0, 0, 0, 0.6);
  transform: scale(0.94);
  transition: transform 350ms cubic-bezier(0.22, 1, 0.36, 1);
}

.lightbox.is-open .lightbox__img {
  transform: scale(1);
}

.lightbox__close {
  position: absolute;
  top: 20px;
  right: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.24);
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 200ms;
}

.lightbox__close:hover {
  background: rgba(255, 255, 255, 0.20);
}

@media (prefers-reduced-motion: reduce) {
  .lightbox,
  .lightbox__img {
    transition: none !important;
  }
  main .picture-wrap:hover {
    transform: none !important;
  }
  main .picture-wrap:hover > img,
  main .picture-wrap:hover > picture > img {
    transform: none !important;
  }
}


/* ============================================================
 * EFFEKT image-fade
 * Sanfter Fade aus dem Hintergrund, 500ms.
 * Kein clip-path, kein Konflikt mit Hover Scale.
 * Speziell fuer Brunnen Sektion.
 * ============================================================ */
html.js-reveal [data-reveal-effect="image-fade"] .picture-wrap {
  opacity: 0;
  transition: opacity 500ms cubic-bezier(0.22, 1, 0.36, 1);
}
html.js-reveal [data-reveal-effect="image-fade"].is-revealed .picture-wrap {
  opacity: 1;
}

html.js-reveal [data-reveal-effect="image-fade"] .stack-lg > * {
  opacity: 0;
  transform: translateX(24px);
  transition:
    opacity 800ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 800ms cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 200ms;
}
html.js-reveal [data-reveal-effect="image-fade"].is-revealed .stack-lg > * {
  opacity: 1;
  transform: translateX(0);
}


/* ============================================================
 * IMAGE TREATMENT v6 NO RACE
 * Hover ist nur box-shadow Aenderung, kein Transform mehr.
 * Damit kann Bild nie mit Hover konkurrieren, kein Zittern.
 * Bild bleibt visuell ruhig, Schatten waechst beim Hover.
 * ============================================================ */
main .picture-wrap {
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.45);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.06),
    0 4px 10px rgba(40, 18, 18, 0.16),
    0 16px 32px rgba(40, 18, 18, 0.22),
    0 32px 64px rgba(40, 18, 18, 0.18);
  isolation: isolate;
  cursor: zoom-in;
  transition: box-shadow 600ms cubic-bezier(0.22, 1, 0.36, 1);
}

main .picture-wrap > img,
main .picture-wrap > picture,
main .picture-wrap > picture > img {
  border-radius: inherit;
  pointer-events: none;
  transition: filter 600ms cubic-bezier(0.22, 1, 0.36, 1);
}

main .picture-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.30);
  pointer-events: none;
  z-index: 2;
}

@media (hover: hover) {
  main .picture-wrap:hover {
    box-shadow:
      0 0 0 1px rgba(0, 0, 0, 0.10),
      0 8px 18px rgba(40, 18, 18, 0.26),
      0 28px 56px rgba(40, 18, 18, 0.36),
      0 56px 112px rgba(40, 18, 18, 0.32),
      0 80px 160px rgba(40, 18, 18, 0.22);
  }
  main .picture-wrap:hover > img,
  main .picture-wrap:hover > picture > img {
    filter: brightness(1.06);
  }
}

.section-burgund .picture-wrap,
.section-anthrazit .picture-wrap {
  border-color: rgba(255, 230, 200, 0.25);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.16),
    0 6px 12px rgba(0, 0, 0, 0.40),
    0 20px 40px rgba(0, 0, 0, 0.45),
    0 50px 100px rgba(0, 0, 0, 0.34);
}

@media (prefers-reduced-motion: reduce) {
  main .picture-wrap,
  main .picture-wrap > img,
  main .picture-wrap > picture > img {
    transition: none !important;
    filter: none !important;
  }
}




/* ============================================================
 * BRUNNEN SEKTION FINAL
 * 2000ms Fade von 0 zu 1.
 * Sanftes Hover Scale auf das Bild im Inneren.
 * Container bleibt fix, dadurch kein Race mit Reveal.
 * ============================================================ */
html.js-reveal #aussen .picture-wrap {
  opacity: 0 !important;
  transition: opacity 2000ms cubic-bezier(0.4, 0, 0.2, 1) !important;
}

html.js-reveal #aussen.is-revealed .picture-wrap {
  opacity: 1 !important;
}

#aussen .picture-wrap > img,
#aussen .picture-wrap > picture > img {
  pointer-events: none;
  transition:
    transform 900ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 900ms cubic-bezier(0.22, 1, 0.36, 1) !important;
  transform-origin: center center;
}

@media (hover: hover) {
  #aussen .picture-wrap:hover > img,
  #aussen .picture-wrap:hover > picture > img {
    transform: scale(1.05) !important;
    filter: brightness(1.05);
  }
  #aussen .picture-wrap:hover {
    box-shadow:
      0 0 0 1px rgba(0, 0, 0, 0.10),
      0 8px 18px rgba(40, 18, 18, 0.26),
      0 28px 56px rgba(40, 18, 18, 0.36),
      0 56px 112px rgba(40, 18, 18, 0.32) !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #aussen .picture-wrap > img,
  #aussen .picture-wrap > picture > img {
    transition: none !important;
    transform: none !important;
    filter: none !important;
  }
}


/* ============================================================
 * REVIEW MODAL mit Bokeh Hintergrund
 * Klick auf Quote Card oeffnet Modal mit Blur Background.
 * ============================================================ */
.review-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 350ms cubic-bezier(0.22, 1, 0.36, 1);
  background: rgba(20, 12, 10, 0.55);
  -webkit-backdrop-filter: blur(28px) saturate(160%);
          backdrop-filter: blur(28px) saturate(160%);
}

.review-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}

.review-modal__content {
  position: relative;
  max-width: 640px;
  width: 92vw;
  background: var(--vr-creme, #f5efe3);
  color: var(--vr-text, #1d1614);
  padding: 56px 44px 44px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.40);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.10),
    0 30px 80px rgba(0, 0, 0, 0.55);
  transform: scale(0.94);
  transition: transform 400ms cubic-bezier(0.22, 1, 0.36, 1);
  text-align: center;
}

.review-modal.is-open .review-modal__content {
  transform: scale(1);
}

.review-modal__stars {
  display: inline-flex;
  gap: 5px;
  color: var(--vr-gold, #c08c2e);
  margin-bottom: 22px;
}

.review-modal__stars svg {
  width: 26px;
  height: 26px;
  fill: currentColor;
}

.review-modal__text {
  font-family: var(--vr-font-display, 'Fraunces', serif);
  font-size: clamp(1.25rem, 2.2vw, 1.6rem);
  line-height: 1.45;
  font-style: italic;
  margin: 0 0 28px;
}

.review-modal__author {
  font-style: normal;
  font-weight: 600;
  font-size: 1rem;
  opacity: 0.78;
}

.review-modal__close {
  position: absolute;
  top: 14px;
  right: 18px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: transparent;
  border: 1px solid rgba(40, 18, 18, 0.20);
  color: var(--vr-text, #1d1614);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 200ms;
}

.review-modal__close:hover {
  background: rgba(40, 18, 18, 0.08);
}

.review-card,
.section-burgund .quote-card {
  cursor: pointer;
}

@media (prefers-reduced-motion: reduce) {
  .review-modal,
  .review-modal__content {
    transition: none !important;
  }
}


/* ============================================================
 * EFFEKT menu-rise
 * Speisekarte Rubrik. Titel fade up, dann menu-item Artikel
 * gestaffelt von unten nach oben, einer nach dem anderen.
 * Speziell fuer die Karten Struktur mit .menu-item.
 * ============================================================ */
html.js-reveal [data-reveal-effect="menu-rise"] .menu-category__title {
  opacity: 0;
  transform: translateY(var(--reveal-distance));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="menu-rise"] .menu-item {
  opacity: 0;
  transform: translateY(calc(var(--reveal-distance) * 1.4));
  transition:
    opacity var(--reveal-child) var(--reveal-ease),
    transform var(--reveal-child) var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="menu-rise"] .menu-item:nth-child(1)  { transition-delay: 260ms; }
html.js-reveal [data-reveal-effect="menu-rise"] .menu-item:nth-child(2)  { transition-delay: 360ms; }
html.js-reveal [data-reveal-effect="menu-rise"] .menu-item:nth-child(3)  { transition-delay: 460ms; }
html.js-reveal [data-reveal-effect="menu-rise"] .menu-item:nth-child(4)  { transition-delay: 560ms; }
html.js-reveal [data-reveal-effect="menu-rise"] .menu-item:nth-child(5)  { transition-delay: 660ms; }
html.js-reveal [data-reveal-effect="menu-rise"] .menu-item:nth-child(6)  { transition-delay: 760ms; }
html.js-reveal [data-reveal-effect="menu-rise"] .menu-item:nth-child(7)  { transition-delay: 860ms; }
html.js-reveal [data-reveal-effect="menu-rise"] .menu-item:nth-child(8)  { transition-delay: 960ms; }
html.js-reveal [data-reveal-effect="menu-rise"] .menu-item:nth-child(n+9) { transition-delay: 1060ms; }
html.js-reveal [data-reveal-effect="menu-rise"].is-revealed .menu-category__title,
html.js-reveal [data-reveal-effect="menu-rise"].is-revealed .menu-item {
  opacity: 1;
  transform: translateY(0);
}


/* ============================================================
 * EFFEKT menu-slide
 * Speisekarte Rubrik, Variante. Titel fade up, dann menu-item
 * Artikel abwechselnd von links und rechts in die Mitte.
 * ============================================================ */
html.js-reveal [data-reveal-effect="menu-slide"] .menu-category__title {
  opacity: 0;
  transform: translateY(var(--reveal-distance));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="menu-slide"] .menu-item {
  opacity: 0;
  transition:
    opacity var(--reveal-child) var(--reveal-ease),
    transform var(--reveal-child) cubic-bezier(0.22, 1.08, 0.36, 1);
}
html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(odd) {
  transform: translateX(calc(-1 * var(--reveal-distance) * 3.5));
}
html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(even) {
  transform: translateX(calc(var(--reveal-distance) * 3.5));
}
html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(1) { transition-delay: 240ms; }
html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(2) { transition-delay: 320ms; }
html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(3) { transition-delay: 400ms; }
html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(4) { transition-delay: 480ms; }
html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(5) { transition-delay: 560ms; }
html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(6) { transition-delay: 640ms; }
html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(n+7) { transition-delay: 720ms; }
html.js-reveal [data-reveal-effect="menu-slide"].is-revealed .menu-category__title,
html.js-reveal [data-reveal-effect="menu-slide"].is-revealed .menu-item {
  opacity: 1;
  transform: translateX(0) translateY(0);
}

/* Mobile zahmer */
@media (max-width: 768px) {
  html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(odd) {
    transform: translateX(-24px);
  }
  html.js-reveal [data-reveal-effect="menu-slide"] .menu-item:nth-child(even) {
    transform: translateX(24px);
  }
}


/* ============================================================
 * EFFEKT legend-reveal
 * Speisekarte Allergen Legende. Kopf fade up, dann die beiden
 * legend-block von links und rechts in die Mitte, Footnote nach.
 * ============================================================ */
html.js-reveal [data-reveal-effect="legend-reveal"] .section-head > * {
  opacity: 0;
  transform: translateY(var(--reveal-distance));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="legend-reveal"] .section-head > *:nth-child(2) { transition-delay: 120ms; }
html.js-reveal [data-reveal-effect="legend-reveal"] .section-head > *:nth-child(3) { transition-delay: 240ms; }
html.js-reveal [data-reveal-effect="legend-reveal"] .legend-block {
  opacity: 0;
  transition:
    opacity var(--reveal-child) var(--reveal-ease),
    transform var(--reveal-child) cubic-bezier(0.22, 1.08, 0.36, 1);
}
html.js-reveal [data-reveal-effect="legend-reveal"] .legend-block:nth-child(1) {
  transform: translateX(calc(-1 * var(--reveal-distance) * 4)) scale(0.92);
  transition-delay: 360ms;
}
html.js-reveal [data-reveal-effect="legend-reveal"] .legend-block:nth-child(2) {
  transform: translateX(calc(var(--reveal-distance) * 4)) scale(0.92);
  transition-delay: 460ms;
}
html.js-reveal [data-reveal-effect="legend-reveal"] .legend-footnote {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity var(--reveal-child) var(--reveal-ease),
    transform var(--reveal-child) var(--reveal-ease);
  transition-delay: 600ms;
}
html.js-reveal [data-reveal-effect="legend-reveal"].is-revealed .section-head > *,
html.js-reveal [data-reveal-effect="legend-reveal"].is-revealed .legend-block,
html.js-reveal [data-reveal-effect="legend-reveal"].is-revealed .legend-footnote {
  opacity: 1;
  transform: translateX(0) translateY(0);
}

@media (max-width: 768px) {
  html.js-reveal [data-reveal-effect="legend-reveal"] .legend-block:nth-child(1) {
    transform: translateX(-24px);
  }
  html.js-reveal [data-reveal-effect="legend-reveal"] .legend-block:nth-child(2) {
    transform: translateX(24px);
  }
}


/* ============================================================
 * EFFEKT cta-reveal
 * Speisekarte CTA Bordeaux. Kopf fade up, dann die drei Buttons
 * im Cluster gestaffelt mit Scale Pop.
 * ============================================================ */
html.js-reveal [data-reveal-effect="cta-reveal"] .section-head > * {
  opacity: 0;
  transform: translateY(var(--reveal-distance));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease),
    transform var(--reveal-duration) var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="cta-reveal"] .section-head > *:nth-child(2) { transition-delay: 130ms; }
html.js-reveal [data-reveal-effect="cta-reveal"] .section-head > *:nth-child(3) { transition-delay: 260ms; }
html.js-reveal [data-reveal-effect="cta-reveal"] .cluster > * {
  opacity: 0;
  transform: scale(0.86);
  transition:
    opacity var(--reveal-child) var(--reveal-ease),
    transform var(--reveal-child) cubic-bezier(0.22, 1.12, 0.36, 1);
}
html.js-reveal [data-reveal-effect="cta-reveal"] .cluster > *:nth-child(1) { transition-delay: 420ms; }
html.js-reveal [data-reveal-effect="cta-reveal"] .cluster > *:nth-child(2) { transition-delay: 520ms; }
html.js-reveal [data-reveal-effect="cta-reveal"] .cluster > *:nth-child(3) { transition-delay: 620ms; }
html.js-reveal [data-reveal-effect="cta-reveal"].is-revealed .section-head > *,
html.js-reveal [data-reveal-effect="cta-reveal"].is-revealed .cluster > * {
  opacity: 1;
  transform: scale(1) translateY(0);
}


/* ============================================================
 * cta-reveal ERWEITERUNG: Curtain Hintergrund
 * Roter Block oeffnet sich aus der Mitte nach links und rechts,
 * wie curtain-stage auf der Startseite. Inhalt faded danach.
 * ============================================================ */
html.js-reveal [data-reveal-effect="cta-reveal"] {
  clip-path: inset(0 50% 0 50%);
  transition: clip-path 2000ms var(--reveal-ease);
}
html.js-reveal [data-reveal-effect="cta-reveal"].is-revealed {
  clip-path: inset(0 0 0 0);
}

@media (max-width: 768px) {
  html.js-reveal [data-reveal-effect="cta-reveal"] {
    clip-path: inset(0 20% 0 20%);
  }
}

@media (prefers-reduced-motion: reduce) {
  html.js-reveal [data-reveal-effect="cta-reveal"] {
    clip-path: none !important;
  }
}
