/* =========================================================================
   Julia Ross — Motion (scroll reveals, parallax, hero) — shared
   Normal system cursor everywhere. No custom cursor.
   ========================================================================= */

/* ---- Scroll reveal ---- */
[data-reveal] {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity var(--dur-slow) var(--ease-out),
              transform var(--dur-slow) var(--ease-out);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}
[data-reveal="fade"] { transform: none; }
[data-reveal="left"]  { transform: translateX(-40px); }
[data-reveal="right"] { transform: translateX(40px); }
[data-reveal="scale"] { transform: scale(0.94); }

[data-reveal].in-view { opacity: 1; transform: none; }

/* Line that draws itself in */
.rule-draw { height: 1px; background: var(--line-strong); transform: scaleX(0); transform-origin: left; transition: transform var(--dur-slow) var(--ease-out); }
.rule-draw.in-view { transform: scaleX(1); }

/* Image reveal mask (clip wipe) */
.media-reveal { overflow: hidden; }
.media-reveal img {
  transform: scale(1.12);
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1.2s var(--ease-out), transform 1.6s var(--ease-out);
}
.media-reveal.in-view img { transform: scale(1); clip-path: inset(0 0 0 0); }

/* Parallax hooks (JS-driven via CSS var --py) */
[data-parallax] { transform: translate3d(0, var(--py, 0), 0); will-change: transform; }

/* Hero intro (revealed after loader) */
.hero-line { display: block; overflow: hidden; }
.hero-line > span {
  display: block;
  transform: translateY(110%);
  transition: transform 1s var(--ease-out);
}
body.is-loaded .hero-line > span,
.no-loader .hero-line > span { transform: translateY(0); }
body.is-loaded .hero-line:nth-child(2) > span { transition-delay: 0.08s; }
body.is-loaded .hero-line:nth-child(3) > span { transition-delay: 0.16s; }

.hero-fade {
  opacity: 0; transform: translateY(18px);
  transition: opacity 1s var(--ease-out) 0.5s, transform 1s var(--ease-out) 0.5s;
}
body.is-loaded .hero-fade, .no-loader .hero-fade { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  [data-reveal], .rule-draw, .media-reveal img, .hero-line > span, .hero-fade {
    opacity: 1 !important; transform: none !important; clip-path: none !important;
    transition: none !important;
  }
  [data-parallax] { transform: none !important; }
}
