

.slide-enter {
  animation: slideEnter 0.9s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.slide-exit {
  animation: slideExit 0.9s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
@keyframes slideEnter {
  from {
    opacity: 0;
    transform: scale(1.06);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes slideExit {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0.97);
  }
}

.text-reveal {
  animation: textReveal 0.75s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.text-reveal-delay {
  animation: textReveal 0.75s 0.12s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.text-reveal-delay2 {
  animation: textReveal 0.75s 0.26s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.text-reveal-delay3 {
  animation: textReveal 0.75s 0.4s cubic-bezier(0.22, 1, 0.36, 1) both;
}
@keyframes textReveal {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.shimmer-badge {
  position: relative;
  overflow: hidden;
}
.shimmer-badge::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -75%;
  width: 50%;
  height: 200%;
  background: linear-gradient(105deg, transparent 40%, rgba(255, 255, 255, 0.4) 50%, transparent 60%);
  animation: shimmer 3.5s 1.8s infinite;
}
@keyframes shimmer {
  0% {
    left: -75%;
  }
  100% {
    left: 125%;
  }
}

.progress-bar {
  animation: progressFill 5.5s linear forwards;
}
@keyframes progressFill {
  from {
    width: 0%;
  }
  to {
    width: 100%;
  }
}

.ctrl-btn {
  transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.ctrl-btn:hover {
  transform: scale(1.18);
  background: rgba(255, 255, 255, 0.22);
}

.dot-indicator {
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.diagonal-cut::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 72px;
  background: #f0f7ff;
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  z-index: 6;
}

.feature-card {
  transition:
    transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 0.35s ease;
}
.feature-card:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 0 24px 48px rgba(30, 64, 175, 0.13);
}

.glow-btn {
  position: relative;
}
.glow-btn::before {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 9999px;
  background: linear-gradient(135deg, #fbbf24, #ef4444, #3b82f6);
  opacity: 0;
  transition: opacity 0.3s;
  z-index: -1;
  filter: blur(10px);
}
.glow-btn:hover::before {
  opacity: 0.65;
}

.vignette {
  background: radial-gradient(ellipse at center, transparent 35%, rgba(0, 0, 0, 0.5) 100%);
}
.light-leak {
  background: radial-gradient(ellipse 55% 35% at 25% 0%, rgba(251, 191, 36, 0.16) 0%, transparent 70%);
}
