/* Animations */
@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translateX(-30px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translateY(-30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes imageZoomIn {
  from {
    opacity: 0;
    transform: scale(0.5) rotate(-10deg);
  }
  to {
    opacity: 1;
    transform: scale(1) rotate(0deg);
  }
}

@keyframes float {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  25% { transform: translateY(-10px) rotate(2deg); }
  50% { transform: translateY(0px) rotate(0deg); }
  75% { transform: translateY(-5px) rotate(-2deg); }
}

@keyframes rotateBorder {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@keyframes borderPulse {
  from { box-shadow: 0 0 20px rgba(141, 20, 121, 0.5),
                    0 0 40px rgba(184, 0, 204, 0.3),
                    inset 0 0 10px rgba(141, 20, 121, 0.3); }
  to { box-shadow: 0 0 40px rgba(141, 20, 121, 0.8),
                  0 0 80px rgba(184, 0, 204, 0.5),
                  inset 0 0 20px rgba(141, 20, 121, 0.5); }
}

@keyframes imageGlow {
  from { box-shadow: 0 0 20px rgba(141, 20, 121, 0.3); }
  to { box-shadow: 0 0 40px rgba(141, 20, 121, 0.6); }
}

@keyframes floatParticle {
  0% {
    transform: translateY(0) rotate(0deg);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% {
    transform: translateY(-100vh) rotate(720deg);
    opacity: 0;
  }
}