/* ============================================================
   YolyLuxeSpa — Luxury Scroll Reveal Animations
   ============================================================ */

/* ── Base: alle reveal-elementen starten verborgen ────────── */
.reveal,
.reveal-left,
.reveal-right,
.reveal-scale,
.reveal-fade,
.reveal-line {
  opacity: 0;
  will-change: opacity, transform;
}

/* Overgangsgedrag (gedeeld) */
.reveal,
.reveal-left,
.reveal-right,
.reveal-scale,
.reveal-fade {
  transition-property: opacity, transform;
  transition-duration: 1s;
  transition-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── Beginposities per variant ────────────────────────────── */

/* Standaard: fade omhoog (tekst, kaarten, koppen) */
.reveal {
  transform: translateY(60px);
}

/* Van links (linker kolommen, tekst naast afbeeldingen) */
.reveal-left {
  transform: translateX(-50px);
  transition-property: opacity, transform;
  transition-duration: 1.1s;
  transition-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
}

/* Van rechts (rechter kolommen, afbeeldingen rechts) */
.reveal-right {
  transform: translateX(50px);
  transition-property: opacity, transform;
  transition-duration: 1.1s;
  transition-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
}

/* Subtiele zoom-in (grote afbeeldingen, hero-foto's) */
.reveal-scale {
  transform: scale(0.95);
  transition-property: opacity, transform;
  transition-duration: 1.3s;
  transition-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
}

/* Alleen opacity (brede achtergrondblokken, overlays) */
.reveal-fade {
  transform: none;
  transition-property: opacity;
  transition-duration: 1.2s;
  transition-timing-function: cubic-bezier(0.25, 0.1, 0.25, 1);
}

/* Horizontale lijn sweep (decoratieve lijnen, dividers) */
.reveal-line {
  transform: scaleX(0);
  transform-origin: left center;
  transition-property: opacity, transform;
  transition-duration: 1s;
  transition-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── Zichtbaar staat (na .visible class via JS) ───────────── */
.reveal.visible,
.reveal-left.visible,
.reveal-right.visible,
.reveal-scale.visible,
.reveal-fade.visible,
.reveal-line.visible {
  opacity: 1;
  transform: none;
  will-change: auto;
}

/* ── Stagger vertragingen ────────────────────────────────── */
/* Handmatig */
.reveal-d1 { transition-delay: 0.1s; }
.reveal-d2 { transition-delay: 0.2s; }
.reveal-d3 { transition-delay: 0.3s; }
.reveal-d4 { transition-delay: 0.4s; }
.reveal-d5 { transition-delay: 0.5s; }
.reveal-d6 { transition-delay: 0.6s; }

/* ── Gouden streep onder sectiekoppen ────────────────────── */
/* De kop zelf revealt, daarna loopt de lijn in */
.section-title {
  position: relative;
}
.section-title::after {
  content: '';
  display: block;
  width: 48px;
  height: 2px;
  background: linear-gradient(90deg, #A8884E, #C5A572, #D4B882);
  margin-top: 12px;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  transition-delay: 0.5s;
}
.section-title.visible::after {
  transform: scaleX(1);
}

/* Centraal uitgelijnde koppen: lijn gecentreerd */
.section-title[style*="center"]::after,
.section-title.text-center::after {
  margin-left: auto;
  margin-right: auto;
}


/* ── Duurzaamheid: respecteer reduced-motion voorkeur ──────── */
@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal-left,
  .reveal-right,
  .reveal-scale,
  .reveal-fade,
  .reveal-line {
    opacity: 1;
    transform: none;
    transition: none;
    will-change: auto;
  }
  .section-title::after {
    transform: scaleX(1);
    transition: none;
  }
}
