/* Reveal on scroll */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out);
  will-change: transform, opacity;
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger children when parent is .reveal-group */
.reveal-group > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out);
}
.reveal-group.is-visible > * { opacity: 1; transform: translateY(0); }
.reveal-group.is-visible > *:nth-child(1)  { transition-delay: 40ms; }
.reveal-group.is-visible > *:nth-child(2)  { transition-delay: 100ms; }
.reveal-group.is-visible > *:nth-child(3)  { transition-delay: 160ms; }
.reveal-group.is-visible > *:nth-child(4)  { transition-delay: 220ms; }
.reveal-group.is-visible > *:nth-child(5)  { transition-delay: 280ms; }
.reveal-group.is-visible > *:nth-child(6)  { transition-delay: 340ms; }
.reveal-group.is-visible > *:nth-child(7)  { transition-delay: 400ms; }
.reveal-group.is-visible > *:nth-child(8)  { transition-delay: 460ms; }
.reveal-group.is-visible > *:nth-child(n+9){ transition-delay: 520ms; }

/* Hero title char animation */
@keyframes rise-in {
  from { opacity: 0; transform: translateY(40%); }
  to   { opacity: 1; transform: translateY(0); }
}
.title-line {
  display: block;
  overflow: hidden;
}
.title-line > span {
  display: inline-block;
  animation: rise-in 900ms var(--ease-out) both;
}
.title-line:nth-child(1) > span { animation-delay: 60ms; }
.title-line:nth-child(2) > span { animation-delay: 180ms; }
.title-line:nth-child(3) > span { animation-delay: 300ms; }

/* Marquee-style ticker */
@keyframes ticker-slide {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.ticker {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  background: var(--bg-alt);
  padding: var(--sp-4) 0;
}
.ticker-track {
  display: inline-flex;
  white-space: nowrap;
  animation: ticker-slide 60s linear infinite;
}
.ticker-item {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  padding: 0 var(--sp-7);
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  letter-spacing: 0.04em;
}
.ticker-item .dot {
  width: 6px; height: 6px;
  background: var(--accent-clay);
  border-radius: 50%;
}

/* Cursor follow easing handled in JS */

/* Counters */
.counter {
  display: inline-block;
}
