/* Optimized Animation CSS - Non-critical animations only */

/* Marquee animations - commonly used */
@keyframes scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

@keyframes scroll-reverse {
  0% {
    transform: translateX(-50%);
  }
  100% {
    transform: translateX(0);
  }
}

/* Float animations - for interactive elements */
@keyframes float {
  0%,
  100% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-10px);
  }
}

@keyframes float-slow {
  0%,
  100% {
    transform: translateY(0px) translateX(0px);
  }
  25% {
    transform: translateY(-10px) translateX(5px);
  }
  50% {
    transform: translateY(-5px) translateX(-5px);
  }
  75% {
    transform: translateY(-15px) translateX(3px);
  }
}

@keyframes float-slow-reverse {
  0%,
  100% {
    transform: translateY(0px) translateX(0px);
  }
  25% {
    transform: translateY(10px) translateX(-5px);
  }
  50% {
    transform: translateY(5px) translateX(5px);
  }
  75% {
    transform: translateY(15px) translateX(-3px);
  }
}

/* Pulse animations */
@keyframes pulse-gentle {
  0%,
  100% {
    opacity: 0.8;
    transform: scale(1);
  }
  50% {
    opacity: 0.4;
    transform: scale(1.05);
  }
}

/* Gradient animation */
@keyframes gradient-x {
  0%,
  100% {
    background-size: 200% 200%;
    background-position: left center;
  }
  50% {
    background-size: 200% 200%;
    background-position: right center;
  }
}

/* Utility classes */
.marquee {
  will-change: transform;
  animation: scroll 18s linear infinite;
}

.marquee-rtl {
  will-change: transform;
  animation: scroll-reverse 18s linear infinite;
}

.marquee:hover,
.marquee-rtl:hover {
  animation-play-state: paused;
}

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

.animate-float-slow {
  animation: float-slow 8s ease-in-out infinite;
}

.animate-float-slow-reverse {
  animation: float-slow-reverse 10s ease-in-out infinite;
}

.animate-pulse-gentle {
  animation: pulse-gentle 4s ease-in-out infinite;
}

.animate-gradient-x {
  animation: gradient-x 3s ease infinite;
}

/* Performance optimizations */
.animate-float,
.animate-float-slow,
.animate-float-slow-reverse {
  will-change: transform;
}

.animate-pulse-gentle {
  will-change: opacity, transform;
}

.animate-gradient-x {
  will-change: background-position;
}
