/* Animations: slide-in utilities and hover translate */

/* Base hidden state for slide-in elements */
.vw-animate {
  opacity: 0;
  transform: translate3d(0, 0, 0);
  transition: opacity 1200ms cubic-bezier(0.22, 1, 0.36, 1), transform 1200ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}

/* Directions: initial offset before entering */
.vw-slide-left {
  transform: translate3d(-30px, 0, 0);
}

.vw-slide-right {
  transform: translate3d(30px, 0, 0);
}

.vw-slide-top {
  transform: translate3d(0, -30px, 0);
}

.vw-slide-bottom {
  transform: translate3d(0, 30px, 0);
}

/* Active state when element is in viewport */
.vw-in-view {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

/* Optional: allow custom duration/delay via CSS vars */
.vw-animate {
  transition-duration: var(--vw-anim-duration, 1200ms);
  transition-delay: var(-anim-delay, 0ms);
}

/* Hover translate removed */



/* Infinite rotation utility */
@keyframes vw-rotate {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.vw-rotate {
  display: inline-block;
  animation: vw-rotate var(--vw-rotate-duration, 40s) linear infinite;
  transform-origin: center center;
  /* Helps SVGs rotate around their own center */
  transform-box: fill-box;
}

@media (prefers-reduced-motion: reduce) {
  .vw-rotate { animation: none; }
}


/* Letter-by-letter reveal animation */
.vw-letter-reveal {
  display: inline-block;
  overflow: visible;
  will-change: auto;
}

.vw-letter-reveal .letter-wrapper {
  display: inline-block;
  vertical-align: bottom;
}

.vw-letter-reveal .letter {
  display: inline-block;
  visibility: hidden;
  /* No transition - instant appearance like printing */
}

.vw-letter-reveal.vw-letters-visible .letter {
  visibility: visible;
}

/* Preserve spaces */
.vw-letter-reveal .space {
  display: inline-block;
  width: 0.25em;
}

/* Support for line breaks */
.vw-letter-reveal .line-break {
  display: block;
  height: 0;
}

@media (prefers-reduced-motion: reduce) {
  .vw-letter-reveal .letter {
    visibility: visible;
  }
}

