/* === ANIMATIONS — MOT-3 STAGGER MARQUE === */

/* Reveal base */
[data-reveal] {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .55s var(--ease), transform .55s var(--ease);
}
[data-reveal].in {
  opacity: 1;
  transform: none;
}

/* Stagger — MOT-3 : delais .05s -> .50s par index */
[data-stagger] > * {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .5s var(--ease), transform .5s var(--ease);
}
[data-stagger] > *.in { opacity: 1; transform: none; }
[data-stagger] > *:nth-child(1) { transition-delay: .05s; }
[data-stagger] > *:nth-child(2) { transition-delay: .12s; }
[data-stagger] > *:nth-child(3) { transition-delay: .19s; }
[data-stagger] > *:nth-child(4) { transition-delay: .26s; }
[data-stagger] > *:nth-child(5) { transition-delay: .33s; }
[data-stagger] > *:nth-child(6) { transition-delay: .40s; }
[data-stagger] > *:nth-child(7) { transition-delay: .47s; }
[data-stagger] > *:nth-child(8) { transition-delay: .54s; }

/* Hero reveal-mask */
.reveal-mask {
  overflow: hidden;
}
.reveal-mask > * {
  transform: translateY(100%);
  transition: transform .7s var(--ease);
  display: block;
}
.reveal-mask.in > * { transform: none; }

/* Compteur stats */
.stat-number[data-counting] {
  opacity: 0;
  transition: opacity .3s;
}
.stat-number[data-counting].visible { opacity: 1; }

/* Réduit mouvement */
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
  [data-stagger] > * { opacity: 1; transform: none; transition: none; }
  .reveal-mask > * { transform: none; transition: none; }
  * { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
