/* Framer Motion replacements */

@keyframes pulseOpacity {
  0% { opacity: 0.1; }
  50% { opacity: 0.2; }
  100% { opacity: 0.1; }
}

@keyframes blob1 {
  0% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(50px, 30px) scale(1.2); }
  100% { transform: translate(0, 0) scale(1); }
}

@keyframes blob2 {
  0% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(-60px, -40px) scale(1.3); }
  100% { transform: translate(0, 0) scale(1); }
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeInDown {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.98); }
  to { opacity: 1; transform: scale(1); }
}

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

.bg-pulse {
  animation: pulseOpacity 10s ease-in-out infinite;
}

.bg-blob-1 {
  animation: blob1 20s ease-in-out infinite;
}

.bg-blob-2 {
  animation: blob2 25s ease-in-out infinite;
}

.fade-in-up {
  opacity: 0;
  animation: fadeInUp 0.5s ease-out forwards;
}

.fade-in-down {
  opacity: 0;
  animation: fadeInDown 0.3s ease-out forwards;
}

.scale-in {
  opacity: 0;
  animation: scaleIn 0.5s ease-out forwards;
}

.blinking-cursor {
  animation: blink 0.8s infinite;
}

.hover-scale-btn {
  transition: transform 0.2s ease;
}

.hover-scale-btn:hover {
  transform: scale(1.02);
}

.hover-scale-btn:active {
  transform: scale(0.98);
}
