/* ==========================================================================
   ANIMATIONS - Cyril Guilleminot Gaming Consulting
   ========================================================================== */

/* -------------------------------------------------------------------------
   KEYFRAME ANIMATIONS
   ------------------------------------------------------------------------- */

@keyframes float {
  0%, 100% {
    transform: translateY(0) rotate(0deg);
  }
  50% {
    transform: translateY(-20px) rotate(2deg);
  }
}

@keyframes pulse-glow {
  0%, 100% {
    opacity: 0.4;
    transform: scale(1);
  }
  50% {
    opacity: 0.6;
    transform: scale(1.05);
  }
}

@keyframes gradient-shift {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

@keyframes scroll-bounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(10px);
  }
}

@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes slide-up {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slide-down {
  from {
    opacity: 0;
    transform: translateY(-30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes glow-pulse {
  0%, 100% {
    box-shadow: 0 0 5px var(--neon-cyan), 0 0 10px var(--neon-cyan);
  }
  50% {
    box-shadow: 0 0 20px var(--neon-cyan), 0 0 40px var(--neon-cyan);
  }
}

@keyframes scan-line {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(100vh);
  }
}

@keyframes typing {
  from {
    width: 0;
  }
  to {
    width: 100%;
  }
}

@keyframes blink-cursor {
  0%, 50% {
    border-color: var(--neon-cyan);
  }
  51%, 100% {
    border-color: transparent;
  }
}

/* -------------------------------------------------------------------------
   SCROLL-TRIGGERED ANIMATIONS
   ------------------------------------------------------------------------- */

[data-animate] {
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.6s ease;
}

[data-animate="fade-up"] {
  transform: translateY(40px);
}

[data-animate="fade-down"] {
  transform: translateY(-40px);
}

[data-animate="fade-left"] {
  transform: translateX(40px);
}

[data-animate="fade-right"] {
  transform: translateX(-40px);
}

[data-animate="fade-in"] {
  transform: none;
}

[data-animate="scale-up"] {
  transform: scale(0.9);
}

[data-animate].visible {
  opacity: 1;
  transform: translate(0, 0) scale(1);
}

/* Stagger delays */
[data-delay="100"] { transition-delay: 0.1s; }
[data-delay="200"] { transition-delay: 0.2s; }
[data-delay="300"] { transition-delay: 0.3s; }
[data-delay="400"] { transition-delay: 0.4s; }
[data-delay="500"] { transition-delay: 0.5s; }
[data-delay="600"] { transition-delay: 0.6s; }
[data-delay="700"] { transition-delay: 0.7s; }
[data-delay="800"] { transition-delay: 0.8s; }

/* -------------------------------------------------------------------------
   APPLIED ANIMATIONS
   ------------------------------------------------------------------------- */

/* Floating orbs */
.floating-orb {
  animation: float 8s ease-in-out infinite, pulse-glow 4s ease-in-out infinite;
}

.orb-1 {
  animation-delay: 0s;
}

.orb-2 {
  animation-delay: -2s;
}

.orb-3 {
  animation-delay: -4s;
}

/* Gradient text animation */
.gradient-text {
  background-size: 200% 200%;
  animation: gradient-shift 4s ease infinite;
}

/* Scroll indicator */
.scroll-indicator {
  animation: scroll-bounce 2s ease-in-out infinite;
}

/* Hero entrance animations */
.hero.loaded .hero-badge {
  animation: slide-down 0.6s ease forwards;
}

.hero.loaded .hero-name {
  animation: slide-up 0.6s ease 0.2s forwards;
}

.hero.loaded .hero-tagline {
  animation: slide-up 0.6s ease 0.3s forwards;
}

.hero.loaded .hero-description {
  animation: fade-in 0.6s ease 0.4s forwards;
}

.hero.loaded .hero-stats {
  animation: fade-in 0.6s ease 0.5s forwards;
}

.hero.loaded .hero-cta {
  animation: slide-up 0.6s ease 0.6s forwards;
}

/* -------------------------------------------------------------------------
   HOVER ANIMATIONS
   ------------------------------------------------------------------------- */

/* Button hover glow */
.btn-primary:hover {
  animation: glow-pulse 1.5s ease-in-out infinite;
}

/* Card hover lift */
.service-card {
  transition: transform var(--transition-base),
              border-color var(--transition-base),
              box-shadow var(--transition-base);
}

.service-card:hover {
  transform: translateY(-8px);
}

/* Link underline animation */
.nav-links a:not(.nav-cta)::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--neon-cyan);
  transition: width var(--transition-base);
}

.nav-links a:not(.nav-cta):hover::after,
.nav-links a:not(.nav-cta).active::after {
  width: 100%;
}

/* -------------------------------------------------------------------------
   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;
  }

  [data-animate] {
    opacity: 1;
    transform: none;
  }
}

/* -------------------------------------------------------------------------
   MICRO-INTERACTIONS
   ------------------------------------------------------------------------- */

/* Typing effect cursor */
.hero-tagline.typing-ready {
  border-right: 3px solid var(--neon-cyan);
  animation: blink-cursor 0.8s step-end infinite;
  padding-right: 4px;
}

.hero-tagline.typing-done {
  border-right: none;
  animation: none;
  padding-right: 0;
}

/* Counter animation - smooth number transitions */
.stat-number {
  display: inline-block;
  min-width: 80px;
  font-variant-numeric: tabular-nums;
}

/* Custom cursor */
.custom-cursor {
  position: fixed;
  width: 40px;
  height: 40px;
  border: 2px solid var(--neon-cyan);
  border-radius: 50%;
  pointer-events: none;
  z-index: 10000;
  transform: translate(-50%, -50%);
  transition: width 0.2s ease, height 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
  mix-blend-mode: difference;
}

.custom-cursor-dot {
  position: fixed;
  width: 6px;
  height: 6px;
  background: var(--neon-magenta);
  border-radius: 50%;
  pointer-events: none;
  z-index: 10001;
  transform: translate(-50%, -50%);
}

.custom-cursor.cursor-hover {
  width: 60px;
  height: 60px;
  border-color: var(--neon-magenta);
  background: rgba(255, 0, 255, 0.1);
}

.custom-cursor-dot.cursor-hover {
  opacity: 0;
}

/* Hide default cursor when custom cursor is active */
.has-custom-cursor {
  cursor: none;
}

.has-custom-cursor a,
.has-custom-cursor button,
.has-custom-cursor [role="button"] {
  cursor: none;
}

/* Smoother section transitions */
.section {
  transition: opacity 0.3s ease;
}

/* Enhanced card transitions */
.service-card,
.highlight-card,
.timeline-content {
  transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              border-color 0.3s ease,
              box-shadow 0.3s ease;
}

/* Stat cards hover effect */
.stat {
  transition: transform 0.3s ease;
}

.stat:hover {
  transform: translateY(-4px);
}

/* Logo hover smooth transition */
.company-logo {
  transition: filter 0.4s ease, transform 0.3s ease;
}

.company-logo:hover {
  transform: scale(1.1);
}

/* Button ripple-like effect */
.btn {
  position: relative;
  overflow: hidden;
}

.btn::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  transition: width 0.6s ease, height 0.6s ease;
}

.btn:active::after {
  width: 300px;
  height: 300px;
}
