/* ============================================================
   Ride the Wave — full-screen urge ritual
   ============================================================ */

body.urge-page { background: #0B0B0E; }
body.urge-page.urge-active { overflow: hidden; }

.urge { position: relative; min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 160px 24px 80px; overflow: hidden; }
.urge-ambient { position: absolute; inset: 0; pointer-events: none; background: radial-gradient(60% 50% at 50% 50%, rgba(245,158,11,0.10), transparent 60%); }

/* ---------- Intro ---------- */
.urge-intro { max-width: 540px; text-align: center; position: relative; z-index: 1; }
.urge-h1 { font-size: clamp(2.4rem, 5.6vw, 3.6rem); font-weight: 600; letter-spacing: -0.035em; line-height: 1.05; margin: 22px 0 28px; color: var(--ink-1); text-wrap: balance; }
.urge-h1 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--ink-2); }
.urge-lede { color: var(--ink-2); font-size: 1.0625rem; line-height: 1.6; margin: 0 0 36px; text-wrap: pretty; }
.urge-start { display: inline-flex; align-items: center; padding: 16px 30px; border-radius: 999px; background: var(--ink-1); color: #0B0B0E; font: inherit; font-size: 15px; font-weight: 600; letter-spacing: -0.005em; border: 0; cursor: pointer; transition: transform 200ms ease, box-shadow 240ms ease; }
.urge-start:hover { transform: translateY(-1px); box-shadow: 0 14px 40px -12px rgba(245,158,11,0.4); }
.urge-foot { margin-top: 32px; font-size: 12px; color: var(--ink-3); display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; letter-spacing: 0.03em; }
.urge-foot em { font-family: var(--font-serif); font-style: italic; color: var(--ink-2); }

/* ---------- Stage ---------- */
.urge-stage { text-align: center; position: relative; z-index: 1; max-width: 480px; }
.urge-rings { width: 320px; height: 320px; margin: 0 auto 36px; position: relative; transform: scale(var(--urge-scale, 1)); transition: transform 200ms cubic-bezier(0.4, 0, 0.2, 1); }
.urge-ring { position: absolute; inset: 0; border-radius: 50%; border: 1px solid rgba(245,158,11,0.30); }
.urge-ring.r2 { inset: 32px; border-color: rgba(245,158,11,0.22); }
.urge-ring.r3 { inset: 64px; border-color: rgba(245,158,11,0.14); }
.urge-core { position: absolute; inset: 96px; border-radius: 50%; background: radial-gradient(60% 60% at 50% 40%, rgba(245,158,11,0.20), rgba(245,158,11,0.04)); display: flex; flex-direction: column; align-items: center; justify-content: center; }
.urge-counter { font-size: 56px; font-weight: 200; color: var(--ink-1); letter-spacing: -0.04em; font-variant-numeric: tabular-nums; line-height: 1; }
.urge-unit { font-size: 24px; color: var(--ink-2); margin-left: 2px; }
.urge-of { font-size: 11px; color: var(--ink-2); letter-spacing: 0.12em; text-transform: uppercase; margin-top: 4px; font-weight: 500; }
.urge-phase { font-size: clamp(2rem, 4.8vw, 2.8rem); font-weight: 500; letter-spacing: -0.025em; color: var(--ink-1); margin: 0 0 12px; }
.urge-sub { color: var(--ink-2); font-size: 1rem; line-height: 1.55; margin: 0 0 36px; }
.urge-anchor { padding: 14px 28px; background: transparent; color: var(--ink-1); border: 1px solid var(--line-2); border-radius: 999px; font: inherit; font-size: 14px; font-weight: 500; cursor: pointer; transition: border-color 200ms ease, background 200ms ease; }
.urge-anchor:hover { border-color: var(--line-3); background: rgba(255,255,255,0.02); }

/* ---------- Finish ---------- */
.urge-finish { max-width: 520px; text-align: center; position: relative; z-index: 1; padding: 0 16px; }
.urge-finish-h { font-family: var(--font-serif); font-style: italic; font-size: clamp(2rem, 5vw, 3rem); font-weight: 400; line-height: 1.15; color: var(--ink-1); margin: 18px 0 24px; }
.urge-finish-sub { color: var(--ink-2); font-size: 1.0625rem; line-height: 1.55; margin: 0 0 36px; }
.urge-finish-cta { display: inline-flex; gap: 14px; align-items: center; flex-wrap: wrap; justify-content: center; }
.urge-again { padding: 14px 24px; background: transparent; color: var(--ink-1); border: 1px solid var(--line-2); border-radius: 999px; font: inherit; font-size: 14px; cursor: pointer; transition: border-color 200ms ease, background 200ms ease; }
.urge-again:hover { border-color: var(--line-3); background: rgba(255,255,255,0.02); }
.urge-app { color: #4DA3FF; font-size: 14px; font-weight: 500; padding: 14px 18px; }
