/* ============================================
   BOTOLA INSIGHTS - Animations
   ============================================ */

/* --- Pulse for live badge --- */
@keyframes pulse-live {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.4;
    transform: scale(0.75);
  }
}

/* --- Fade-in reveal system --- */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

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

/* Stagger delays */
.reveal[data-delay="0"] { transition-delay: 0ms; }
.reveal[data-delay="1"] { transition-delay: 120ms; }
.reveal[data-delay="2"] { transition-delay: 240ms; }
.reveal[data-delay="3"] { transition-delay: 360ms; }

/* --- Hero entrance animations --- */
.hero-badge {
  opacity: 0;
  transform: translateY(20px);
  animation: hero-fade-in 0.6s ease forwards 0.2s;
}

.hero-title {
  opacity: 0;
  transform: translateY(40px);
  animation: hero-fade-in 0.8s ease forwards 0.4s;
}

.hero-sub {
  opacity: 0;
  transform: translateY(30px);
  animation: hero-fade-in 0.7s ease forwards 0.7s;
}

.hero .cta-button {
  opacity: 0;
  transform: translateY(20px);
  animation: hero-fade-in 0.6s ease forwards 1.0s;
}

@keyframes hero-fade-in {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* --- Pitch grid parallax (subtle) --- */
.hero-pitch-grid {
  transition: transform 0.1s linear;
  will-change: transform;
}

/* --- Stat number count-up glow --- */
.stat-number.counted {
  color: var(--text-primary);
}

/* --- Service card icon subtle float --- */
.service-card:hover .service-icon {
  transform: translateY(-2px);
  transition: transform 0.3s ease;
}

/* --- Nav scroll state --- */
header.scrolled {
  background: rgba(10, 15, 30, 0.95);
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.3);
}

/* --- Glow keyframes for accent elements --- */
@keyframes glow-pulse {
  0%, 100% {
    box-shadow: 0 0 20px var(--accent-glow);
  }
  50% {
    box-shadow: 0 0 40px var(--accent-glow), 0 0 60px rgba(26, 110, 245, 0.15);
  }
}

/* --- Smooth underline slide for links --- */
@keyframes underline-slide {
  from { width: 0; }
  to { width: 100%; }
}
