/* ===================================
  KEYFRAMES ANIMATIONS
  =================================== */

/* Continuous spin animation */
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

/* FWP Pulse and transitions (currently commented out)
@keyframes fwpPulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.15);
    box-shadow: var(--glow-accent);
  }
}

@keyframes fwpEnter {
  from {
    opacity: 0;
    transform: translateX(-50%) scale(0.8);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) scale(1);
  }
}

@keyframes fwpExit {
  from {
    opacity: 1;
    transform: translateX(-50%) scale(1);
  }
  to {
    opacity: 0;
    transform: translateX(-50%) scale(0.8);
  }
}

#fwpDisplay.entering {
  animation: fwpEnter 0.5s var(--ease-out) forwards;
}

#fwpDisplay.exiting {
  animation: fwpExit 0.5s var(--ease-out) forwards;
}
*/

/* Character entrance animation */
@keyframes characterEnter {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Text fade-in for dialogue or UI */
@keyframes textFadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Correct selection pulse */
@keyframes correctPulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
}

/* Shake effect for wrong selection or error feedback */
@keyframes shake {
  0%, 100% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-8px);
  }
  75% {
    transform: translateX(8px);
  }
}

/* Slide in from right for panels or menus */
@keyframes slideInFromRight {
  from {
    transform: translateX(100%);
  }
  to {
    transform: translateX(0);
  }
}

/* Simple fade-in */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
