/* ============================================================
   reload.rs — animated "arrow / loop" sections (Claude Design)
   Prefixed rla-* to avoid collisions. Uses site tokens.
   ============================================================ */
.rla-eyebrow { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--teal); display: inline-flex; align-items: center; gap: 12px; }
.rla-eyebrow .n { opacity: 0.5; }
.rla-eyebrow .dot { width: 7px; height: 7px; background: var(--teal); display: inline-block; transform: rotate(45deg); }
.rla-title { font-family: var(--font-display); font-size: clamp(38px, 6.4vw, 96px); font-weight: 700; letter-spacing: -0.04em; line-height: 0.9; color: var(--on-dark); }
.rla-title em { font-style: normal; color: var(--teal); }
.rla-lead { color: var(--on-dark-2); font-size: clamp(15px, 1.5vw, 19px); line-height: 1.55; max-width: 46ch; margin-top: 22px; }

/* ---------- 01 SELF-DRAW LOOP ---------- */
.rla-draw { position: relative; height: 220vh; background: var(--ink); }
.rla-draw-sticky { position: sticky; top: 0; height: 100vh; display: flex; align-items: center; overflow: clip; }
.rla-draw .g { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 60px); align-items: center; width: 100%; }
.rla-draw svg { width: 100%; height: auto; overflow: visible; }
.rla-drawpath { fill: none; stroke: var(--teal); stroke-width: 6; stroke-linecap: round; stroke-linejoin: round; }
.rla-drawpath.dim { stroke: rgba(255,255,255,0.07); }
@media (max-width: 860px) { .rla-draw .g { grid-template-columns: 1fr; gap: 24px; } .rla-draw .vis { order: -1; max-width: 340px; } }

/* ---------- 02 CONCENTRIC RINGS ---------- */
.rla-rings { position: relative; min-height: 90vh; display: flex; align-items: center; justify-content: center; background: var(--ink-2); overflow: clip; }
.rla-rings-stage { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.rla-ring { position: absolute; }
.rla-ring svg { width: 100%; height: 100%; overflow: visible; }
.rla-ring path { fill: none; stroke-linecap: round; stroke-linejoin: round; }
@keyframes rlaSpin { to { transform: rotate(360deg); } }
.rla-ring.r1 { width: min(34vh,300px); height: min(34vh,300px); animation: rlaSpin 9s linear infinite; }
.rla-ring.r2 { width: min(54vh,480px); height: min(54vh,480px); animation: rlaSpin 16s linear infinite reverse; }
.rla-ring.r3 { width: min(76vh,680px); height: min(76vh,680px); animation: rlaSpin 26s linear infinite; }
.rla-ring.r1 path { stroke: var(--teal); stroke-width: 7; }
.rla-ring.r2 path { stroke: rgba(255,199,53,0.45); stroke-width: 5; }
.rla-ring.r3 path { stroke: rgba(255,255,255,0.08); stroke-width: 4; }
.rla-rings-copy { position: relative; z-index: 3; text-align: center; padding: 80px 0; }
.rla-rings-copy h2 { font-family: var(--font-display); font-size: clamp(40px,7vw,108px); font-weight: 700; letter-spacing: -0.04em; line-height: 0.86; color: var(--on-dark); }
.rla-rings-copy h2 em { font-style: normal; color: var(--teal); }

/* ---------- 04 PATH FOLLOW ---------- */
.rla-path { position: relative; height: 210vh; background: var(--paper); }
.rla-path-sticky { position: sticky; top: 0; height: 100vh; display: flex; flex-direction: column; justify-content: center; overflow: clip; }
.rla-path .head { position: absolute; top: clamp(70px, 12vh, 130px); left: 0; right: 0; }
.rla-path-wrap { width: 100%; }
.rla-path-wrap svg { width: 100%; height: auto; overflow: visible; }
.rla-path-base { fill: none; stroke: rgba(12,15,20,0.12); stroke-width: 3; stroke-dasharray: 2 12; stroke-linecap: round; }
.rla-path-line { fill: none; stroke: var(--text); stroke-width: 4; stroke-linecap: round; }
.rla-way { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; fill: var(--text); }
.rla-way circle { fill: var(--teal); }
.rla-path .head .rla-title { color: var(--text); }
.rla-path .head .rla-title em { color: var(--teal-deep, #C99A12); }
.rla-path .head .rla-eyebrow { color: var(--text); }

/* ---------- 05 LOGO CONVEYOR ---------- */
.rla-convey { background: var(--teal); padding: 0; overflow: hidden; }
.rla-convey-row { display: flex; align-items: center; gap: clamp(34px, 5vw, 60px); width: max-content; padding: clamp(30px, 4vw, 46px) 0; will-change: transform; animation: rlaSlideL 24s linear infinite; }
@keyframes rlaSlideL { to { transform: translateX(-50%); } }
.rla-convey-row img { height: clamp(56px, 9vw, 120px); display: block; }
.rla-convey-row .word { font-family: var(--font-display); font-size: clamp(44px, 7vw, 100px); font-weight: 700; letter-spacing: -0.04em; color: var(--ink); }
.rla-convey-row .word.hollow { color: transparent; -webkit-text-stroke: 2px var(--ink); }
@media (prefers-reduced-motion: reduce) { .rla-convey-row { animation: none; } }

/* ---------- 12 ARROW RAIN (CTA) ---------- */
.rla-rain-sec { position: relative; min-height: 92vh; display: flex; align-items: center; justify-content: center; text-align: center; background: var(--ink); overflow: clip; }
.rla-rain { position: absolute; inset: 0; z-index: 1; -webkit-mask-image: linear-gradient(transparent, #000 15%, #000 85%, transparent); mask-image: linear-gradient(transparent, #000 15%, #000 85%, transparent); }
.rla-rain-col { position: absolute; top: -20%; height: 150%; display: flex; flex-direction: column; align-items: center; gap: 22px; will-change: transform; }
@keyframes rlaFall { from { transform: translateY(-28%); } to { transform: translateY(0); } }
.rla-rain-col svg { width: 18px; height: auto; color: rgba(255,255,255,0.28); display: block; }
.rla-rain-col.y svg { color: rgba(255,199,53,0.6); }
.rla-rain-copy { position: relative; z-index: 3; padding: 60px var(--pad); }
.rla-rain-copy h2 { font-family: var(--font-display); font-size: clamp(46px, 9vw, 130px); font-weight: 700; letter-spacing: -0.045em; line-height: 0.85; color: var(--on-dark); }
.rla-rain-copy h2 em { font-style: normal; color: var(--teal); }
.rla-rain-copy .rla-lead { margin: 18px auto 0; }
@media (prefers-reduced-motion: reduce) { .rla-rain-col { animation: none !important; } }

/* ---------- 08 ZOOM-THROUGH LOOP ---------- */
.rla-zoom { position: relative; height: 250vh; background: var(--ink); }
.rla-zoom-sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.rla-zoom-loop { position: absolute; width: min(72vh, 72vw); will-change: transform; color: var(--teal); }
.rla-zoom-loop svg { width: 100%; height: auto; overflow: visible; }
.rla-zoom-copy { position: relative; z-index: 3; text-align: center; will-change: transform, opacity; }
.rla-zoom-copy .rla-eyebrow { justify-content: center; }
.rla-zoom-copy h2 { font-family: var(--font-display); font-size: clamp(44px, 8vw, 116px); font-weight: 700; letter-spacing: -0.04em; line-height: 0.86; margin-top: 18px; color: var(--on-dark); }
.rla-zoom-copy h2 em { font-style: normal; color: var(--teal); }

/* ---------- 11 CHEVRON TUNNEL ---------- */
.rla-tunnel { position: relative; height: 260vh; background: var(--ink); }
.rla-tunnel-sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.rla-tunnel-stage { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.rla-tc { position: absolute; top: 50%; left: 50%; width: 46vmin; will-change: transform, opacity; }
.rla-tc svg { width: 100%; height: auto; overflow: visible; display: block; color: var(--teal); }
.rla-tunnel-copy { position: relative; z-index: 6; text-align: center; pointer-events: none; }
.rla-tunnel-copy .rla-eyebrow { justify-content: center; }
.rla-tunnel-copy h2 { font-family: var(--font-display); font-size: clamp(40px, 7vw, 100px); font-weight: 700; letter-spacing: -0.04em; line-height: 0.86; margin-top: 16px; color: var(--on-dark); }
.rla-tunnel-copy h2 em { font-style: normal; color: var(--teal); }

/* ---------- 03 POINTER FIELD ---------- */
.rla-field-sec { position: relative; min-height: 92vh; display: flex; align-items: center; background: var(--ink); overflow: clip; }
.rla-field { position: absolute; inset: 0; display: grid; z-index: 1; }
.rla-afa { display: flex; align-items: center; justify-content: center; }
.rla-afa svg { width: clamp(16px, 2.4vw, 30px); height: auto; color: rgba(255,255,255,0.16); transition: color 0.3s; }
.rla-afa.near svg { color: var(--teal); }
.rla-field-copy { position: relative; z-index: 3; pointer-events: none; }
.rla-field-copy .rla-lead { pointer-events: auto; }

/* ---------- 06 RADIAL BURST ---------- */
.rla-radial-sec { position: relative; min-height: 92vh; display: flex; align-items: center; justify-content: center; background: var(--ink-2); overflow: clip; }
.rla-radial-stage { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.rla-ray { position: absolute; top: 50%; left: 50%; width: 0; height: 0; }
.rla-ray .arr { position: absolute; color: var(--teal); }
.rla-ray .arr svg { width: 26px; height: auto; display: block; }
@keyframes rlaBurst { 0% { transform: translateY(-40px) scale(0.5); opacity: 0; } 18% { opacity: 1; } 70% { opacity: 0.9; } 100% { transform: translateY(-260px) scale(1); opacity: 0; } }
.rla-radial-copy { position: relative; z-index: 3; text-align: center; padding: 60px 0; }
.rla-radial-copy h2 { font-family: var(--font-display); font-size: clamp(40px,7vw,96px); font-weight: 700; letter-spacing: -0.04em; line-height: 0.88; color: var(--on-dark); }
.rla-radial-copy h2 em { font-style: normal; color: var(--teal); }
.rla-radial-copy .hub { width: 78px; height: 78px; border-radius: 50%; background: var(--teal); display: flex; align-items: center; justify-content: center; margin: 0 auto 30px; }
.rla-radial-copy .hub svg { width: 40px; height: 40px; color: var(--ink); }
@media (prefers-reduced-motion: reduce) { .rla-ray .arr { animation: none !important; } }

/* ---------- 07 HORIZONTAL SCRUB (mega arrow) ---------- */
.rla-hscrub { position: relative; height: 280vh; background: var(--ink-2); }
.rla-hscrub-sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; display: flex; align-items: center; }
.rla-hscrub .rla-eyebrow { position: absolute; top: 40px; left: var(--pad); z-index: 5; }
.rla-hscrub-track { position: absolute; left: 0; top: 50%; transform: translateY(-50%); display: flex; align-items: center; gap: 6vw; width: max-content; will-change: transform; padding-left: 8vw; }
.rla-hscrub-track .gword { font-family: var(--font-display); font-size: 26vh; font-weight: 700; letter-spacing: -0.05em; line-height: 0.8; color: transparent; -webkit-text-stroke: 2px rgba(255,255,255,0.22); white-space: nowrap; }
.rla-hscrub-track .gword.fill { color: var(--teal); -webkit-text-stroke: 0; }
.rla-hscrub-track .garrow { flex: none; color: var(--teal); }
.rla-hscrub-track .garrow svg { height: 34vh; width: auto; display: block; overflow: visible; }

/* ---------- 09 MACRO CHEVRON SPREAD ---------- */
.rla-spread { position: relative; height: 250vh; background: var(--ink-2); }
.rla-spread-sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.rla-spread-stage { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.rla-ch { position: absolute; width: 128vw; left: 50%; top: 50%; will-change: transform; }
.rla-ch svg { width: 100%; height: auto; overflow: visible; display: block; }
.rla-spread-copy { position: relative; z-index: 5; text-align: center; mix-blend-mode: difference; }
.rla-spread-copy h2 { font-family: var(--font-display); font-size: clamp(40px,7.5vw,112px); font-weight: 700; letter-spacing: -0.04em; line-height: 0.85; color: #fff; }

/* ---------- 10 GIANT ARROW WIPE ---------- */
.rla-wipe { position: relative; height: 240vh; background: var(--paper); }
.rla-wipe-sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.rla-wipe-panel { position: absolute; inset: 0; background: var(--teal); will-change: transform; clip-path: polygon(0 0, calc(100% - 18vw) 0, 100% 50%, calc(100% - 18vw) 100%, 0 100%); }
.rla-wipe-copy { position: relative; z-index: 5; text-align: center; }
.rla-wipe-copy .rla-eyebrow { justify-content: center; color: var(--ink); }
.rla-wipe-copy h2 { font-family: var(--font-display); font-size: clamp(56px,15vw,240px); font-weight: 700; letter-spacing: -0.05em; line-height: 0.8; color: var(--ink); }
