/* =============================================
   Manolo, effects
   Vanilla adaptations inspired by React Bits:
   split text, spotlight cards, glare hover and border glow.
   ============================================= */

.hero__copy {
  position: relative;
  z-index: 1;
}

.fx-split-ready .hero__title-line {
  opacity: 1;
  transform: none;
  animation: none;
}

.fx-word {
  display: inline-block;
  opacity: 0;
  transform: translate3d(0, 0.34em, 0);
  filter: blur(2px);
  transform-origin: left bottom;
  animation: fxWordReveal 820ms cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay: var(--fx-word-delay, 0ms);
  will-change: transform, opacity, filter;
}

@keyframes fxWordReveal {
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    filter: blur(0);
  }
}

.fx-spotlight {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  --fx-mouse-x: 50%;
  --fx-mouse-y: 50%;
  --fx-spotlight-color: rgba(10, 36, 76, 0.08);
}

.fx-spotlight::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: radial-gradient(
    circle at var(--fx-mouse-x) var(--fx-mouse-y),
    var(--fx-spotlight-color),
    transparent 72%
  );
  opacity: 0;
  transition: opacity 520ms ease;
}

.fx-spotlight > * {
  position: relative;
  z-index: 1;
}

@media (hover: hover) and (pointer: fine) {
  .fx-spotlight:hover::before,
  .fx-spotlight:focus-within::before {
    opacity: 1;
  }
}

.card-dark.fx-spotlight,
.service-card--link.fx-spotlight {
  --fx-spotlight-color: rgba(255, 255, 255, 0.13);
}

.page-hero__service-card.fx-spotlight,
.spec-card.fx-spotlight {
  --fx-spotlight-color: rgba(255, 188, 30, 0.13);
}

.card-tech.fx-spotlight,
.card-soft.fx-spotlight {
  --fx-spotlight-color: rgba(70, 130, 180, 0.12);
}

.fx-glare {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.fx-glare::before {
  content: "";
  position: absolute;
  inset: -45%;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(
    115deg,
    transparent 42%,
    rgba(255, 255, 255, 0.54) 50%,
    transparent 58%
  );
  opacity: 0;
  transform: translate3d(-62%, 0, 0);
  transition:
    transform 920ms cubic-bezier(0.16, 1, 0.3, 1),
    opacity 260ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .fx-glare:hover::before,
  .fx-glare:focus-visible::before {
    opacity: 0.24;
    transform: translate3d(62%, 0, 0);
  }
}

.fx-border-glow {
  position: relative;
  isolation: isolate;
  overflow: visible;
  --fx-mouse-x: 50%;
  --fx-mouse-y: 50%;
}

.fx-border-glow::after {
  content: "";
  position: absolute;
  inset: -2px;
  z-index: -1;
  pointer-events: none;
  border-radius: inherit;
  padding: 2px;
  background:
    radial-gradient(
      150px circle at var(--fx-mouse-x) var(--fx-mouse-y),
      rgba(255, 188, 30, 0.95),
      rgba(70, 130, 180, 0.52) 42%,
      transparent 72%
    );
  opacity: 0.85;
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  mask-composite: exclude;
  transition: opacity var(--t-fast), transform var(--t-fast);
}

@media (hover: hover) and (pointer: fine) {
  .fx-border-glow:hover::after,
  .fx-border-glow:focus-visible::after {
    opacity: 1;
    transform: scale(1.01);
  }
}

@media (prefers-reduced-motion: reduce) {
  .fx-word,
  .fx-glare::before {
    animation: none;
    transition: none;
  }

  .fx-word {
    opacity: 1;
    transform: none;
    filter: none;
  }

  .fx-spotlight::before,
  .fx-glare::before {
    display: none;
  }
}
