/* File: assets/css/animation.css */

@keyframes mouse-scroll-anim {
  0% {
    opacity: 0;
    top: 6px;
  }
  30% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    top: 22px;
  }
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fade-in-element {
  opacity: 0;
  transform: translateY(15px);
  animation: element-entrance 0.8s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.hero-actions.fade-in-element {
  animation-delay: 0.3s;
}

@keyframes element-entrance {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.reveal-fade,
.reveal-slide-left,
.reveal-slide-right {
  opacity: 0;
  will-change: transform, opacity;
  transition:
    opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.reveal-fade {
  transform: translateY(25px);
}
.reveal-slide-left {
  transform: translateX(-35px);
}
.reveal-slide-right {
  transform: translateX(35px);
}

.revealed {
  opacity: 1;
  transform: translate(0, 0);
}

.btn-glow {
  position: relative;
}

.btn-glow::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--gold-primary), var(--gold-light));
  border-radius: 8px;
  z-index: -1;
  opacity: 0.25;
  filter: blur(10px);
  transition: opacity 0.3s ease;
}

.btn-glow:hover::after {
  opacity: 0.6;
}
