/* Animations */

/* Scroll reveal */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

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

.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }

/* Fade in */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.fade-in { animation: fadeIn 0.4s ease; }

/* Slide up */
@keyframes slideUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.slide-up { animation: slideUp 0.5s ease; }

/* Pulse glow (for CTA) */
@keyframes pulseGlow {
  0%, 100% { box-shadow: 0 0 20px rgba(74, 108, 247, 0.2); }
  50% { box-shadow: 0 0 40px rgba(74, 108, 247, 0.4); }
}

.pulse-glow { animation: pulseGlow 2s ease infinite; }

/* Float */
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

.float { animation: float 3s ease-in-out infinite; }

/* Shimmer loading */
@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

.skeleton {
  background: linear-gradient(90deg, var(--bg-card) 25%, var(--bg-input) 50%, var(--bg-card) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--radius-sm);
}

/* Page transition */
.page-enter {
  animation: slideUp 0.3s ease;
}

/* Hero gradient animation */
@keyframes gradientMove {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.hero-gradient {
  background: linear-gradient(135deg, var(--bg-primary), #1a1040, var(--bg-primary), #102040);
  background-size: 400% 400%;
  animation: gradientMove 15s ease infinite;
}

html[data-theme="light"] .hero-gradient {
  background: linear-gradient(135deg, #eeeef5, #e0daf0, #eeeef5, #dae0f0);
  background-size: 400% 400%;
  animation: gradientMove 15s ease infinite;
}

/* Gold text shimmer */
@keyframes goldShimmer {
  0% { background-position: -200% center; }
  100% { background-position: 200% center; }
}

.gold-shimmer {
  background: linear-gradient(90deg, var(--gold) 0%, #fff 50%, var(--gold) 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: goldShimmer 3s linear infinite;
}

html[data-theme="light"] .gold-shimmer {
  background: linear-gradient(90deg, var(--gold) 0%, #333 50%, var(--gold) 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Counter animation */
.count-up {
  display: inline-block;
  font-variant-numeric: tabular-nums;
}
