.reveal {
  position: relative;
  --reveal-x: 0px;
  --reveal-y: 28px;
  overflow-x: clip;
  opacity: 0;
  transform: translate3d(var(--reveal-x), var(--reveal-y), 0) scale(0.985);
  transition:
    opacity 720ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 720ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 720ms cubic-bezier(0.22, 1, 0.36, 1);
  filter: blur(6px);
  isolation: isolate;
}

.reveal::before {
  content: "";
  position: absolute;
  inset: -6%;
  pointer-events: none;
  opacity: 0.45;
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.9) 0.04rem, transparent 0.08rem);
  background-size: 0.95rem 0.95rem;
  transform: scale(1);
  transition:
    opacity 680ms ease,
    transform 680ms ease;
}

.reveal-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  filter: blur(0);
}

.reveal-visible::before {
  opacity: 0;
  transform: scale(1.08);
}

[data-reveal="left"] {
  --reveal-x: -34px;
  --reveal-y: 0px;
}

[data-reveal="right"] {
  --reveal-x: 34px;
  --reveal-y: 0px;
}

[data-reveal="up"] {
  --reveal-y: 30px;
}

[data-reveal="stagger"] {
  transition-delay: var(--delay, 0ms);
}

.reveal-hero {
  animation: hero-rise 900ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.pulse-ring {
  animation: pulse-ring 2.8s ease-in-out infinite;
}

@keyframes hero-rise {
  from {
    opacity: 0;
    transform: translate3d(0, 2rem, 0);
    filter: blur(8px);
  }

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

@keyframes pulse-ring {
  0%,
  100% {
    box-shadow:
      0 0 0 0 rgba(255, 255, 255, 0.16),
      0 24px 70px rgba(0, 0, 0, 0.55);
  }

  50% {
    box-shadow:
      0 0 0 0.9rem rgba(255, 255, 255, 0),
      0 24px 70px rgba(0, 0, 0, 0.55);
  }
}

@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal-visible {
    opacity: 1;
    transform: none;
    filter: none;
  }

  .reveal::before {
    display: none;
  }
}
