/* Custom gradient animation */
@keyframes gradient {
  0% {
    background-position: 0 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0 50%;
  }
}
@keyframes gradient-x {
  0%,
  100% {
    transform: translateX(0%);
  }
  50% {
    transform: translateX(-100%);
  }
}
@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateX(-10px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
/* Fade in animation */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fade-in {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* Line animation */
@keyframes expand-line {
  from {
    width: 0;
  }
  to {
    width: 100%;
  }
}
@keyframes pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}
/* Subtle pulse */
@keyframes subtle-pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.8;
  }
}
/* Progress bar animation */
@keyframes progress {
  from {
    width: 0;
  }
  to {
    width: var(--progress);
  }
}
/* Loading spinner */
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.slide-in {
  animation: slideIn 0.3s ease-out forwards;
}
.fade-in {
  animation: fadeIn 0.4s ease-out forwards;
}
.progress-bar {
  animation: progress 0.5s ease-out forwards;
}
.spinner {
  animation: spin 1s linear infinite;
}
.animate-fade-in {
  animation: fade-in 0.3s ease-out forwards;
}
.animated-gradient {
  background-size: 200% 200%;
  animation: gradient 6s ease infinite;
}
.animate-line {
  animation: expand-line 1.5s ease-out forwards;
}
.fade-in {
  animation: fadeIn 0.8s ease-out forwards;
}
.status-pulse {
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}
.gradient-underline {
  background: linear-gradient(90deg, #06b6d4, #14b8a6, #fb923c);
  height: 3px;
  background-size: 200% 100%;
  animation: gradient-x 3s ease infinite;
}
/*# sourceMappingURL=/assets/animations-b95cbe07.css.map */