/* MOT-4 : Texte masque montant (titres apparaissent depuis un masque) + fade pour le reste */
.reveal-mask {
  overflow: hidden;
  display: block;
}
.reveal-mask > * {
  display: inline-block;
  transform: translateY(105%);
  transition: transform .7s cubic-bezier(.2,.8,.2,1);
  will-change: transform;
}
.reveal-mask.in > * {
  transform: none;
}

/* Fade sobre pour le reste des elements reveles */
[data-reveal]:not(.reveal-mask) {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1);
  will-change: opacity, transform;
}
[data-reveal]:not(.reveal-mask).in {
  opacity: 1;
  transform: none;
}

/* Stagger sur les grilles (services, gallery, faq, contact rows) */
.stagger > * {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .55s ease, transform .55s ease;
}
.stagger.in > * { opacity: 1; transform: none; }
.stagger.in > *:nth-child(1) { transition-delay: .05s; }
.stagger.in > *:nth-child(2) { transition-delay: .12s; }
.stagger.in > *:nth-child(3) { transition-delay: .19s; }
.stagger.in > *:nth-child(4) { transition-delay: .26s; }
.stagger.in > *:nth-child(5) { transition-delay: .33s; }
.stagger.in > *:nth-child(6) { transition-delay: .40s; }
.stagger.in > *:nth-child(7) { transition-delay: .47s; }
.stagger.in > *:nth-child(8) { transition-delay: .54s; }

@media (prefers-reduced-motion: reduce) {
  .reveal-mask > *,
  [data-reveal],
  .stagger > * {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .dispo-dot::after { animation: none; }
}
