// fade
.router-transition-zmp-fade-forward,
.router-transition-zmp-fade-backward {
  background: var(--zmp-page-bg-color);
  .page-next,
  .page-current,
  .page-previous:not(.stacked) {
    pointer-events: none;
  }
}
.router-transition-zmp-fade-forward {
  .page-next {
    opacity: 0 !important;
    animation: zmp-fade-in var(--zmp-page-fade-transition-duration) forwards;
  }
  .page-current {
    animation: zmp-fade-out var(--zmp-page-fade-transition-duration) forwards;
  }
}
.router-transition-zmp-fade-backward {
  .page-current {
    animation: zmp-fade-out var(--zmp-page-fade-transition-duration) forwards;
  }
  .page-previous {
    animation: zmp-fade-in var(--zmp-page-fade-transition-duration) forwards;
  }
}
@keyframes zmp-fade-in {
  from {
    opacity: 0;
  }
  50% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes zmp-fade-out {
  from {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  to {
    opacity: 0;
  }
}
