.card-spotlight {
  --spot-x: 50%;
  --spot-y: 50%;
}

.card-spotlight::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(420px circle at var(--spot-x) var(--spot-y), rgba(46, 107, 138, 0.09) 0%, transparent 58%);
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
  z-index: 0;
}

.card-spotlight:hover::before {
  opacity: 1;
}

.glow-card {
  position: relative;
  --glow-start: 0;
  --glow-spread: 40;
  --glow-active: 0;
  --glow-border-width: 3px;
  --glow-gradient:
    radial-gradient(circle, #F6D307 10%, #F6D30700 20%),
    radial-gradient(circle at 40% 40%, #E5C306 5%, #E5C30600 15%),
    radial-gradient(circle at 60% 60%, #C8A90A 10%, #C8A90A00 20%),
    radial-gradient(circle at 40% 60%, #2E6B8A 10%, #2E6B8A00 20%),
    repeating-conic-gradient(from 236.84deg at 50% 50%, #F6D307 0%, #E5C306 5%, #C8A90A 10%, #2E6B8A 15%, #F6D307 20%);
}

.glow-card__border,
.glow-card__glow,
.glow-card__glow .glow-inner {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
}

.glow-card__border {
  border: 1px solid rgba(255, 255, 255, 0.08);
  z-index: 0;
}

.glow-card__glow {
  z-index: 0;
}

.glow-card__glow .glow-inner::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: var(--glow-border-width) solid transparent;
  background: var(--glow-gradient);
  background-attachment: fixed;
  opacity: var(--glow-active);
  transition: opacity 0.3s ease;
  -webkit-mask-clip: padding-box, border-box;
  mask-clip: padding-box, border-box;
  -webkit-mask-composite: source-in;
  mask-composite: intersect;
  -webkit-mask-image: linear-gradient(#0000, #0000), conic-gradient(from calc((var(--glow-start) - var(--glow-spread)) * 1deg), #00000000 0deg, #fff, #00000000 calc(var(--glow-spread) * 2deg));
  mask-image: linear-gradient(#0000, #0000), conic-gradient(from calc((var(--glow-start) - var(--glow-spread)) * 1deg), #00000000 0deg, #fff, #00000000 calc(var(--glow-spread) * 2deg));
}

.glow-card > *:not(.glow-card__border):not(.glow-card__glow) {
  position: relative;
  z-index: 1;
}

.reveal,
.reveal--left,
.reveal--right,
.reveal--scale {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal--left {
  transform: translateX(-40px);
}

.reveal--right {
  transform: translateX(40px);
}

.reveal--scale {
  transform: scale(0.95);
}

.reveal.is-visible,
.reveal--left.is-visible,
.reveal--right.is-visible,
.reveal--scale.is-visible {
  opacity: 1;
  transform: translate(0, 0) scale(1);
}

.word-reveal .wr-word {
  display: inline-block;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.word-reveal.is-visible .wr-word {
  opacity: 1;
  transform: translateY(0);
}

.btn-magnetic {
  transition: transform 0.3s cubic-bezier(0.03, 0.98, 0.52, 0.99);
}

.header-reveal-enabled .section-header__title,
.header-reveal-enabled .section-header__label,
.header-reveal-enabled .section-header__subtitle {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.header-reveal-enabled .section-header__label {
  transform: translateY(22px) scale(0.98);
}

.header-reveal-enabled .section-header__title.is-visible,
.header-reveal-enabled .section-header__label.is-visible,
.header-reveal-enabled .section-header__subtitle.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal--left,
  .reveal--right,
  .reveal--scale,
  .word-reveal .wr-word,
  .header-reveal-enabled .section-header__title,
  .header-reveal-enabled .section-header__label,
  .header-reveal-enabled .section-header__subtitle {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .card-spotlight::before,
  .glow-card__glow .glow-inner::after {
    display: none;
  }
}
