/* ========================================
   ANIMATIONS — Card Game Edition
   ======================================== */

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

@keyframes slideUp {
  to { opacity: 1; transform: translateY(0); }
}

@keyframes slideRemove {
  to {
    max-height: 0;
    margin-bottom: 0;
    opacity: 0;
    transform: translateX(-100%);
  }
}

@keyframes packFadeIn {
  to { opacity: 1; transform: translateY(0); }
}

@keyframes pulseDot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.7); }
}

/* Card deal — slides in from bottom-right like being dealt */
@keyframes cardIn {
  from {
    opacity: 0;
    transform: translateY(40px) rotate(2deg);
  }
  to {
    opacity: 1;
    transform: translateY(0) rotate(0deg);
  }
}

@keyframes badgePop {
  0% { opacity: 0; transform: scale(0.8); }
  60% { transform: scale(1.05); }
  100% { opacity: 1; transform: scale(1); }
}

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

@keyframes bubblePop {
  0% { transform: scale(1); }
  30% { transform: scale(1.15); }
  60% { transform: scale(0.97); }
  100% { transform: scale(1.03); }
}

@keyframes blitzSlide {
  from { opacity: 0; transform: translateX(40px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 0.7; transform: translateY(0); }
}

@keyframes orbit {
  0%, 100% { transform: translate(0, 0) scale(1); }
  25% { transform: translate(8px, -8px) scale(1.03); }
  50% { transform: translate(0, -4px) scale(0.97); }
  75% { transform: translate(-8px, 4px) scale(1.01); }
}

@keyframes pulse {
  0%, 100% { opacity: 0.3; transform: scale(0.8); }
  50% { opacity: 1; transform: scale(1.2); }
}

@keyframes countPop {
  0% { transform: scale(0.5); opacity: 0; }
  60% { transform: scale(1.1); }
  100% { transform: scale(1); opacity: 1; }
}

@keyframes tapHintPulse {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 0.8; }
}

@keyframes cardConfettiBurst {
  0% { transform: translate(0, 0) scale(1); opacity: 1; }
  100% { opacity: 0; }
}

@keyframes vibeGradient {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

@keyframes vibeShimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

@keyframes confettiFall {
  0% { transform: translateY(0) rotate(0deg); opacity: 1; }
  100% { transform: translateY(100vh) rotate(720deg); opacity: 0; }
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-4px); }
  80% { transform: translateX(4px); }
}

/* Card flip for reveals */
@keyframes cardFlipIn {
  0% {
    transform: perspective(800px) rotateY(90deg);
    opacity: 0;
  }
  100% {
    transform: perspective(800px) rotateY(0deg);
    opacity: 1;
  }
}

/* Deck stack subtle bob */
@keyframes deckBreathe {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}

/* Spirit ring spin */
@keyframes spiritSpin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Duo glow ambient pulse */
@keyframes duoGlowPulse {
  0%, 100% { transform: scale(1); opacity: 0.12; }
  50% { transform: scale(1.15); opacity: 0.2; }
}

/* Ripple expanding outward */
@keyframes rippleExpand {
  0% { transform: scale(1); opacity: 0.6; }
  100% { transform: scale(1.8); opacity: 0; }
}
@keyframes rippleExpandDim {
  0% { transform: scale(1); opacity: 0.15; }
  100% { transform: scale(1.6); opacity: 0; }
}

/* Energy beam gradient flow */
@keyframes beamFlow {
  0% { background-position: 0% 0%; }
  100% { background-position: 200% 0%; }
}

/* Beam endpoint pulse */
@keyframes beamDotPulse {
  0%, 100% { transform: translateY(-50%) scale(1); opacity: 0.6; }
  50% { transform: translateY(-50%) scale(1.5); opacity: 1; }
}

/* Floating particles */
@keyframes particleFloat {
  0% { opacity: 0; transform: translateY(0) scale(0); }
  20% { opacity: 0.7; transform: translateY(-8px) scale(1); }
  80% { opacity: 0.4; transform: translateY(-24px) scale(0.8); }
  100% { opacity: 0; transform: translateY(-32px) scale(0); }
}

/* Shake utility class */
.shake { animation: shake 0.4s ease; }
