/* ============================================================
   reveal.css — Scroll Reveal Animations
   ============================================================ */

/* ── Base: slide up + fade ──────────────────── */
.rv {
  opacity: 0;
  transform: translateY(44px);
  transition:
    opacity   0.9s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}

.rv.vis {
  opacity: 1;
  transform: none;
}

/* ── Stagger delays ─────────────────────────── */
.rv.d1 { transition-delay: 0.10s; }
.rv.d2 { transition-delay: 0.20s; }
.rv.d3 { transition-delay: 0.30s; }
.rv.d4 { transition-delay: 0.40s; }

/* ── Scale + rise (bento cards) ─────────────── */
.rv.rv-scale {
  transform: translateY(44px) scale(0.94);
}
.rv.rv-scale.vis {
  transform: none;
}

/* ── Slide from left (orb) ──────────────────── */
.rv.rv-left {
  transform: translateX(-64px);
}
.rv.rv-left.vis {
  transform: none;
}

/* ── Slide from right (about copy, contact right) */
.rv.rv-right {
  transform: translateX(64px);
}
.rv.rv-right.vis {
  transform: none;
}

/* ── Blur fade (section headings) ───────────── */
.rv.rv-blur {
  transform: translateY(28px);
  filter: blur(6px);
  transition:
    opacity   1.1s cubic-bezier(0.16, 1, 0.3, 1),
    transform 1.1s cubic-bezier(0.16, 1, 0.3, 1),
    filter    1.1s cubic-bezier(0.16, 1, 0.3, 1);
}
.rv.rv-blur.vis {
  transform: none;
  filter: blur(0);
}

/* ── Big rise (stats) ───────────────────────── */
.rv.rv-rise {
  transform: translateY(80px);
  transition:
    opacity   1s cubic-bezier(0.16, 1, 0.3, 1),
    transform 1s cubic-bezier(0.16, 1, 0.3, 1);
}
.rv.rv-rise.vis {
  transform: none;
}

/* ── Wipe from bottom (logo strip, marquee) ─── */
.rv.rv-wipe {
  opacity: 1;
  transform: none;
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1s cubic-bezier(0.16, 1, 0.3, 1);
}
.rv.rv-wipe.vis {
  clip-path: inset(0 0 0% 0);
}
