/* ============ MOT-2 — Slide directionnel ============ */
/* Note : overflow-x:clip sur body empêche le scroll horizontal des éléments
   qui font translateX avant d'entrer dans le viewport (PIÈGE #13) */

[data-reveal] {
  opacity: 0;
  transition: opacity .6s ease, transform .6s cubic-bezier(.2, .7, .2, 1);
}

[data-reveal] { transform: translateX(-28px); }
[data-reveal]:nth-child(even) { transform: translateX(28px); }

[data-reveal].in {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  [data-reveal] {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* Stagger sur les cards de galerie (via .stagger wrapper) */
.stagger > * {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .5s ease, transform .5s ease;
}

.stagger.in > * {
  opacity: 1;
  transform: none;
}

.stagger.in > *:nth-child(1)  { transition-delay: .04s; }
.stagger.in > *:nth-child(2)  { transition-delay: .10s; }
.stagger.in > *:nth-child(3)  { transition-delay: .16s; }
.stagger.in > *:nth-child(4)  { transition-delay: .22s; }
.stagger.in > *:nth-child(5)  { transition-delay: .28s; }
.stagger.in > *:nth-child(6)  { transition-delay: .34s; }
.stagger.in > *:nth-child(7)  { transition-delay: .40s; }
.stagger.in > *:nth-child(8)  { transition-delay: .46s; }

@media (prefers-reduced-motion: reduce) {
  .stagger > * {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* Compteurs stats strip */
@keyframes count-pulse {
  0%, 100% { opacity: 1; }
  50%  { opacity: .7; }
}
