/* ============================================
   Wrexham FC — Animations & Transitions
   ============================================ */

/* --- Scroll Reveal --- */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--delay, 0ms);
}

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

/* Reveal from left */
.reveal--left {
  opacity: 0;
  transform: translateX(-40px);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--delay, 0ms);
}

.reveal--left.reveal--visible {
  opacity: 1;
  transform: translateX(0);
}

/* Reveal from right */
.reveal--right {
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--delay, 0ms);
}

.reveal--right.reveal--visible {
  opacity: 1;
  transform: translateX(0);
}

/* Scale up reveal */
.reveal--scale {
  opacity: 0;
  transform: scale(0.95);
  transition: opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--delay, 0ms);
}

.reveal--scale.reveal--visible {
  opacity: 1;
  transform: scale(1);
}

/* --- Timeline Dot Pulse --- */
.timeline__dot {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.timeline__dot:hover {
  transform: scale(1.3);
}

.timeline__dot--ownership:hover {
  box-shadow: 0 0 16px rgba(212, 160, 23, 0.5);
}

.timeline__dot--promotion:hover {
  box-shadow: 0 0 16px rgba(0, 103, 71, 0.5);
}

.timeline__dot--signing:hover {
  box-shadow: 0 0 16px rgba(59, 130, 246, 0.5);
}

.timeline__dot--match:hover {
  box-shadow: 0 0 16px rgba(255, 255, 255, 0.4);
}

.timeline__dot--milestone:hover {
  box-shadow: 0 0 16px rgba(212, 160, 23, 0.5);
}

/* --- Card Hover Lift --- */
.season-card,
.player-card {
  will-change: transform;
}

/* --- Animated Counter --- */
.counter-animated {
  font-variant-numeric: tabular-nums;
}

/* --- Nav Link Underline Slide --- */
.nav__link::after {
  will-change: width;
}

/* --- Hero Fade In --- */
.hero__content {
  animation: heroFadeIn 1.2s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

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

.hero__badge {
  animation: heroFadeIn 1s cubic-bezier(0.22, 1, 0.36, 1) 0.2s both;
}

.hero__title {
  animation: heroFadeIn 1s cubic-bezier(0.22, 1, 0.36, 1) 0.4s both;
}

.hero__subtitle {
  animation: heroFadeIn 1s cubic-bezier(0.22, 1, 0.36, 1) 0.6s both;
}

.hero__scroll-indicator {
  animation: heroFadeIn 1s cubic-bezier(0.22, 1, 0.36, 1) 0.8s both;
}

/* --- Stat Number Glow on Reveal --- */
.about__stat-number,
.season-card__stat-value {
  transition: color 0.3s ease;
}

/* --- Scroll Progress Bar --- */
.scroll-progress {
  will-change: width;
  transition: none;
}

/* --- Mobile Nav Toggle Animation --- */
.nav__toggle--active span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

.nav__toggle--active span:nth-child(2) {
  opacity: 0;
}

.nav__toggle--active span:nth-child(3) {
  transform: rotate(-45deg) translate(5px, -5px);
}

/* --- Reduced Motion --- */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

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

  .hero__content,
  .hero__badge,
  .hero__title,
  .hero__subtitle,
  .hero__scroll-indicator {
    animation: none;
    opacity: 1;
    transform: none;
  }

  .hero__arrow {
    animation: none;
  }

  .player-card__inner {
    transition: none !important;
  }

  .player-card:hover .player-card__inner {
    transform: none !important;
  }

  .player-card__back {
    display: none;
  }

  .player-card__flip-hint {
    display: none;
  }
}
