/* ─── ANIMACIONES ────────────────────────────────────── */

/* ── Scroll reveal base ── */
.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out);
}

.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

.reveal[data-direction="left"] {
  transform: translateX(-40px);
}

.reveal[data-direction="right"] {
  transform: translateX(40px);
}

.reveal[data-direction="left"].revealed,
.reveal[data-direction="right"].revealed {
  transform: translateX(0);
}

.reveal[data-scale] {
  transform: scale(0.94);
}

.reveal[data-scale].revealed {
  transform: scale(1);
}

/* Delays */
.reveal[data-delay="100"]  { transition-delay: 100ms; }
.reveal[data-delay="150"]  { transition-delay: 150ms; }
.reveal[data-delay="200"]  { transition-delay: 200ms; }
.reveal[data-delay="300"]  { transition-delay: 300ms; }
.reveal[data-delay="400"]  { transition-delay: 400ms; }
.reveal[data-delay="500"]  { transition-delay: 500ms; }
.reveal[data-delay="600"]  { transition-delay: 600ms; }

/* ── Hero entrada (stagger inline) ── */
.hero-animate {
  opacity: 0;
  transform: translateY(30px);
  animation: heroFadeUp 0.8s var(--ease-out) forwards;
}

@keyframes heroFadeUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ── Scroll indicator pulse ── */
@keyframes scrollPulse {
  0%, 100% { transform: scaleY(1); opacity: 1; }
  50%       { transform: scaleY(0.3); opacity: 0.4; }
}

/* ── Marquee ── */
@keyframes marqueeScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── Hero fallback gradient pulse ── */
@keyframes heroPulse {
  0%, 100% { opacity: 0.6; }
  50%       { opacity: 0.9; }
}

/* ── Proceso número flip ── */
@keyframes numFlipOut {
  to { transform: rotateX(-90deg); opacity: 0; }
}

@keyframes numFlipIn {
  from { transform: rotateX(90deg); opacity: 0; }
  to   { transform: rotateX(0deg); opacity: 1; }
}
