/* ============================================================
   ROKDA7 — Animations & Scroll Reveal
   ============================================================ */

/* ---------- KEYFRAMES ---------- */
@keyframes floatPhone {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-14px); }
}

@keyframes pulseBadge {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.65; transform: scale(1.2); }
}

@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

@keyframes glowPulse {
  0%, 100% { box-shadow: 0 0 16px rgba(255, 30, 60, 0.30); }
  50%      { box-shadow: 0 0 40px rgba(255, 30, 60, 0.70); }
}

@keyframes neonFlicker {
  0%, 94%, 100% { opacity: 1; }
  95%, 99%      { opacity: 0.82; }
}

@keyframes slideInUp {
  from { opacity: 0; transform: translateY(40px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes borderScan {
  0%   { background-position: 0%; }
  100% { background-position: 200%; }
}

@keyframes blink {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.25; }
}

@keyframes spinSlow {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* ---- Redesigned hero scene ---- */
@keyframes deviceFloat {
  0%, 100% { transform: rotateY(-16deg) rotateX(6deg) rotateZ(1.5deg) translateY(0); }
  50%      { transform: rotateY(-13deg) rotateX(4deg) rotateZ(1deg) translateY(-16px); }
}
@keyframes floatY {
  0%, 100% { transform: translateY(0) rotate(-2deg); }
  50%      { transform: translateY(-16px) rotate(-2deg); }
}
@keyframes floatY2 {
  0%, 100% { transform: translateY(0) rotate(2deg); }
  50%      { transform: translateY(14px) rotate(2deg); }
}
@keyframes floatY3 {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-10px); }
}
@keyframes glowMove {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: .85; }
  50%      { transform: translate(18px, -14px) scale(1.08); opacity: 1; }
}
@keyframes crashDraw {
  0%   { stroke-dashoffset: 360; }
  60%  { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: 0; }
}
@keyframes crashDot {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.5); opacity: .6; }
}
@keyframes coinSpin {
  0%, 100% { transform: translateY(0) rotate(-8deg); }
  50%      { transform: translateY(-18px) rotate(8deg); }
}
@keyframes sheen {
  0%   { transform: translateX(-120%) skewX(-18deg); }
  60%, 100% { transform: translateX(220%) skewX(-18deg); }
}

/* ---------- REVEAL CLASSES ---------- */
.reveal       { opacity: 0; transform: translateY(36px); transition: opacity .7s var(--ease, ease), transform .7s var(--ease, ease); }
.reveal-left  { opacity: 0; transform: translateX(-46px); transition: opacity .7s var(--ease, ease), transform .7s var(--ease, ease); }
.reveal-right { opacity: 0; transform: translateX(46px);  transition: opacity .7s var(--ease, ease), transform .7s var(--ease, ease); }

.reveal.revealed,
.reveal-left.revealed,
.reveal-right.revealed { opacity: 1; transform: none; }

/* ---------- STAGGER ---------- */
.stagger > * { opacity: 0; transform: translateY(28px); transition: opacity .6s var(--ease, ease), transform .6s var(--ease, ease); }
.stagger.revealed > * { opacity: 1; transform: none; }
.stagger.revealed > *:nth-child(1) { transition-delay: 0s; }
.stagger.revealed > *:nth-child(2) { transition-delay: 0.08s; }
.stagger.revealed > *:nth-child(3) { transition-delay: 0.16s; }
.stagger.revealed > *:nth-child(4) { transition-delay: 0.24s; }
.stagger.revealed > *:nth-child(5) { transition-delay: 0.32s; }
.stagger.revealed > *:nth-child(6) { transition-delay: 0.40s; }
.stagger.revealed > *:nth-child(7) { transition-delay: 0.48s; }
.stagger.revealed > *:nth-child(8) { transition-delay: 0.56s; }
.stagger.revealed > *:nth-child(9) { transition-delay: 0.64s; }
.stagger.revealed > *:nth-child(10){ transition-delay: 0.72s; }

/* ---------- EFFECT HELPERS ---------- */
.card-neon { transition: box-shadow .3s, border-color .3s, transform .25s; }
.card-neon:hover { box-shadow: 0 0 28px rgba(255,30,60,0.35); border-color: var(--red-primary); }

.anim-glow-pulse { animation: glowPulse 2.4s ease-in-out infinite; }
.anim-neon-flicker { animation: neonFlicker 4s infinite; }
.anim-float { animation: floatPhone 6s ease-in-out infinite; }
.anim-pulse-badge { animation: pulseBadge 1.8s ease-in-out infinite; }
.anim-blink { animation: blink 1.4s ease-in-out infinite; }

/* ---------- REDUCED MOTION ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .reveal, .reveal-left, .reveal-right, .stagger > * { opacity: 1 !important; transform: none !important; }
  .ticker-track { animation: none !important; }
}
