/* Centralized motion definitions. Names match legacy keyframes to keep UI identical. */
@keyframes ptrSpin {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

@keyframes cardAppear {
  0% {
    opacity: 0;
    transform: translateY(10px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}

@keyframes bootLoaderMove {
  0%,
  100% {
    transform: translateX(-80%);
  }

  50% {
    transform: translateX(80%);
  }
}

/* confirmSpin was identical to spin — use spin instead. */

@keyframes purseFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0) rotate(0deg);
  }

  50% {
    transform: translate3d(0, -4px, 0) rotate(-1.2deg);
  }
}

@keyframes maintenanceBreath {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }

  50% {
    transform: translateY(-2px) scale(1.03);
  }
}

@keyframes balancePillFlash {
  0%,
  100% {
    opacity: 1;
  }

  35% {
    opacity: 0.75;
  }
}

@keyframes toastSlidePop {
  0% {
    transform: translateY(calc(-100% - 18px)) scale(0.98);
  }

  60% {
    transform: translateY(0) scale(1.02);
  }

  100% {
    transform: translateY(0) scale(1);
  }
}

@keyframes iosBannerIn {
  0% {
    opacity: 0;
    transform: translate3d(0, calc(-100% - 16px), 0);
  }

  65% {
    opacity: 1;
    transform: translate3d(0, 6px, 0);
  }

  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes iosBannerOut {
  0% {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }

  100% {
    opacity: 0;
    transform: translate3d(0, calc(-100% - 16px), 0);
  }
}

.gift-card--enter {
  animation: cardAppear var(--dur-med, var(--gp-motion-medium)) var(--gp-motion-ease) both;
  animation-delay: var(--enter-delay, 0ms);
}

html.gp-motion-reduced .gift-card--enter {
  animation-duration: 1ms !important;
}

/* System-level reduced motion preference (covers JS-off scenario). */
@media (prefers-reduced-motion: reduce) {
  .gift-card--enter {
    animation-duration: 1ms !important;
  }
}
