.fade-top,
.fade-in,
.fade-bottom {
  opacity: 0;
  will-change: opacity, transform, filter;
  transition: opacity var(--fade-duration, 0.45s) ease var(--fade-delay, 0s),
    transform var(--fade-duration, 0.45s) ease var(--fade-delay, 0s),
    filter var(--fade-duration, 0.45s) ease var(--fade-delay, 0s);
  filter: blur(4px);
}

.fade-top {
  transform: translateY(-60%);
}

.fade-in {
  transform: translateY(20%);
}

.fade-bottom {
  transform: translateY(40%);
}

.fade-top.in-view,
.fade-in.in-view,
.fade-bottom.in-view {
  opacity: 1;
  transform: translate(0, 0);
  filter: blur(0);
}

@media (prefers-reduced-motion: reduce) {
  .fade-top,
  .fade-in,
  .fade-bottom {
    transition: none;
    transform: none;
    filter: none;
  }
  .fade-top.in-view,
  .fade-in.in-view,
  .fade-bottom.in-view {
    opacity: 1;
  }
}
