/* ==========================================================================
   animations.css — ScaleWthUs
   All @keyframe definitions and animation-specific classes
   ========================================================================== */

/* ===== TICKER SCROLL ANIMATION ===== */
@keyframes tickerMove {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.ticker-track {
  animation: tickerMove 25s linear infinite;
}

/* ===== SCROLL REVEAL ===== */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ===== HERO GLOW PULSE ===== */
@keyframes glowPulse {
  0%, 100% { opacity: 0.7; transform: translate(-50%, -50%) scale(1); }
  50%       { opacity: 1;   transform: translate(-50%, -50%) scale(1.08); }
}
.hero-glow {
  animation: glowPulse 6s ease-in-out infinite;
}

/* ===== FLOATING BADGE CARDS ===== */
@keyframes floatBadge {
  0%, 100% { transform: translateY(-50%) translateX(0);  }
  50%       { transform: translateY(-50%) translateX(-6px); }
}
.hero-badge {
  animation: floatBadge 4s ease-in-out infinite;
}

/* ===== STAGGER HELPERS ===== */
/* Used inline via style="transition-delay: Xs" on reveal elements */
.reveal-delay-1 { transition-delay: 0.05s; }
.reveal-delay-2 { transition-delay: 0.10s; }
.reveal-delay-3 { transition-delay: 0.15s; }
.reveal-delay-4 { transition-delay: 0.20s; }
.reveal-delay-5 { transition-delay: 0.25s; }

/* ===== SMOOTH FADE IN (page load) ===== */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.fade-in {
  animation: fadeIn 0.7s ease forwards;
}

/* ===== SHINE BUTTON EFFECT ===== */
@keyframes btnShine {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}
.btn-primary::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    105deg,
    transparent 40%,
    rgba(255, 255, 255, 0.12) 50%,
    transparent 60%
  );
  background-size: 200% 100%;
  opacity: 0;
  transition: opacity 0.3s;
}
.btn-primary {
  position: relative;
  overflow: hidden;
}
.btn-primary:hover::after {
  opacity: 1;
  animation: btnShine 0.7s linear;
}
