/* Taktume Landing — chooser + product pages
   Cyan = Recruit, Purple = Anytime
*/

:root {
  --bg-deep: #02060a;
  --cy: #00FFFF;
  --cy2: #00E5FF;
  --cy3: #00b8cc;
  --cy-glow: rgba(0,255,255,0.18);
  --pu: #a855f7;
  --pu2: #c084fc;
  --pu3: #7c3aed;
  --pu-glow: rgba(168,85,247,0.22);
  --txt: rgba(255,255,255,0.92);
  --txt2: rgba(255,255,255,0.55);
  --txt3: rgba(255,255,255,0.28);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { background: #000; color: var(--txt); font-family: 'Geist', 'Inter', system-ui, sans-serif; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
body { min-height: 100vh; }
button { font-family: inherit; cursor: pointer; }

/* =========================== CHOOSER =========================== */

.chooser {
  position: fixed; inset: 0;
  background: #000;
  z-index: 50;
  overflow: hidden;
}

/* persistent backgrounds — half-screen each */
.chooser-bg-anytime, .chooser-bg-recruit {
  position: absolute; top: 0; bottom: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  transition: opacity 0.5s ease, filter 0.5s ease;
}
.chooser-bg-anytime {
  left: 0; right: 50%;
  background:
    radial-gradient(ellipse 80% 90% at 30% 50%, rgba(168,85,247,0.22), transparent 65%),
    linear-gradient(135deg, #0a0612 0%, #0f0820 100%);
}
.chooser-bg-recruit {
  left: 50%; right: 0;
  background:
    radial-gradient(ellipse 80% 90% at 70% 50%, rgba(0,255,255,0.12), transparent 65%),
    linear-gradient(135deg, #050e10 0%, #02080c 100%);
}
.chooser.has-hover .chooser-bg-anytime,
.chooser.has-hover .chooser-bg-recruit { opacity: 0.7; }
.chooser .chooser-half:hover ~ .chooser-bg-anytime,
.chooser .chooser-half:hover ~ .chooser-bg-recruit { /* noop, kept for spec */ }

/* bokeh canvas (Anytime) */
.bokeh-canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.chooser-bg-anytime::after {
  content: '';
  position: absolute; inset: 0;
  backdrop-filter: blur(60px);
  -webkit-backdrop-filter: blur(60px);
  background: rgba(15, 8, 32, 0.32);
  pointer-events: none;
}

/* node network (Recruit) */
.chooser-bg-recruit .node-net,
.chooser-preview-recruit .node-net {
  position: absolute; inset: 0; width: 100%; height: 100%;
  opacity: 0.85;
}

@keyframes netLineIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes netNodeIn { from { opacity: 0; transform: scale(0.4); transform-origin: center; } to { opacity: 1; transform: scale(1); } }

/* halves sit on top, no own background */
.chooser-half {
  position: absolute; top: 0; bottom: 0; width: 50%;
  display: flex; align-items: center; justify-content: center;
  padding: 72px 48px;
  cursor: pointer;
  overflow: hidden;
  z-index: 2;
  text-align: left;
  transition: backdrop-filter 0.4s ease;
}
.chooser-half.anytime { left: 0; }
.chooser-half.recruit { right: 0; }
.chooser-half:hover { backdrop-filter: brightness(1.1); }
.chooser-half {
  transition: width 0.45s cubic-bezier(0.65,0,0.35,1),
              backdrop-filter 0.4s ease,
              opacity 0.4s ease;
}

/* dim non-hovered side */
.chooser.has-hover .chooser-half:not(:hover) { opacity: 0.4; transition: opacity 0.4s; }

/* ── Hover-side expansion ──
   Give the active half ~65% of the viewport so the hover-reel videos
   (which sit at the outer edge) keep more horizontal distance from the
   text content. Backgrounds + divider slide with the new boundary. */
.chooser.hover-anytime .chooser-half.anytime { width: 65%; }
.chooser.hover-anytime .chooser-half.recruit { width: 35%; }
.chooser.hover-recruit .chooser-half.anytime { width: 35%; }
.chooser.hover-recruit .chooser-half.recruit { width: 65%; }

.chooser-bg-anytime, .chooser-bg-recruit {
  transition: left 0.45s cubic-bezier(0.65,0,0.35,1),
              right 0.45s cubic-bezier(0.65,0,0.35,1),
              opacity 0.5s ease,
              filter 0.5s ease;
}
.chooser.hover-anytime .chooser-bg-anytime { right: 35%; }
.chooser.hover-anytime .chooser-bg-recruit { left: 65%; }
.chooser.hover-recruit .chooser-bg-anytime { right: 65%; }
.chooser.hover-recruit .chooser-bg-recruit { left: 35%; }

.chooser-divider,
.chooser-divider-orb {
  transition: left 0.45s cubic-bezier(0.65,0,0.35,1);
}
.chooser.hover-anytime .chooser-divider,
.chooser.hover-anytime .chooser-divider-orb { left: 65%; }
.chooser.hover-recruit .chooser-divider,
.chooser.hover-recruit .chooser-divider-orb { left: 35%; }

.chooser-preview-anytime, .chooser-preview-recruit {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: -1;
}

.chooser-content {
  position: relative;
  z-index: 2;
  max-width: 440px;
  display: flex; flex-direction: column; align-items: flex-start; gap: 18px;
  transition: transform 0.5s cubic-bezier(0.65,0,0.35,1);
}
.chooser-half.anytime .chooser-content { margin-left: auto; margin-right: 60px; }
.chooser-half.recruit .chooser-content { margin-right: auto; margin-left: 60px; }
.chooser-half:hover .chooser-content { transform: translateY(-6px); }

/* When a side is hovered, shift its text content inward (toward the
   centerline) and away from the hover-reel videos sitting at the
   outer edge — prevents text/video overlap on narrower viewports. */
.chooser.hover-anytime .chooser-half.anytime:hover .chooser-content {
  transform: translate(60px, -6px);
}
.chooser.hover-recruit .chooser-half.recruit:hover .chooser-content {
  transform: translate(-60px, -6px);
}

/* unique product mark — logo only, no pill */
.chooser-mark {
  display: inline-flex; align-items: center;
  padding: 0;
  background: none;
  border: none;
  box-shadow: none;
  backdrop-filter: none;
}
.chooser-mark-name {
  font-size: 0.92rem; font-weight: 500; letter-spacing: -0.01em; color: var(--txt2);
}
.chooser-mark-name strong {
  font-weight: 700; letter-spacing: -0.02em;
}
.anytime .chooser-mark-name strong { color: var(--pu2); }
.recruit .chooser-mark-name strong { color: var(--cy); }

@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:.25;} }

.chooser-h1 {
  font-size: clamp(2.4rem, 4.6vw, 3.8rem);
  font-weight: 700; line-height: 1.02; letter-spacing: -0.035em;
  text-wrap: balance;
}
.anytime .chooser-h1 em { font-style: normal; color: var(--pu2); text-shadow: 0 0 40px rgba(168,85,247,0.45); }
.recruit .chooser-h1 em { font-style: normal; color: var(--cy); text-shadow: 0 0 40px rgba(0,255,255,0.5); }

.chooser-sub {
  color: var(--txt2);
  font-size: 1rem; line-height: 1.65;
  max-width: 380px;
}

.chooser-bullets {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: 6px;
  text-align: left;
}
.chooser-bullets li {
  list-style: none;
  display: flex; align-items: center; gap: 10px;
  font-size: 0.86rem; color: var(--txt2);
}
.chooser-bullets li::before {
  content: ''; width: 14px; height: 1px; background: currentColor; opacity: 0.5;
}
.anytime .chooser-bullets li { color: rgba(192,132,252,0.85); }
.recruit .chooser-bullets li { color: rgba(34,212,250,0.85); }

.chooser-cta {
  margin-top: 12px;
  padding: 14px 28px;
  border-radius: 999px;
  font-size: 0.95rem; font-weight: 600;
  border: 1px solid; background: transparent;
  color: var(--txt);
  display: inline-flex; align-items: center; gap: 12px;
  transition: all 0.25s ease;
  letter-spacing: -0.005em;
}
.anytime .chooser-cta { border-color: var(--pu); background: var(--pu); color: #fff; box-shadow: 0 6px 24px rgba(168,85,247,0.3); }
.recruit .chooser-cta { border-color: var(--cy); background: var(--cy); color: #001014; box-shadow: 0 6px 24px rgba(0,255,255,0.25); }
.anytime .chooser-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 36px var(--pu-glow); }
.recruit .chooser-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 36px var(--cy-glow); }
.chooser-cta svg { width: 16px; height: 16px; }
.chooser-meta {
  font-family: 'Geist Mono', monospace;
  font-size: 0.66rem; letter-spacing: 0.06em;
  color: var(--txt3);
  margin-top: 4px;
}

/* ── divider ── */
.chooser-divider {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%; width: 1px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,0.18) 18%, rgba(255,255,255,0.18) 82%, transparent);
  z-index: 5;
  transform: translateX(-0.5px);
}
.chooser-divider::before {
  content: '';
  position: absolute; left: -40px; right: -40px; top: 0; bottom: 0;
  background:
    linear-gradient(90deg, transparent, rgba(168,85,247,0.08) 30%, rgba(0,255,255,0.08) 70%, transparent);
  filter: blur(16px);
  z-index: -1;
}
.chooser-divider-orb {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 64px; height: 64px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #fff, transparent 60%), conic-gradient(from 0deg, var(--pu), var(--cy), var(--pu));
  box-shadow: 0 0 60px rgba(255,255,255,0.25), 0 0 120px rgba(168,85,247,0.3), 0 0 120px rgba(0,255,255,0.3);
  z-index: 6;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Geist Mono', monospace;
  font-size: 0.62rem; font-weight: 600; letter-spacing: 0.1em;
  color: rgba(0,0,0,0.85);
  animation: orbSpin 12s linear infinite;
}
.chooser-divider-orb::after {
  content: 'OR';
  position: absolute;
  background: #000; padding: 4px 10px; border-radius: 999px;
  font-size: 0.6rem;
  border: 1px solid rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.16em;
  animation: orbSpinReverse 12s linear infinite;
}
@keyframes orbSpin { to { transform: translate(-50%, -50%) rotate(360deg); } }
@keyframes orbSpinReverse { to { transform: rotate(-360deg); } }

/* center wordmark — TAKTUME with ANYTIME left, RECRUIT right */
.chooser-wordmark {
  position: absolute;
  top: 36px; left: 50%; transform: translateX(-50%);
  display: flex; align-items: center; gap: 14px;
  z-index: 11;
  font-family: 'Geist', sans-serif;
  font-weight: 800;
  letter-spacing: 0.06em;
  white-space: nowrap;
  font-size: 0.96rem;
}
.wm-tak { color: rgba(255,255,255,0.92); letter-spacing: 0.12em; }
.wm-anytime {
  color: var(--pu2);
  text-shadow: 0 0 18px rgba(168,85,247,0.4);
  transition: color 0.3s, text-shadow 0.3s, transform 0.3s;
}
.wm-recruit {
  color: var(--cy);
  text-shadow: 0 0 18px rgba(0,255,255,0.45);
  transition: color 0.3s, text-shadow 0.3s, transform 0.3s;
}
.wm-bar {
  width: 18px; height: 1px; background: rgba(255,255,255,0.2); display: inline-block;
}
.chooser-wordmark.side-anytime .wm-anytime { transform: scale(1.12); text-shadow: 0 0 32px rgba(168,85,247,0.7); }
.chooser-wordmark.side-anytime .wm-recruit { color: rgba(255,255,255,0.25); text-shadow: none; }
.chooser-wordmark.side-anytime .wm-tak { color: rgba(255,255,255,0.5); }
.chooser-wordmark.side-recruit .wm-recruit { transform: scale(1.12); text-shadow: 0 0 32px rgba(0,255,255,0.75); }
.chooser-wordmark.side-recruit .wm-anytime { color: rgba(255,255,255,0.25); text-shadow: none; }
.chooser-wordmark.side-recruit .wm-tak { color: rgba(255,255,255,0.5); }

.chooser-question {
  position: absolute;
  bottom: 36px; left: 0; right: 0;
  text-align: center;
  font-size: 0.74rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--txt3);
  font-family: 'Geist Mono', monospace;
  z-index: 4;
}

/* hover preview content */
.chooser-preview-anytime, .chooser-preview-recruit {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
}
.chooser-half:hover .chooser-preview-anytime,
.chooser-half:hover .chooser-preview-recruit { opacity: 1; transition: opacity 0.6s ease 0.1s; }

/* preview anytime: orb + practice cards */
.prev-orb {
  position: absolute;
  top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 280px; height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle at 32% 28%, rgba(212,170,255,0.4), rgba(168,85,247,0.18) 50%, transparent 75%);
  filter: blur(8px);
  animation: prevPulse 3s ease-in-out infinite;
  opacity: 0.6;
}
@keyframes prevPulse {
  0%,100% { transform: translate(-50%,-50%) scale(0.95); opacity: 0.5; }
  50% { transform: translate(-50%,-50%) scale(1.08); opacity: 0.8; }
}

.prev-cards {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.prev-card {
  position: absolute;
  background: rgba(20, 12, 40, 0.85);
  border: 1px solid rgba(168,85,247,0.3);
  border-radius: 12px;
  padding: 12px 14px;
  font-size: 0.72rem;
  color: var(--txt2);
  backdrop-filter: blur(8px);
  box-shadow: 0 12px 40px rgba(168,85,247,0.18);
  opacity: 0;
  transform: translateY(8px);
  animation: prevCardIn 0.5s ease forwards;
  min-width: 180px;
}
.prev-card.pc1 { top: 22%; left: 12%; animation-delay: 0.2s; }
.prev-card.pc2 { top: 60%; left: 18%; animation-delay: 0.5s; }
.prev-card.pc3 { top: 32%; right: 14%; animation-delay: 0.8s; }
.prev-card .pc-label { font-family: 'Geist Mono', monospace; font-size: 0.6rem; color: var(--pu2); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 4px; }
.prev-card .pc-text { color: var(--txt); font-weight: 500; }
@keyframes prevCardIn {
  to { opacity: 1; transform: translateY(0); }
}

/* preview recruit: world map with nodes */
.prev-globe {
  position: absolute;
  inset: 0;
  display: flex; align-items: center; justify-content: center;
}
.prev-globe svg { width: 90%; height: 90%; max-width: 560px; }
.prev-globe-pulse {
  position: absolute;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(0,255,255,0.12), transparent 60%);
  border-radius: 50%;
  filter: blur(20px);
  animation: prevPulse 4s ease-in-out infinite;
}

/* =========================== TRANSITION =========================== */

/* Horizontal slide track — chooser ↔ product. Lives over the viewport during
   the 480ms slide, then unmounts so the product page can use normal scrolling. */
.slide-track {
  position: fixed;
  inset: 0;
  overflow: hidden;
  z-index: 9999;
  background: #000;
}
.slide-pane {
  position: absolute;
  inset: 0;
  width: 100vw;
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  transition: transform 480ms cubic-bezier(.4, 0, .2, 1);
  will-change: transform;
}
/* Recruit on the right of chooser → chooser slides LEFT, recruit slides in from RIGHT. */
.slide-track.slide-left .slide-pane-chooser  { transform: translateX(0);     }
.slide-track.slide-left .slide-pane-product  { transform: translateX(100%);  }
.slide-track.slide-left.is-sliding .slide-pane-chooser  { transform: translateX(-100%); }
.slide-track.slide-left.is-sliding .slide-pane-product  { transform: translateX(0);     }
/* Anytime on the left of chooser → chooser slides RIGHT, anytime slides in from LEFT. */
.slide-track.slide-right .slide-pane-chooser { transform: translateX(0);     }
.slide-track.slide-right .slide-pane-product { transform: translateX(-100%); }
.slide-track.slide-right.is-sliding .slide-pane-chooser { transform: translateX(100%); }
.slide-track.slide-right.is-sliding .slide-pane-product { transform: translateX(0);    }

.transition-overlay {
  position: fixed; inset: 0;
  z-index: 200;
  background: #000;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}

.transition-stage {
  position: relative;
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
}

.transition-progress {
  position: absolute;
  bottom: 60px; left: 50%; transform: translateX(-50%);
  width: 280px; height: 2px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  overflow: hidden;
}
.transition-progress-fill {
  height: 100%;
  width: 0;
  border-radius: 2px;
  transition: width 0.1s linear;
}
.transition-recruit .transition-progress-fill { background: linear-gradient(90deg, var(--cy3), var(--cy)); box-shadow: 0 0 16px var(--cy-glow); }
.transition-anytime .transition-progress-fill { background: linear-gradient(90deg, var(--pu3), var(--pu2)); box-shadow: 0 0 16px var(--pu-glow); }

.transition-label {
  position: absolute;
  bottom: 90px; left: 50%; transform: translateX(-50%);
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt2);
}
.transition-label .tl-accent { color: var(--cy); }
.transition-anytime .transition-label .tl-accent { color: var(--pu2); }

.transition-skip {
  position: absolute;
  top: 32px; right: 32px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem;
  color: var(--txt2);
  background: transparent;
  border: 1px solid rgba(255,255,255,0.12);
  padding: 8px 16px;
  border-radius: 999px;
  letter-spacing: 0.05em;
  z-index: 10;
}
.transition-skip:hover { border-color: rgba(255,255,255,0.3); color: var(--txt); }

/* world-map transition stage */
.tx-globe {
  position: relative;
  width: min(90vw, 1100px);
  aspect-ratio: 16/9;
}
.tx-globe svg.world-base { position: absolute; inset: 0; width: 100%; height: 100%; }

.tx-node {
  position: absolute;
  transform: translate(-50%, -50%);
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.tx-node-tile {
  width: 84px; height: 56px;
  border-radius: 8px;
  border: 1px solid rgba(0,255,255,0.4);
  background: linear-gradient(160deg, rgba(0,30,38,0.9), rgba(0,12,16,0.85));
  position: relative;
  overflow: hidden;
  box-shadow: 0 0 32px rgba(0,255,255,0.32), inset 0 0 0 1px rgba(0,255,255,0.08);
  display: flex; align-items: center; justify-content: center;
}
.tx-node-tile::before {
  content:''; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 50% 35%, rgba(0,255,255,0.25), transparent 60%),
    repeating-linear-gradient(0deg, transparent 0 3px, rgba(0,255,255,0.04) 3px 4px);
}
.tx-node-tile .live {
  position: absolute; top: 4px; left: 4px;
  font-family: 'Geist Mono', monospace; font-size: 0.5rem;
  color: var(--cy); letter-spacing: 0.1em;
  display: flex; align-items: center; gap: 4px;
}
.tx-node-tile .live::before {
  content:''; width: 4px; height: 4px; background: #ef4444; border-radius: 50%;
  box-shadow: 0 0 6px #ef4444;
  animation: blink 1.4s infinite;
}
.tx-node-tile .face {
  width: 22px; height: 22px; border-radius: 50%;
  background: linear-gradient(135deg, #fde68a, #f59e0b);
  position: relative; z-index: 1;
}
.tx-node-label {
  font-family: 'Geist Mono', monospace; font-size: 0.6rem;
  color: var(--cy2);
  white-space: nowrap;
  letter-spacing: 0.08em;
  background: rgba(0,0,0,0.6); padding: 2px 6px; border-radius: 4px;
  border: 1px solid rgba(0,255,255,0.18);
}

.tx-dot {
  position: absolute;
  transform: translate(-50%, -50%);
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--cy);
  box-shadow: 0 0 12px var(--cy);
}
.tx-dot::after {
  content: '';
  position: absolute; inset: -8px;
  border-radius: 50%;
  border: 1px solid var(--cy);
  animation: dotRing 1.6s ease-out infinite;
  opacity: 0;
}
@keyframes dotRing {
  0% { transform: scale(0.4); opacity: 1; }
  100% { transform: scale(2.6); opacity: 0; }
}

.tx-line {
  stroke: rgba(0,255,255,0.45);
  stroke-width: 1;
  fill: none;
  stroke-dasharray: 4 6;
  stroke-linecap: round;
}

.tx-headline {
  position: absolute;
  top: 12%; left: 50%; transform: translateX(-50%);
  text-align: center;
  font-size: clamp(1.4rem, 2.4vw, 2.1rem);
  font-weight: 600; letter-spacing: -0.025em;
  text-wrap: balance;
  max-width: 720px;
  color: var(--txt);
  opacity: 0;
  animation: txHeadlineIn 0.8s ease 0.4s forwards;
}
.tx-headline em {
  font-style: normal;
  color: var(--cy);
  text-shadow: 0 0 24px var(--cy-glow);
}
.transition-anytime .tx-headline em { color: var(--pu2); text-shadow: 0 0 24px var(--pu-glow); }
@keyframes txHeadlineIn {
  from { opacity: 0; transform: translate(-50%, -10px); }
  to { opacity: 1; transform: translate(-50%, 0); }
}

/* anytime transition: orb expanding */
.tx-anytime-stage {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
  position: relative;
}
.tx-anytime-orb {
  width: 220px; height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle at 32% 28%, #d4aaff, #a855f7 45%, #6d28d9 78%, #2e1065);
  box-shadow: 0 0 80px rgba(168,85,247,0.6), 0 0 200px rgba(168,85,247,0.3);
  animation: anyOrbBloom 2.4s ease-in-out infinite;
}
@keyframes anyOrbBloom {
  0%,100% { transform: scale(1); }
  50% { transform: scale(1.12); }
}
.tx-anytime-rings { position: absolute; inset: 0; display:flex; align-items:center; justify-content:center; }
.tx-anytime-ring {
  position: absolute;
  border: 1px solid rgba(168,85,247,0.4);
  border-radius: 50%;
  animation: anyRing 3s ease-out infinite;
}
@keyframes anyRing {
  0% { width: 220px; height: 220px; opacity: 0.6; }
  100% { width: 700px; height: 700px; opacity: 0; }
}

/* =========================== SHARED COMPONENTS =========================== */

.lp-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 90;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 48px;
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.lp-nav-recruit { background: rgba(2,8,12,0.7); }
.lp-nav-anytime { background: rgba(8,4,15,0.7); }

.lp-brand { display: flex; align-items: center; gap: 12px; }
.lp-brand-name {
  font-family: 'Geist', sans-serif;
  font-size: 1.05rem; font-weight: 700; letter-spacing: -0.02em;
}
.lp-brand-name em { font-style: normal; font-weight: 400; color: var(--txt3); margin-left: 6px; }
.lp-nav-recruit .lp-brand-name em.product { color: var(--cy2); font-weight: 500; }
.lp-nav-anytime .lp-brand-name em.product { color: var(--pu2); font-weight: 500; }

.lp-nav-links { display: flex; gap: 28px; align-items: center; }
.lp-nav-links a { color: var(--txt2); text-decoration: none; font-size: 0.86rem; font-weight: 500; }
.lp-nav-links a:hover { color: var(--txt); }
.lp-nav-actions { display: flex; gap: 10px; align-items: center; }

.lp-nav-back {
  background: transparent; border: 1px solid rgba(255,255,255,0.08);
  color: var(--txt2);
  padding: 8px 14px; border-radius: 999px;
  font-size: 0.78rem;
  display: inline-flex; align-items: center; gap: 6px;
}
.lp-nav-back:hover { border-color: rgba(255,255,255,0.2); color: var(--txt); }

.lp-cta {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 20px; border-radius: 999px;
  font-weight: 600; font-size: 0.86rem;
  border: 1px solid; background: transparent;
  text-decoration: none;
  transition: all 0.2s;
}
.lp-cta-recruit { color: #001014; background: var(--cy); border-color: var(--cy); }
.lp-cta-recruit:hover { box-shadow: 0 0 24px var(--cy-glow); transform: translateY(-1px); }
.lp-cta-anytime { color: #fff; background: var(--pu); border-color: var(--pu); }
.lp-cta-anytime:hover { box-shadow: 0 0 24px var(--pu-glow); transform: translateY(-1px); }

.lp-cta-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 20px; border-radius: 999px;
  font-weight: 500; font-size: 0.86rem;
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--txt);
  background: rgba(255,255,255,0.03);
  text-decoration: none;
}
.lp-cta-ghost:hover { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.22); }

/* =========================== RECRUIT LANDING =========================== */

.recruit-page { background: #02080c; min-height: 100vh; position: relative; }

.recruit-hero {
  position: relative;
  min-height: 100vh;
  padding: 140px 48px 80px;
  display: flex; flex-direction: column; align-items: center;
  overflow: hidden;
}
.recruit-hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(0,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,255,255,0.04) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 30%, #000 30%, transparent 80%);
  pointer-events: none;
}

.recruit-pilot-banner {
  display: inline-flex; align-items: center; gap: 16px;
  padding: 8px 18px;
  border: 1px solid rgba(0,255,255,0.16);
  background: rgba(0,255,255,0.04);
  border-radius: 999px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.06em;
  color: var(--cy2);
  margin-bottom: 28px;
}
.recruit-pilot-banner .pilot-dot {
  width: 6px; height: 6px; background: var(--cy); border-radius: 50%;
  box-shadow: 0 0 8px var(--cy);
  animation: blink 2s infinite;
}
.recruit-pilot-banner .pilot-sep { color: var(--txt3); }

.recruit-h1 {
  font-size: clamp(2.6rem, 5.2vw, 4.8rem);
  font-weight: 700; letter-spacing: -0.035em;
  line-height: 1.0;
  text-align: center;
  text-wrap: balance;
  max-width: 16ch;
  margin-bottom: 22px;
}
.recruit-h1 em {
  font-style: normal;
  background: linear-gradient(135deg, var(--cy) 0%, var(--cy2) 50%, #74f0ff 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.recruit-h1 .recruit-h1-strike {
  position: relative;
  color: var(--txt3);
  font-weight: 400;
}
.recruit-h1 .recruit-h1-strike::after {
  content:''; position: absolute;
  left: -2%; right: -2%; top: 52%;
  height: 2px;
  background: var(--cy);
  box-shadow: 0 0 12px var(--cy-glow);
  transform: rotate(-2deg);
}

.recruit-sub {
  font-size: 1.1rem; color: var(--txt2);
  max-width: 580px; text-align: center;
  line-height: 1.65;
  margin-bottom: 36px;
  text-wrap: pretty;
}

.recruit-hero-ctas {
  display: flex; gap: 12px; align-items: center;
  margin-bottom: 64px;
}

/* world map hero — outline-only countries + sequential hub-and-spoke reveal.
   aspect-ratio matches the source SVG viewBox (784.077 × 458.627) so the
   container fills exactly with no letterboxing — city % coords stay aligned. */
.recruit-worldmap {
  position: relative;
  width: 100%;
  max-width: 1280px;
  aspect-ratio: 784.077 / 458.627;
  margin: 0 auto;
  padding-bottom: 56px;
}
.recruit-worldmap svg.world-base {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  display: block;
  /* stretch to fully fill — pins use container %, must match SVG bounds */
  preserveAspectRatio: none;
}

/* central hub server */
.wm-hub {
  position: absolute;
  transform: translate(-50%, -50%);
  width: 18px; height: 18px;
  z-index: 20;
  pointer-events: none;
}
.wm-hub-core {
  position: absolute; inset: 5px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 12px #fff, 0 0 28px var(--cy), 0 0 50px var(--cy);
  animation: wmHubPulse 1.6s ease-in-out infinite;
}
@keyframes wmHubPulse { 0%,100%{transform:scale(1);} 50%{transform:scale(1.25);} }
.wm-hub-ring {
  position: absolute; inset: 0;
  border-radius: 50%;
  border: 1.5px solid var(--cy);
  opacity: 0.7;
  animation: wmRing 2.4s ease-out infinite;
}
.wm-hub-ring-2 { animation-delay: 1.2s; }
.wm-hub-label {
  position: absolute; left: 50%; top: calc(100% + 8px);
  transform: translateX(-50%);
  font-family: 'Geist Mono', monospace;
  font-size: 0.6rem; letter-spacing: 0.16em;
  color: var(--cy2);
  white-space: nowrap;
  background: rgba(2,8,12,0.7);
  padding: 2px 7px; border-radius: 3px;
  border: 1px solid rgba(0,255,255,0.2);
}

/* network edges */
.wm-network-svg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 2;
}
@keyframes dashIn { from { stroke-dashoffset: 40; opacity: 0; } to { stroke-dashoffset: 0; opacity: 1; } }

/* secondary city pin (no card) */
.wm-pin {
  position: absolute;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity 0.5s ease;
  width: 10px; height: 10px;
  z-index: 4;
  pointer-events: none;
}
.wm-pin.is-in {
  opacity: 1;
}
.wm-pin::before {
  content:''; position: absolute; inset: 3px;
  border-radius: 50%;
  background: var(--cy);
  box-shadow: 0 0 10px var(--cy), 0 0 20px rgba(0,255,255,0.5);
}
.wm-pin-ring {
  position: absolute; inset: 0;
  border-radius: 50%;
  border: 1.5px solid var(--cy);
  opacity: 0.7;
  animation: wmRing 2.4s ease-out infinite;
}
@keyframes wmRing {
  0%   { transform: scale(1);   opacity: 0.7; }
  100% { transform: scale(3.2); opacity: 0;   }
}

/* candidate live card — anchored above its pin */
.wm-card {
  position: absolute;
  transform: translate(-50%, calc(-100% - 4px)) scale(0.92);
  opacity: 0;
  width: 130px;
  border-radius: 8px;
  border: 1px solid rgba(0,255,255,0.34);
  background: rgba(2,12,16,0.94);
  box-shadow:
    0 18px 50px rgba(0,0,0,0.55),
    0 0 24px rgba(0,255,255,0.18),
    inset 0 0 0 1px rgba(0,255,255,0.08);
  overflow: hidden;
  z-index: 10;
  transform-origin: 50% calc(100% + 14px);
}
.wm-card.is-in {
  opacity: 1;
}
.wm-card-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16/10;
  background: linear-gradient(160deg, #001a22, #000);
  overflow: hidden;
}
.wm-card-thumb video,
.wm-card-thumb img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}
.wm-card-thumb::after {
  content:''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.55));
  pointer-events: none;
}
.wm-card-live {
  position: absolute; top: 5px; left: 5px;
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 6px;
  border-radius: 3px;
  background: rgba(0,0,0,0.78);
  color: #fff;
  font-family: 'Geist Mono', monospace;
  font-size: 0.52rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  z-index: 2;
}
.wm-live-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: #ef4444;
  box-shadow: 0 0 6px #ef4444;
  animation: wmLivePulse 1.4s ease-in-out infinite;
}
@keyframes wmLivePulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.4; }
}
.wm-card-meta {
  padding: 7px 9px 8px;
  font-family: 'Geist Mono', monospace;
  letter-spacing: 0.05em;
  display: flex; flex-direction: column; gap: 1px;
}
.wm-card-role {
  color: var(--txt);
  font-size: 0.66rem;
  font-weight: 600;
}
.wm-card-place {
  color: var(--txt3);
  font-size: 0.58rem;
}

.recruit-worldmap-stats {
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%);
  display: flex; gap: 10px;
  align-items: center;
  font-family: 'Geist Mono', monospace; font-size: 0.72rem;
  color: var(--txt2);
  letter-spacing: 0.06em;
  background: rgba(2,8,12,0.85);
  padding: 9px 20px;
  border-radius: 999px;
  border: 1px solid rgba(0,255,255,0.18);
  white-space: nowrap;
  backdrop-filter: blur(8px);
}
.recruit-worldmap-stats .acc { color: var(--cy2); font-weight: 600; }
.recruit-worldmap-stats .sep { color: var(--txt3); opacity: 0.7; }

/* recruit sections */
.recruit-section { padding: 100px 48px; position: relative; }
.recruit-wrap { max-width: 1200px; margin: 0 auto; }

.recruit-eyebrow {
  font-family: 'Geist Mono', monospace; font-size: 0.7rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--cy3); margin-bottom: 14px;
  display: inline-flex; align-items: center; gap: 8px;
}
.recruit-eyebrow::before { content: ''; display: none; }

.recruit-h2 {
  font-size: clamp(1.9rem, 3.6vw, 2.8rem);
  font-weight: 700; letter-spacing: -0.025em;
  line-height: 1.1; text-wrap: balance;
  max-width: 22ch;
  margin-bottom: 20px;
}
.recruit-h2 em { font-style: normal; color: var(--cy2); }

.recruit-section-sub {
  color: var(--txt2);
  font-size: 1.02rem; line-height: 1.7;
  max-width: 540px;
  margin-bottom: 48px;
}

/* pilot proof section */
.pilot-proof {
  padding: 56px 48px;
  border-top: 1px solid rgba(0,255,255,0.08);
  border-bottom: 1px solid rgba(0,255,255,0.08);
  background: linear-gradient(180deg, rgba(0,255,255,0.02), transparent);
}
.pilot-proof-grid {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1.1fr repeat(4, 1fr);
  gap: 32px;
  align-items: center;
}
.pilot-proof-label {
  font-family: 'Geist Mono', monospace; font-size: 0.72rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--cy3);
  line-height: 1.6;
}
.pilot-proof-label strong {
  display: block;
  color: var(--txt); font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.04em; text-transform: none;
  margin-top: 4px; font-family: 'Geist', sans-serif;
}
.pilot-proof-stat { text-align: left; }
.pilot-proof-stat .ps-num {
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  font-weight: 700; letter-spacing: -0.03em;
  color: var(--cy);
  line-height: 1;
  font-feature-settings: "tnum";
  text-shadow: 0 0 24px rgba(0,255,255,0.3);
}
.pilot-proof-stat .ps-num.green { color: #34d399; text-shadow: 0 0 24px rgba(52,211,153,0.3); }
.pilot-proof-stat .ps-lbl {
  font-family: 'Geist Mono', monospace;
  font-size: 0.66rem; letter-spacing: 0.08em;
  color: var(--txt3);
  margin-top: 8px;
  text-transform: uppercase;
}

/* shift comparison */
.shift-grid {
  display: grid; grid-template-columns: 1fr 60px 1fr; gap: 0;
  align-items: stretch;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.06);
}
.shift-col { padding: 36px 32px; }
.shift-col-old { background: rgba(255,255,255,0.02); }
.shift-col-new { background: linear-gradient(160deg, rgba(0,255,255,0.05), rgba(0,255,255,0.02)); border-left: 1px solid rgba(0,255,255,0.08); }
.shift-arrow {
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,255,255,0.08);
  border-left: 1px solid rgba(0,255,255,0.16);
  border-right: 1px solid rgba(0,255,255,0.16);
  color: var(--cy);
  font-size: 1.4rem;
}
.shift-tag {
  font-family: 'Geist Mono', monospace; font-size: 0.66rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt3); margin-bottom: 10px;
}
.shift-col-new .shift-tag { color: var(--cy2); }
.shift-time { font-size: 1.6rem; font-weight: 600; letter-spacing: -0.02em; margin-bottom: 18px; }
.shift-col-old .shift-time { color: var(--txt2); }
.shift-col-new .shift-time { color: var(--cy); }
.shift-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.shift-list li {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: 0.86rem; color: var(--txt2); line-height: 1.55;
}
.shift-list li::before {
  content: ''; width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0; margin-top: 3px;
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12);
}
.shift-col-new .shift-list li::before {
  background: rgba(0,255,255,0.1); border-color: rgba(0,255,255,0.25);
  box-shadow: 0 0 8px rgba(0,255,255,0.25);
}

/* live moment / hero video */
.recruit-clip {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(0,255,255,0.16);
  background: #000;
  box-shadow: 0 32px 80px rgba(0,255,255,0.08);
}
.recruit-clip video {
  width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block;
}
.recruit-clip-overlay {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 22px 26px;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,0.4), transparent 25%, transparent 70%, rgba(0,0,0,0.7));
}
.recruit-clip-top { display: flex; justify-content: space-between; align-items: flex-start; }
.recruit-clip-tag {
  font-family: 'Geist Mono', monospace; font-size: 0.7rem;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px; border-radius: 999px;
  background: rgba(0,0,0,0.6); border: 1px solid rgba(0,255,255,0.32);
  color: var(--cy2);
  letter-spacing: 0.1em;
}
.recruit-clip-tag::before {
  content:''; width: 6px; height: 6px; background: #ef4444; border-radius: 50%;
  box-shadow: 0 0 6px #ef4444;
  animation: blink 1.4s infinite;
}
.recruit-clip-meta {
  font-family: 'Geist Mono', monospace; font-size: 0.66rem;
  color: var(--txt2); text-align: right;
  letter-spacing: 0.06em;
}
.recruit-clip-meta strong { color: var(--cy); display: block; font-weight: 600; }
.recruit-clip-bottom {
  display: flex; justify-content: space-between; align-items: flex-end;
  font-family: 'Geist Mono', monospace; font-size: 0.7rem;
  color: var(--txt2);
}
.recruit-clip-score {
  display: flex; align-items: center; gap: 12px;
  font-family: 'Geist Mono', monospace; font-size: 0.75rem;
  background: rgba(0,0,0,0.6); padding: 10px 14px; border-radius: 8px;
  border: 1px solid rgba(0,255,255,0.2);
  color: var(--cy2);
}
.recruit-clip-score .clip-score-n { color: var(--cy); font-weight: 600; font-size: 1.1rem; }

.clip-grid {
  display: grid; grid-template-columns: 1.6fr 1fr; gap: 32px;
  align-items: center;
}

/* dashboard preview */
.dash-shell {
  background: #030d10;
  border: 1px solid rgba(0,255,255,0.12);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,255,255,0.06);
}
.dash-titlebar {
  padding: 12px 18px;
  display: flex; align-items: center; gap: 8px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  background: rgba(0,0,0,0.3);
}
.dash-titlebar .dot { width: 8px; height: 8px; border-radius: 50%; }
.dash-titlebar .dot.r { background: rgba(255,80,70,0.55); }
.dash-titlebar .dot.y { background: rgba(254,180,40,0.55); }
.dash-titlebar .dot.g { background: rgba(40,195,60,0.55); }
.dash-titlebar .ttl {
  margin-left: 14px;
  font-family: 'Geist Mono', monospace; font-size: 0.7rem;
  color: var(--txt3);
}
.dash-titlebar .ttl strong { color: var(--cy2); font-weight: 500; }
.dash-content { padding: 22px; }

.dash-kpi-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
  margin-bottom: 18px;
}
.dash-kpi {
  padding: 14px 16px;
  border: 1px solid rgba(0,255,255,0.1);
  background: rgba(0,255,255,0.03);
  border-radius: 10px;
}
.dash-kpi .k-num {
  font-size: 1.4rem; font-weight: 600; letter-spacing: -0.02em;
  color: var(--cy);
}
.dash-kpi .k-lbl {
  font-family: 'Geist Mono', monospace; font-size: 0.6rem;
  color: var(--txt3); margin-top: 4px;
  letter-spacing: 0.06em; text-transform: uppercase;
}
.dash-kpi .k-trend {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 0.65rem; color: #34d399;
  margin-top: 6px;
}

.dash-row {
  display: grid; grid-template-columns: 32px 2fr 1.2fr 90px 70px;
  gap: 10px; align-items: center;
  padding: 10px 14px;
  border: 1px solid rgba(255,255,255,0.04);
  background: rgba(255,255,255,0.02);
  border-radius: 8px;
  margin-bottom: 6px;
  font-size: 0.78rem;
}
.dash-row .av {
  width: 28px; height: 28px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 0.65rem; color: #001014;
}
.dash-row .candidate-info strong { display: block; font-weight: 500; color: var(--txt); }
.dash-row .candidate-info span { font-family: 'Geist Mono', monospace; font-size: 0.62rem; color: var(--txt3); }
.dash-row .role-tag {
  font-family: 'Geist Mono', monospace; font-size: 0.66rem;
  color: var(--txt2);
}
.dash-row .score-bar {
  display: flex; flex-direction: column; gap: 4px; align-items: flex-end;
}
.dash-row .score-num { font-weight: 600; color: var(--cy); font-size: 0.92rem; }
.dash-row .score-track { width: 70px; height: 3px; background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden; }
.dash-row .score-fill { height: 100%; background: linear-gradient(90deg, var(--cy3), var(--cy)); border-radius: 2px; }
.dash-row .verdict {
  font-family: 'Geist Mono', monospace; font-size: 0.6rem;
  padding: 3px 8px; border-radius: 4px;
  text-align: center; letter-spacing: 0.04em;
}
.dash-row .verdict.r { background: rgba(16,185,129,0.1); color: #34d399; border: 1px solid rgba(16,185,129,0.2); }
.dash-row .verdict.y { background: rgba(245,158,11,0.1); color: #fbbf24; border: 1px solid rgba(245,158,11,0.2); }
.dash-row .verdict.x { background: rgba(255,255,255,0.04); color: var(--txt3); border: 1px solid rgba(255,255,255,0.06); }

/* features grid */
.feat-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: rgba(255,255,255,0.04);
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.06);
}
.feat-card {
  padding: 32px 28px;
  background: #050e11;
  display: flex; flex-direction: column; gap: 14px;
}
.feat-icon {
  width: 38px; height: 38px;
  border-radius: 8px;
  background: rgba(0,255,255,0.06);
  border: 1px solid rgba(0,255,255,0.16);
  display: flex; align-items: center; justify-content: center;
  color: var(--cy);
}
.feat-card h4 { font-size: 1rem; font-weight: 600; letter-spacing: -0.015em; }
.feat-card p { font-size: 0.85rem; color: var(--txt2); line-height: 1.6; }

/* quote section */
.recruit-quote {
  padding: 80px 48px;
  background: linear-gradient(180deg, rgba(0,255,255,0.04), transparent);
  border-top: 1px solid rgba(0,255,255,0.08);
  border-bottom: 1px solid rgba(0,255,255,0.08);
}
.recruit-quote-wrap { max-width: 940px; margin: 0 auto; }
.recruit-quote q {
  display: block;
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 500; letter-spacing: -0.02em;
  line-height: 1.3;
  margin-bottom: 32px;
  text-wrap: balance;
  quotes: "“" "”";
}
.recruit-quote q em { color: var(--cy2); font-style: normal; }
.recruit-quote-attr {
  display: flex; align-items: center; gap: 14px;
  font-size: 0.92rem;
}
.recruit-quote-attr .qa-av {
  width: 48px; height: 48px; border-radius: 50%;
  background: linear-gradient(135deg, var(--cy3), var(--cy));
  display: flex; align-items: center; justify-content: center;
  color: #001014; font-weight: 700;
}
.recruit-quote-attr strong { display: block; color: var(--txt); }
.recruit-quote-attr span { color: var(--txt3); font-family: 'Geist Mono', monospace; font-size: 0.78rem; }

/* CTA */
.recruit-final {
  padding: 120px 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.recruit-final::before {
  content:''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 40% at 50% 50%, rgba(0,255,255,0.12), transparent 70%);
}
.recruit-final-h {
  font-size: clamp(2.4rem, 4.4vw, 3.6rem);
  font-weight: 700; letter-spacing: -0.03em;
  line-height: 1.05; text-wrap: balance;
  max-width: 18ch; margin: 0 auto 24px;
  position: relative;
}
.recruit-final-h em { font-style: normal; color: var(--cy); }
.recruit-final-sub {
  color: var(--txt2); font-size: 1.05rem;
  max-width: 540px; margin: 0 auto 36px;
  line-height: 1.65; position: relative;
}
.recruit-final-ctas { display: flex; gap: 12px; justify-content: center; position: relative; }

/* footer */
.lp-footer {
  padding: 36px 48px 32px;
  border-top: 1px solid rgba(255,255,255,0.05);
  font-size: 0.78rem; color: var(--txt3);
  font-family: 'Geist Mono', monospace; letter-spacing: 0.05em;
}
.lp-footer-recruit { background: #02080c; }
.lp-footer-anytime { background: #08040f; }
.lp-footer a { color: var(--txt2); text-decoration: none; transition: color 0.15s ease; }
.lp-footer a:hover { color: var(--txt); }

/* Top row: brand on left, socials on right */
.lp-footer-top {
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  margin-bottom: 20px;
}
.lp-footer-brand {
  display: flex; align-items: center; gap: 14px;
}
.lp-footer-brand-text {
  display: flex; flex-direction: column; gap: 2px;
  text-transform: none; letter-spacing: 0;
  font-family: 'Geist', sans-serif;
}
.lp-footer-name {
  font-size: 0.95rem; font-weight: 600; color: var(--txt);
}
.lp-footer-sub {
  font-size: 0.78rem; color: var(--txt3);
}
.lp-footer-sub a {
  color: var(--txt2); border-bottom: 1px dotted rgba(255,255,255,0.25);
}
.lp-footer-sub a:hover { color: var(--txt); border-bottom-color: rgba(255,255,255,0.6); }

/* Social icon row */
.lp-footer-socials {
  display: flex; align-items: center; gap: 10px;
}
.lp-footer-socials a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: 8px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  color: rgba(220,210,240,0.7);
  transition: all 0.15s ease;
}
.lp-footer-socials svg { width: 16px; height: 16px; }
.lp-footer-anytime .lp-footer-socials a:hover {
  background: rgba(168,85,247,0.15);
  border-color: rgba(168,85,247,0.5);
  color: #e9d5ff;
  transform: translateY(-1px);
}
.lp-footer-recruit .lp-footer-socials a:hover {
  background: rgba(0,229,255,0.15);
  border-color: rgba(0,229,255,0.5);
  color: #b6f7ff;
  transform: translateY(-1px);
}

/* Bottom row: copyright on left, links on right */
.lp-footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px;
}
.lp-footer-links { display: flex; gap: 22px; flex-wrap: wrap; }

@media (max-width: 720px) {
  .lp-footer { padding: 28px 22px 24px; }
  .lp-footer-top {
    flex-direction: column; align-items: flex-start; gap: 18px;
  }
  .lp-footer-bottom {
    flex-direction: column; align-items: flex-start; gap: 14px;
  }
  .lp-footer-links { gap: 14px 22px; font-size: 0.74rem; }
}

/* =========================== ANYTIME LANDING =========================== */

.anytime-page { background: #08040f; min-height: 100vh; position: relative; color: var(--txt); }

.anytime-hero {
  position: relative; min-height: 100vh;
  padding: 140px 48px 80px;
  display: flex; flex-direction: column; align-items: center; text-align: center;
  overflow: hidden;
}
.anytime-hero-bg {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 50% 40% at 50% 28%, rgba(168,85,247,0.18), transparent 70%),
    radial-gradient(ellipse 80% 50% at 50% 80%, rgba(124,58,237,0.08), transparent 70%);
}
.any-orb-hero {
  width: 220px; height: 220px;
  margin: 24px 0 36px;
  border-radius: 50%;
  background: radial-gradient(circle at 32% 28%, #d4aaff, #a855f7 45%, #6d28d9 78%, #2e1065);
  box-shadow: 0 0 100px rgba(168,85,247,0.5), 0 0 200px rgba(168,85,247,0.2);
  animation: anyOrbBloom 3s ease-in-out infinite;
  position: relative;
}
.any-orb-hero::after {
  content:''; position: absolute; inset: -16px;
  border-radius: 50%; border: 1px solid rgba(168,85,247,0.3);
  animation: anyOrbRing 3s ease-in-out infinite;
}
@keyframes anyOrbRing {
  0%,100% { transform: scale(1); opacity: 0.5; }
  50% { transform: scale(1.18); opacity: 0.1; }
}

.anytime-h1 {
  font-size: clamp(2.6rem, 5.2vw, 4.8rem);
  font-weight: 700; letter-spacing: -0.035em;
  line-height: 1.0; text-wrap: balance;
  max-width: 16ch; margin-bottom: 22px;
}
.anytime-h1 em {
  font-style: normal;
  background: linear-gradient(135deg, #c084fc 0%, #a855f7 50%, #d4aaff 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: 0 0 60px rgba(168,85,247,0.3);
}
.anytime-sub {
  font-size: 1.1rem; color: var(--txt2);
  max-width: 540px; line-height: 1.65;
  margin-bottom: 36px;
  text-wrap: pretty;
}
.anytime-hero-ctas {
  display: flex; gap: 12px; align-items: center;
}
.lp-cta-anytime-strong {
  background: linear-gradient(135deg, var(--pu), var(--pu3));
}

.anytime-section { padding: 100px 48px; position: relative; }
.anytime-wrap { max-width: 1100px; margin: 0 auto; }
.anytime-eyebrow {
  font-family: 'Geist Mono', monospace; font-size: 0.7rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--pu2); margin-bottom: 14px;
  display: inline-flex; align-items: center; gap: 8px;
}
.anytime-eyebrow::before { content: '▸'; opacity: 0.6; }
.anytime-h2 {
  font-size: clamp(1.9rem, 3.6vw, 2.8rem);
  font-weight: 700; letter-spacing: -0.025em;
  line-height: 1.1; text-wrap: balance;
  margin-bottom: 20px;
  color: var(--pu2);
  text-shadow: 0 0 40px rgba(168,85,247,0.2);
}
.anytime-section-sub {
  color: var(--txt2); font-size: 1.02rem;
  line-height: 1.7; max-width: 540px;
  margin-bottom: 48px;
}

.any-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(255,255,255,0.05); border-radius: 18px; overflow: hidden; }
.any-step { padding: 28px 24px; background: #0c0816; }
.any-step .step-n {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid rgba(168,85,247,0.25);
  background: rgba(168,85,247,0.08);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Geist Mono', monospace; font-weight: 600; font-size: 0.78rem;
  color: var(--pu2);
  margin-bottom: 14px;
}
.any-step h4 { font-size: 0.95rem; font-weight: 600; margin-bottom: 6px; }
.any-step p { font-size: 0.82rem; color: var(--txt2); line-height: 1.6; }

/* responsive trims */
@media (max-width: 900px) {
  .chooser { grid-template-columns: 1fr; grid-template-rows: 1fr 1fr; }
  .chooser-divider { left: 0; right: 0; top: 50%; bottom: auto; width: auto; height: 1px; }
  .chooser-divider-orb { left: 50%; top: 50%; }
  .pilot-proof-grid { grid-template-columns: 1fr 1fr; }
  .clip-grid { grid-template-columns: 1fr; }
  .feat-grid, .any-steps, .shift-grid { grid-template-columns: 1fr; }
  .shift-arrow { padding: 14px; }
}


/* ─────────────────────────────────────────────────────
   VIDEO PRODUCTION SLOTS / ROADMAP
   ───────────────────────────────────────────────────── */

.vroadmap-section {
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(0,255,255,0.04), transparent 60%),
    linear-gradient(180deg, rgba(2,8,12,0.4), rgba(0,4,8,0.95) 100%);
  position: relative;
}
.vroadmap-section::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(0,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,255,255,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  mask: linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent);
  -webkit-mask: linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent);
}

.vroadmap-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-top: 36px;
}
@media (max-width: 1100px) { .vroadmap-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .vroadmap-grid { grid-template-columns: 1fr; } }

.vslot {
  background: rgba(8,18,24,0.55);
  border: 1px solid rgba(0,255,255,0.08);
  border-radius: 14px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: border-color 0.25s, transform 0.25s, box-shadow 0.25s;
}
.vslot:hover {
  border-color: rgba(0,255,255,0.25);
  transform: translateY(-2px);
  box-shadow: 0 12px 36px -12px rgba(0,255,255,0.18);
}

.vslot-frame {
  position: relative;
  aspect-ratio: 16 / 10;
  background: #02080c;
  overflow: hidden;
  border-bottom: 1px solid rgba(0,255,255,0.08);
}
.vslot-frame video {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

.vslot-placeholder {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 18px;
  background:
    repeating-linear-gradient(135deg, rgba(0,255,255,0.025) 0 12px, transparent 12px 24px),
    radial-gradient(ellipse 70% 60% at 50% 50%, rgba(0,255,255,0.06), transparent 70%),
    #02080c;
  color: rgba(0,255,255,0.5);
}
.vslot-empty .vslot-placeholder { color: rgba(0,255,255,0.5); }
.vslot-ph-icon { width: 44px; height: 44px; opacity: 0.7; }
.vslot-ph-icon svg { width: 100%; height: 100%; }
.vslot-ph-record {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  color: rgba(0,255,255,0.7);
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  border: 1px solid rgba(0,255,255,0.18);
  border-radius: 999px;
  background: rgba(0,255,255,0.04);
}
.rec-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #ff3344; box-shadow: 0 0 8px #ff3344;
  animation: blink 1.4s infinite;
}

.vslot-corner-num {
  position: absolute; top: 10px; left: 10px;
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.7rem; letter-spacing: 0.05em;
  color: rgba(0,255,255,0.85);
  background: rgba(0,8,12,0.7);
  border: 1px solid rgba(0,255,255,0.25);
  padding: 4px 8px;
  border-radius: 6px;
  backdrop-filter: blur(6px);
}
.vslot-corner-dur {
  position: absolute; top: 10px; right: 10px;
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.66rem; letter-spacing: 0.05em;
  color: rgba(255,255,255,0.7);
  background: rgba(0,0,0,0.6);
  padding: 4px 8px;
  border-radius: 6px;
  backdrop-filter: blur(6px);
}

.vslot-body {
  padding: 16px 16px 14px;
  display: flex; flex-direction: column; gap: 8px;
  flex: 1;
}
.vslot-label {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--txt);
  letter-spacing: -0.01em;
}
.vslot-desc {
  font-size: 0.78rem;
  color: var(--txt2);
  line-height: 1.5;
}
.vslot-sells {
  font-size: 0.74rem;
  color: var(--txt3);
  line-height: 1.5;
  padding-top: 8px;
  border-top: 1px dashed rgba(255,255,255,0.06);
  margin-top: 4px;
}
.vslot-sells-eyebrow {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.6rem;
  letter-spacing: 0.18em;
  color: var(--cy2);
  display: block;
  margin-bottom: 3px;
}
.vslot-path {
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px dashed rgba(255,255,255,0.06);
  display: flex; flex-direction: column; gap: 4px;
}
.vslot-path-label {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  color: var(--txt3);
}
.vslot-path code {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.72rem;
  color: var(--cy);
  background: rgba(0,255,255,0.04);
  border: 1px solid rgba(0,255,255,0.12);
  padding: 6px 8px;
  border-radius: 6px;
  user-select: all;
  display: block;
  word-break: break-all;
}

/* ── checklist ── */
.vroadmap-checklist {
  margin-top: 32px;
  background: rgba(0,8,12,0.6);
  border: 1px solid rgba(0,255,255,0.1);
  border-radius: 14px;
  overflow: hidden;
}
.vroadmap-checklist-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 18px;
  border-bottom: 1px solid rgba(0,255,255,0.08);
  background: rgba(0,255,255,0.025);
}
.vrc-eyebrow {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.66rem; letter-spacing: 0.2em;
  color: var(--cy);
}
.vrc-meta {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.7rem; letter-spacing: 0.06em;
  color: var(--txt3);
}
.vroadmap-checklist-rows {
  display: flex; flex-direction: column;
}
.vrc-row {
  display: grid;
  grid-template-columns: 32px 220px 1fr 60px;
  gap: 14px;
  align-items: center;
  padding: 11px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 0.82rem;
}
.vrc-row:last-child { border-bottom: none; }
.vrc-row:hover { background: rgba(0,255,255,0.03); }
.vrc-num {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.68rem; letter-spacing: 0.04em;
  color: var(--cy2);
  background: rgba(0,255,255,0.06);
  border: 1px solid rgba(0,255,255,0.18);
  padding: 4px 6px;
  border-radius: 5px;
  text-align: center;
}
.vrc-label { color: var(--txt); font-weight: 500; }
.vrc-path {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.72rem;
  color: var(--cy);
  user-select: all;
  background: rgba(0,255,255,0.03);
  padding: 4px 8px;
  border-radius: 5px;
  border: 1px solid rgba(0,255,255,0.08);
  word-break: break-all;
}
.vrc-dur {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.7rem;
  color: var(--txt3);
  text-align: right;
}
@media (max-width: 800px) {
  .vrc-row { grid-template-columns: 28px 1fr 50px; }
  .vrc-path { grid-column: 1 / -1; }
}


/* ─────────────────────────────────────────────────────
   ANYTIME V2 — conversion-focused job-seeker landing
   ───────────────────────────────────────────────────── */

.anytime-v2 { background: #07050f; color: var(--txt); }

/* ── HERO ── */
.any-hero-v2 {
  position: relative;
  padding: 140px 56px 80px;
  overflow: hidden;
  background:
    radial-gradient(ellipse 80% 60% at 30% 30%, rgba(168,85,247,0.18), transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 70%, rgba(99,57,200,0.14), transparent 60%),
    linear-gradient(180deg, #0a0612 0%, #07050f 100%);
}
.any-hero-bg-stars { position: absolute; inset: 0; pointer-events: none; }
.any-hero-bg-stars span {
  position: absolute; width: 2px; height: 2px; border-radius: 50%;
  background: rgba(192,132,252,0.7);
  box-shadow: 0 0 6px rgba(192,132,252,0.6);
  animation: starTwinkle 4s ease-in-out infinite;
}
@keyframes starTwinkle { 0%,100%{opacity:.2;transform:scale(.7);} 50%{opacity:1;transform:scale(1.2);} }

.any-hero-grid {
  position: relative; z-index: 2;
  max-width: 1280px; margin: 0 auto;
  display: grid; grid-template-columns: 1.05fr 1fr; gap: 60px;
  align-items: center;
}
.any-hero-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 7px 14px;
  border-radius: 999px;
  background: rgba(168,85,247,0.08);
  border: 1px solid rgba(168,85,247,0.25);
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.7rem; letter-spacing: 0.16em;
  color: var(--pu2);
  margin-bottom: 26px;
}
.ahp-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--pu); box-shadow: 0 0 8px var(--pu); animation: blink 2s infinite; }

.any-h1-v2 {
  font-size: clamp(2.6rem, 5.2vw, 4.4rem);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.035em;
  margin: 0 0 22px;
  text-wrap: balance;
}
.any-h1-v2 em { font-style: normal; color: var(--pu2); text-shadow: 0 0 36px rgba(168,85,247,0.5); }

.any-sub-v2 {
  font-size: 1.05rem; line-height: 1.65;
  color: var(--txt2);
  max-width: 540px;
  margin: 0 0 32px;
  text-wrap: pretty;
}
.any-sub-v2 strong { color: var(--pu2); font-weight: 600; }

.any-hero-ctas-v2 { display: flex; gap: 14px; align-items: center; margin-bottom: 24px; }
.any-hero-ctas-v2 .lp-cta svg { width: 16px; height: 16px; margin-left: 6px; }

.any-hero-microproof {
  display: flex; gap: 14px; align-items: center;
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.74rem;
  color: var(--txt3);
  letter-spacing: 0.04em;
}
.any-hero-microproof b { color: var(--txt); font-weight: 600; }
.ahmp-sep { opacity: 0.4; }

/* ── HERO ORB ── */
.any-hero-right { position: relative; height: 540px; }
.any-hero-orb {
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 360px; height: 360px;
}
.aho-core {
  position: absolute; left: 50%; top: 50%;
  width: 110px; height: 110px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #e9d5ff, #a855f7 50%, #6d28d9 95%);
  box-shadow: 0 0 60px rgba(168,85,247,0.6), inset 0 0 30px rgba(255,255,255,0.2);
  transform: translate(-50%,-50%);
  animation: orbPulse 3s ease-in-out infinite;
}
@keyframes orbPulse { 0%,100%{transform:translate(-50%,-50%) scale(1);} 50%{transform:translate(-50%,-50%) scale(1.05);} }
.aho-ring {
  position: absolute; left: 50%; top: 50%;
  border-radius: 50%;
  border: 1px solid rgba(168,85,247,0.3);
  transform: translate(-50%,-50%);
}
.aho-ring.r1 { width: 180px; height: 180px; animation: orbPulse 3s ease-in-out infinite; }
.aho-ring.r2 { width: 250px; height: 250px; border-color: rgba(168,85,247,0.18); animation: orbPulse 4s ease-in-out infinite 0.4s; }
.aho-ring.r3 { width: 330px; height: 330px; border-color: rgba(168,85,247,0.1); animation: orbPulse 5s ease-in-out infinite 0.8s; }
.aho-wave {
  position: absolute; left: 50%; top: 50%;
  width: 110px; height: 110px;
  border-radius: 50%;
  border: 1.5px solid rgba(192,132,252,0.5);
  transform: translate(-50%,-50%);
  animation: ringOut 2.4s linear infinite;
}
.aho-wave.w2 { animation-delay: 0.8s; }
.aho-wave.w3 { animation-delay: 1.6s; }
@keyframes ringOut {
  0% { transform: translate(-50%,-50%) scale(1); opacity: 0.7; }
  100% { transform: translate(-50%,-50%) scale(2.6); opacity: 0; }
}
.aho-caption {
  position: absolute; left: 50%; bottom: -14px; transform: translateX(-50%);
  white-space: nowrap;
  background: rgba(11,6,18,0.9);
  border: 1px solid rgba(168,85,247,0.3);
  border-radius: 999px;
  padding: 8px 16px;
  font-size: 0.82rem;
  color: var(--pu2);
  display: inline-flex; align-items: center; gap: 10px;
  backdrop-filter: blur(10px);
}
.aho-listen-dot { width: 8px; height: 8px; border-radius: 50%; background: #ff3344; box-shadow: 0 0 10px #ff3344; animation: blink 1.4s infinite; }

/* ── live panel ── */
.any-live-panel {
  position: absolute; right: -10px; bottom: 30px;
  width: 320px;
  background: rgba(11,6,18,0.85);
  border: 1px solid rgba(168,85,247,0.22);
  border-radius: 14px;
  padding: 14px 16px;
  backdrop-filter: blur(14px);
  box-shadow: 0 16px 50px -16px rgba(0,0,0,0.7);
  font-family: 'Geist', sans-serif;
}
.alp-head {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.7rem; letter-spacing: 0.06em;
  color: var(--txt3);
  padding-bottom: 10px;
  margin-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.alp-rec { width: 7px; height: 7px; border-radius: 50%; background: #ff3344; box-shadow: 0 0 8px #ff3344; animation: blink 1.2s infinite; }
.alp-bar { flex: 1; }
.alp-rubric { display: flex; flex-direction: column; gap: 9px; margin-bottom: 12px; }
.alp-row {
  display: grid; grid-template-columns: 92px 1fr 28px; align-items: center; gap: 10px;
  font-size: 0.76rem;
  color: var(--txt2);
}
.alp-row b { color: var(--txt); font-family: 'Geist Mono', monospace; font-size: 0.78rem; text-align: right; }
.alp-meter { height: 4px; background: rgba(255,255,255,0.07); border-radius: 2px; overflow: hidden; }
.alp-meter i { display: block; height: 100%; background: linear-gradient(90deg, var(--pu), #c084fc); }
.alp-coach {
  background: rgba(168,85,247,0.06);
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 0.78rem;
  color: var(--txt2);
  line-height: 1.5;
}
.alp-coach-head {
  font-family: 'Geist Mono', monospace;
  font-size: 0.6rem; letter-spacing: 0.18em;
  color: var(--pu2);
  margin-bottom: 4px;
}

/* ── SECTIONS ── */
.any-section-v2 { padding: 96px 56px; position: relative; }
.any-wrap-v2 { max-width: 1280px; margin: 0 auto; }
.any-eyebrow {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--pu2);
  margin-bottom: 14px;
}
.any-h2-v2 {
  font-size: clamp(1.9rem, 3.4vw, 2.8rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin: 0 0 14px;
  text-wrap: balance;
}
.any-h2-v2 em { font-style: normal; color: var(--pu2); }
.any-section-sub-v2 {
  font-size: 1rem; color: var(--txt2);
  max-width: 660px; line-height: 1.6;
  margin: 0;
}

/* ── MODES GRID ── */
.modes-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
  margin-top: 36px;
}
@media (max-width: 900px) { .modes-grid { grid-template-columns: repeat(2, 1fr); } }
.mode-card {
  position: relative;
  background: rgba(168,85,247,0.03);
  border: 1px solid rgba(168,85,247,0.12);
  border-radius: 14px;
  padding: 22px 20px 50px;
  text-align: left;
  cursor: pointer;
  transition: all 0.25s ease;
  color: var(--txt);
  font-family: inherit;
  display: flex; flex-direction: column; gap: 6px;
}
.mode-card:hover { border-color: rgba(168,85,247,0.4); transform: translateY(-2px); background: rgba(168,85,247,0.07); }
.mode-card.active {
  border-color: var(--pu);
  background: linear-gradient(180deg, rgba(168,85,247,0.12), rgba(168,85,247,0.04));
  box-shadow: 0 0 0 1px var(--pu), 0 16px 40px -16px rgba(168,85,247,0.4);
}
.mode-icon { font-size: 1.6rem; margin-bottom: 6px; }
.mode-name { font-size: 1.05rem; font-weight: 600; letter-spacing: -0.01em; }
.mode-tag {
  font-family: 'Geist Mono', monospace;
  font-size: 0.65rem; letter-spacing: 0.12em;
  color: var(--pu2);
  text-transform: uppercase;
}
.mode-tease { font-size: 0.84rem; color: var(--txt2); line-height: 1.5; }
.mode-arrow {
  position: absolute; right: 18px; bottom: 16px;
  color: var(--pu2);
  font-size: 1.1rem;
  opacity: 0; transform: translateX(-4px);
  transition: all 0.2s;
}
.mode-card:hover .mode-arrow, .mode-card.active .mode-arrow { opacity: 1; transform: translateX(0); }

.mode-active-banner {
  margin-top: 20px;
  padding: 28px 30px;
  background: linear-gradient(135deg, rgba(168,85,247,0.1), rgba(99,57,200,0.05));
  border: 1px solid rgba(168,85,247,0.25);
  border-radius: 16px;
  display: flex; flex-direction: column; align-items: flex-start; gap: 10px;
}
.mab-eyebrow {
  font-family: 'Geist Mono', monospace; font-size: 0.66rem; letter-spacing: 0.2em;
  color: var(--pu2);
}
.mode-active-banner h3 { margin: 0; font-size: 1.4rem; font-weight: 600; }
.mode-active-banner p { margin: 0; color: var(--txt2); font-size: 0.95rem; line-height: 1.55; max-width: 600px; }
.mode-active-banner .lp-cta { margin-top: 6px; }

/* ── COACHING ── */
.any-coaching-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 900px) { .any-coaching-grid { grid-template-columns: 1fr; } }
.any-bullets { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.any-bullets li {
  position: relative;
  padding-left: 24px;
  font-size: 0.94rem; color: var(--txt2); line-height: 1.55;
}
.any-bullets li b { color: var(--pu2); font-weight: 600; }
.any-bullets li::before {
  content: ''; position: absolute; left: 0; top: 9px;
  width: 14px; height: 1px; background: var(--pu);
}

.coaching-mock {
  display: grid; grid-template-rows: 1fr auto 1fr;
  gap: 12px;
  background: rgba(11,6,18,0.5);
  border: 1px solid rgba(168,85,247,0.15);
  border-radius: 18px;
  padding: 24px;
}
.cm-doc {
  background: rgba(255,255,255,0.92);
  color: #1a0f2e;
  border-radius: 10px;
  padding: 16px;
}
.cm-doc-tag {
  font-family: 'Geist Mono', monospace;
  font-size: 0.65rem; letter-spacing: 0.18em;
  color: rgba(26,15,46,0.5);
  margin-bottom: 10px;
}
.cm-line { height: 4px; background: rgba(26,15,46,0.18); border-radius: 2px; margin-bottom: 7px; }
.cm-line.w70 { width: 70%; }
.cm-line.w90 { width: 90%; }
.cm-flag {
  margin: 12px 0;
  background: rgba(251,191,36,0.18);
  border: 1px solid rgba(251,191,36,0.4);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 0.8rem;
  display: flex; gap: 12px; align-items: center;
}
.cm-flag span:first-child { color: #92400e; font-weight: 600; }
.cmf-meta { color: rgba(26,15,46,0.7); font-family: 'Geist Mono', monospace; font-size: 0.72rem; }

.cm-arrow { font-size: 1.6rem; color: var(--pu2); text-align: center; }

.cm-question {
  background: rgba(168,85,247,0.08);
  border: 1px solid rgba(168,85,247,0.3);
  border-radius: 10px;
  padding: 16px 18px;
}
.cm-q-tag { font-family: 'Geist Mono', monospace; font-size: 0.65rem; letter-spacing: 0.18em; color: var(--pu2); margin-bottom: 8px; }
.cm-q-text { font-size: 0.94rem; color: var(--txt); line-height: 1.5; margin-bottom: 10px; font-style: italic; }
.cm-q-foot { display: flex; gap: 6px; flex-wrap: wrap; }
.cm-q-pill {
  font-family: 'Geist Mono', monospace; font-size: 0.62rem; letter-spacing: 0.1em;
  padding: 3px 8px;
  background: rgba(168,85,247,0.1);
  border: 1px solid rgba(168,85,247,0.3);
  border-radius: 4px;
  color: var(--pu2);
}

/* ── GAMIFY ── */
.any-gamify { background: linear-gradient(180deg, transparent, rgba(168,85,247,0.04), transparent); }
.gamify-row {
  display: grid; grid-template-columns: 1fr 1fr 1.4fr; gap: 16px;
  margin-top: 36px;
}
@media (max-width: 900px) { .gamify-row { grid-template-columns: 1fr; } }
.gamify-card {
  background: rgba(11,6,18,0.6);
  border: 1px solid rgba(168,85,247,0.18);
  border-radius: 16px;
  padding: 22px;
}
.gc-eyebrow {
  font-family: 'Geist Mono', monospace; font-size: 0.65rem; letter-spacing: 0.2em;
  color: var(--pu2); margin-bottom: 14px;
}
.gc-streak-num {
  font-size: 3.2rem; font-weight: 700; letter-spacing: -0.04em;
  color: var(--pu2);
  display: flex; align-items: baseline; gap: 8px;
  margin-bottom: 14px;
}
.gc-streak-num span { font-size: 0.9rem; font-weight: 400; color: var(--txt3); letter-spacing: 0.04em; }
.gc-streak-grid { display: grid; grid-template-columns: repeat(15, 1fr); gap: 4px; margin-bottom: 12px; }
.gcs-cell { aspect-ratio: 1; background: rgba(255,255,255,0.05); border-radius: 3px; }
.gcs-on { background: linear-gradient(135deg, var(--pu), #c084fc); box-shadow: 0 0 4px rgba(168,85,247,0.5); }
.gcs-today { background: rgba(168,85,247,0.4); border: 1px solid var(--pu); animation: blink 2s infinite; }
.gc-streak-foot { font-size: 0.82rem; color: var(--txt2); }
.gc-streak-foot b { color: var(--pu2); font-weight: 600; }

.gc-level { font-size: 1.4rem; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 10px; }
.gc-level span { font-size: 0.84rem; font-weight: 400; color: var(--pu2); margin-left: 8px; }
.gc-xp-bar { height: 10px; background: rgba(255,255,255,0.06); border-radius: 5px; overflow: hidden; margin-bottom: 8px; }
.gc-xp-fill { height: 100%; background: linear-gradient(90deg, var(--pu), #c084fc, #e9d5ff); border-radius: 5px; box-shadow: 0 0 12px rgba(168,85,247,0.5); }
.gc-xp-meta { font-family: 'Geist Mono', monospace; font-size: 0.72rem; color: var(--txt3); margin-bottom: 14px; }
.gc-xp-meta b { color: var(--txt); }
.gc-rewards { display: flex; flex-wrap: wrap; gap: 6px; }
.gc-rewards span {
  font-family: 'Geist Mono', monospace; font-size: 0.66rem;
  padding: 4px 8px;
  background: rgba(168,85,247,0.08);
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 4px;
  color: var(--pu2);
}

.gc-badge-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 14px; }
.gc-badge {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 10px 6px;
  border-radius: 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  transition: transform 0.2s;
}
.gc-badge:hover { transform: translateY(-2px); }
.gcb-icon { font-size: 1.5rem; }
.gcb-name { font-size: 0.7rem; font-weight: 500; text-align: center; }
.gcb-rarity {
  font-family: 'Geist Mono', monospace; font-size: 0.55rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--txt3);
}
.gc-badge-common    { border-color: rgba(156,163,175,0.3); }
.gc-badge-rare      { border-color: rgba(96,165,250,0.4); background: rgba(96,165,250,0.06); }
.gc-badge-rare .gcb-rarity { color: #60a5fa; }
.gc-badge-epic      { border-color: rgba(168,85,247,0.5); background: rgba(168,85,247,0.08); box-shadow: 0 0 12px rgba(168,85,247,0.15); }
.gc-badge-epic .gcb-rarity { color: var(--pu2); }
.gc-badge-legendary { border-color: rgba(251,191,36,0.5); background: rgba(251,191,36,0.08); box-shadow: 0 0 18px rgba(251,191,36,0.18); }
.gc-badge-legendary .gcb-rarity { color: #fbbf24; }
.gc-badge-locked { opacity: 0.42; filter: grayscale(0.7); }

.gc-leaderboard-cta {
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.06);
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.84rem; color: var(--txt2);
}
.gc-leaderboard-cta a { color: var(--pu2); font-weight: 500; }

/* ── SCORECARD ── */
.any-scorecard-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 900px) { .any-scorecard-grid { grid-template-columns: 1fr; } }
.inline-code {
  font-family: 'Geist Mono', monospace; font-size: 0.86rem;
  padding: 2px 8px;
  background: rgba(168,85,247,0.1);
  border-radius: 4px;
  color: var(--pu2);
}
.scorecard-mock { position: relative; }
.scm-url {
  font-family: 'Geist Mono', monospace; font-size: 0.78rem;
  background: rgba(11,6,18,0.85);
  border: 1px solid rgba(168,85,247,0.25);
  border-radius: 10px 10px 0 0;
  padding: 8px 14px;
  color: var(--pu2);
}
.scm-card {
  background: linear-gradient(180deg, rgba(168,85,247,0.06), rgba(11,6,18,0.85));
  border: 1px solid rgba(168,85,247,0.25);
  border-top: none;
  border-radius: 0 0 16px 16px;
  padding: 24px;
}
.scm-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 22px; }
.scm-name { font-size: 1.05rem; font-weight: 600; }
.scm-role { font-size: 0.82rem; color: var(--txt3); margin-top: 2px; }
.scm-score { text-align: right; }
.scm-score-n { font-size: 2.6rem; font-weight: 700; letter-spacing: -0.04em; color: var(--pu2); line-height: 1; }
.scm-score-meta { font-family: 'Geist Mono', monospace; font-size: 0.72rem; color: #34d399; margin-top: 2px; }
.scm-rubric { display: flex; flex-direction: column; gap: 9px; padding: 16px 0; border-top: 1px solid rgba(168,85,247,0.15); border-bottom: 1px solid rgba(168,85,247,0.15); margin-bottom: 16px; }
.scm-r { display: grid; grid-template-columns: 130px 1fr 30px; align-items: center; gap: 10px; font-size: 0.8rem; color: var(--txt2); }
.scm-r-bar { height: 5px; background: rgba(255,255,255,0.07); border-radius: 3px; overflow: hidden; }
.scm-r-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--pu), #c084fc); }
.scm-r b { color: var(--txt); font-family: 'Geist Mono', monospace; text-align: right; }
.scm-foot { display: flex; gap: 14px; font-size: 0.78rem; color: var(--txt3); flex-wrap: wrap; }

/* ── PRICING ── */
.any-pricing-section { background: linear-gradient(180deg, transparent, rgba(168,85,247,0.04), transparent); }
.pricing-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 36px; }
@media (max-width: 1100px) { .pricing-grid { grid-template-columns: repeat(2, 1fr); } }
.price-card {
  position: relative;
  background: rgba(11,6,18,0.5);
  border: 1px solid rgba(168,85,247,0.15);
  border-radius: 16px;
  padding: 26px 22px;
  display: flex; flex-direction: column; gap: 14px;
  transition: all 0.25s ease;
}
.price-card:hover { transform: translateY(-3px); border-color: rgba(168,85,247,0.35); }
.pc-featured {
  border-color: var(--pu);
  background: linear-gradient(180deg, rgba(168,85,247,0.12), rgba(168,85,247,0.04));
  box-shadow: 0 0 0 1px var(--pu), 0 24px 60px -20px rgba(168,85,247,0.5);
  transform: scale(1.02);
}
.pc-bootcamp {
  border-color: rgba(251,191,36,0.4);
  background: linear-gradient(180deg, rgba(251,191,36,0.06), rgba(11,6,18,0.5));
}
.pc-badge {
  position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
  font-family: 'Geist Mono', monospace; font-size: 0.62rem; letter-spacing: 0.18em;
  background: var(--pu); color: #fff;
  padding: 4px 12px;
  border-radius: 999px;
  white-space: nowrap;
}
.pc-name { font-size: 1.05rem; font-weight: 600; }
.pc-price { font-size: 2.4rem; font-weight: 700; letter-spacing: -0.03em; }
.pc-price span { font-size: 0.8rem; font-weight: 400; color: var(--txt3); margin-left: 6px; letter-spacing: 0; }
.pc-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.pc-list li { font-size: 0.86rem; color: var(--txt2); padding-left: 18px; position: relative; }
.pc-list li::before { content: '✓'; position: absolute; left: 0; color: var(--pu2); }
.pc-list li b { color: var(--txt); }
.pc-cta {
  text-align: center; padding: 11px 14px;
  border-radius: 10px;
  border: 1px solid rgba(168,85,247,0.3);
  color: var(--txt);
  font-weight: 500; font-size: 0.9rem;
  text-decoration: none;
  transition: all 0.2s;
}
.pc-cta:hover { background: rgba(168,85,247,0.1); border-color: var(--pu); }
.pc-cta-strong { background: var(--pu); color: #fff; border-color: var(--pu); }
.pc-cta-strong:hover { background: #9333ea; box-shadow: 0 8px 24px rgba(168,85,247,0.4); }

.pricing-bundles {
  margin-top: 24px;
  display: flex; gap: 12px; align-items: center; justify-content: center;
  font-family: 'Geist Mono', monospace; font-size: 0.82rem;
  color: var(--txt2);
}
.pb-eyebrow { font-size: 0.66rem; letter-spacing: 0.2em; color: var(--txt3); margin-right: 8px; }
.pricing-bundles b { color: var(--pu2); }
.pb-sep { opacity: 0.4; }

/* ── REFERRAL ── */
.any-referral { padding-bottom: 60px; }
.referral-card {
  background: linear-gradient(135deg, rgba(168,85,247,0.12), rgba(99,57,200,0.06));
  border: 1px solid rgba(168,85,247,0.25);
  border-radius: 20px;
  padding: 40px 48px;
  display: grid; grid-template-columns: 1.3fr 1fr; gap: 32px;
  align-items: center;
  position: relative; overflow: hidden;
}
@media (max-width: 800px) { .referral-card { grid-template-columns: 1fr; } }
.referral-code {
  margin-top: 24px;
  display: flex; align-items: center; gap: 10px;
  font-family: 'Geist Mono', monospace;
}
.referral-code > span:first-child { font-size: 0.66rem; letter-spacing: 0.2em; color: var(--txt3); }
.referral-code code {
  font-size: 1.2rem; font-weight: 600;
  background: rgba(168,85,247,0.15);
  border: 1px solid rgba(168,85,247,0.4);
  padding: 8px 14px;
  border-radius: 8px;
  color: var(--pu2);
  letter-spacing: 0.05em;
}
.rc-copy {
  background: var(--pu); color: #fff;
  border: none; border-radius: 8px;
  padding: 10px 16px; font-size: 0.84rem; font-weight: 500;
  cursor: pointer;
}
.rc-copy:hover { background: #9333ea; }
.referral-orb { position: relative; height: 160px; }
.ro-core, .ro-r1, .ro-r2 {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%);
  border-radius: 50%;
}
.ro-core { width: 70px; height: 70px; background: radial-gradient(circle at 30% 30%, #e9d5ff, #a855f7 50%, #6d28d9); box-shadow: 0 0 40px rgba(168,85,247,0.6); animation: orbPulse 3s ease-in-out infinite; }
.ro-r1 { width: 120px; height: 120px; border: 1px solid rgba(168,85,247,0.3); animation: orbPulse 4s ease-in-out infinite 0.4s; }
.ro-r2 { width: 170px; height: 170px; border: 1px solid rgba(168,85,247,0.18); animation: orbPulse 5s ease-in-out infinite 0.8s; }

/* ── FINAL ── */
.any-final-v2 {
  position: relative;
  text-align: center;
  padding: 110px 56px 90px;
  overflow: hidden;
}
.afv-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 50%, rgba(168,85,247,0.22), transparent 70%),
    radial-gradient(ellipse 100% 60% at 50% 100%, rgba(99,57,200,0.15), transparent 70%);
  z-index: 0;
}
.any-final-h, .any-final-sub, .any-final-ctas, .afv-trust { position: relative; z-index: 2; }
.any-final-h {
  font-size: clamp(2.2rem, 4.4vw, 3.6rem);
  font-weight: 700; letter-spacing: -0.03em; line-height: 1.05;
  max-width: 880px; margin: 0 auto 16px;
  text-wrap: balance;
}
.any-final-h em { font-style: normal; color: var(--pu2); text-shadow: 0 0 36px rgba(168,85,247,0.5); }
.any-final-sub { font-size: 1.05rem; color: var(--txt2); margin: 0 auto 28px; }
.any-final-ctas { display: flex; gap: 14px; justify-content: center; align-items: center; margin-bottom: 28px; }
.any-final-ctas .lp-cta svg { width: 16px; height: 16px; margin-left: 6px; }
.afv-trust {
  font-family: 'Geist Mono', monospace; font-size: 0.78rem;
  color: var(--txt3);
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
}
.afv-trust b { color: var(--pu2); }
.afv-sep { opacity: 0.4; }

@media (max-width: 900px) {
  .any-hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .any-hero-right { height: 460px; }
  .any-live-panel { right: 0; left: 0; margin: 0 auto; }
}


/* ─────────────────────────────────────────────────────
   ANYTIME V3 — B2C conversion overhaul + bokeh
   ───────────────────────────────────────────────────── */

#bokeh { position: fixed; inset: 0; z-index: 0; pointer-events: none; }
.anytime-v3 { position: relative; }
.anytime-v3 > nav,
.anytime-v3 > section,
.anytime-v3 > footer,
.anytime-v3 > .any-risk-banner { position: relative; z-index: 2; }

/* Reset hero v3 to be transparent so bokeh shows */
.anytime-v3 .any-hero-v3 {
  background: linear-gradient(180deg, transparent 0%, rgba(8,4,15,0.5) 100%);
  padding-top: 160px;
}
.anytime-v3 .any-hero-v3 .any-hero-bg-stars { display: none; }

.anytime-v3 .any-section-v2 {
  background: rgba(8,4,15,0.55);
  backdrop-filter: blur(2px);
}
.anytime-v3 .any-final-v2 {
  background: linear-gradient(180deg, rgba(8,4,15,0.55), rgba(8,4,15,0.85));
}
.anytime-v3 .lp-footer { position: relative; z-index: 2; background: rgba(8,4,15,0.8); }

/* ── sticky risk banner ── */
.any-risk-banner {
  position: relative;
  display: flex; justify-content: center; align-items: center; gap: 10px;
  padding: 10px 24px;
  background: linear-gradient(90deg, rgba(34,197,94,0.18), rgba(168,85,247,0.18), rgba(34,197,94,0.18));
  border-bottom: 1px solid rgba(168,85,247,0.18);
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.74rem; letter-spacing: 0.06em;
  color: #d8b4fe;
  z-index: 50;
}
.arb-pulse {
  width: 7px; height: 7px; border-radius: 50%;
  background: #34d399; box-shadow: 0 0 10px #34d399;
  animation: blink 1.4s infinite;
}

/* ── nav v3 ── */
.any-nav-v3 {
  background: rgba(8,4,15,0.85) !important;
  backdrop-filter: blur(24px);
}

/* ── XL CTA ── */
.any-cta-xl {
  padding: 16px 30px !important;
  font-size: 1rem !important;
  box-shadow: 0 16px 50px -12px rgba(168,85,247,0.55) !important;
  font-weight: 700 !important;
}
.any-cta-xl:hover { transform: translateY(-2px); box-shadow: 0 22px 60px -12px rgba(168,85,247,0.7) !important; }

/* ── HERO STAT STRIP ── */
.any-hero-stats {
  position: relative; z-index: 2;
  margin: 80px auto 0;
  max-width: 1180px;
  display: grid; grid-template-columns: repeat(4, 1fr);
  background: rgba(11,6,18,0.55);
  border: 1px solid rgba(168,85,247,0.18);
  border-radius: 18px;
  overflow: hidden;
  backdrop-filter: blur(8px);
}
.ahs-cell {
  padding: 22px 18px;
  text-align: center;
  border-right: 1px solid rgba(255,255,255,0.05);
}
.ahs-cell:last-child { border-right: none; }
.ahs-n {
  font-size: 1.7rem; font-weight: 700; letter-spacing: -0.03em;
  color: var(--pu2);
  text-shadow: 0 0 18px rgba(168,85,247,0.4);
  margin-bottom: 4px;
}
.ahs-l { font-size: 0.78rem; color: var(--txt3); letter-spacing: 0.02em; }
@media (max-width: 800px) { .any-hero-stats { grid-template-columns: repeat(2, 1fr); } .ahs-cell:nth-child(2) { border-right: none; } }

/* ── PAIN AGITATION ── */
.any-pain { padding-top: 120px; padding-bottom: 96px; }
.pain-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: rgba(255,255,255,0.04);
  border-radius: 16px; overflow: hidden;
  margin-top: 36px; margin-bottom: 22px;
}
@media (max-width: 800px) { .pain-grid { grid-template-columns: 1fr; } }
.pain-card {
  padding: 32px 28px;
  background: rgba(11,6,18,0.7);
  transition: background 0.25s;
}
.pain-card:hover { background: rgba(168,85,247,0.05); }
.pain-em { font-size: 1.7rem; margin-bottom: 14px; }
.pain-card h3 { font-size: 1rem; font-weight: 600; margin: 0 0 8px; letter-spacing: -0.01em; }
.pain-card p { margin: 0; font-size: 0.86rem; color: var(--txt2); line-height: 1.6; }
.pain-card p em { font-style: italic; color: var(--pu2); }

.pain-truth {
  padding: 36px 38px;
  background: rgba(168,85,247,0.04);
  border: 1px solid rgba(168,85,247,0.14);
  border-radius: 16px;
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 36px;
  align-items: center;
}
@media (max-width: 800px) { .pain-truth { grid-template-columns: 1fr; gap: 24px; } }
.pain-truth-q {
  font-size: clamp(1.1rem, 2.2vw, 1.5rem);
  font-weight: 600;
  line-height: 1.35; letter-spacing: -0.015em;
  text-wrap: balance;
}
.pain-truth-q em { font-style: normal; color: var(--pu2); text-shadow: 0 0 16px rgba(168,85,247,0.3); }
.pain-truth-stats { display: flex; flex-direction: column; gap: 10px; }
.ptt-row {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 16px;
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(168,85,247,0.1);
  border-radius: 10px;
}
.ptt-n {
  font-size: 1.4rem; font-weight: 700; letter-spacing: -0.03em;
  color: var(--pu2); text-shadow: 0 0 12px rgba(168,85,247,0.3);
  min-width: 60px;
}
.ptt-l { font-size: 0.84rem; color: var(--txt2); line-height: 1.4; }
.ptt-l b { color: var(--txt); font-weight: 600; }

/* ── HOW (4-step) ── */
.any-how { padding: 96px 56px; }
.how-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: rgba(255,255,255,0.04);
  border-radius: 16px; overflow: hidden;
  margin-top: 36px;
}
@media (max-width: 800px) { .how-grid { grid-template-columns: repeat(2, 1fr); } }
.how-card {
  padding: 28px 22px;
  background: rgba(11,6,18,0.7);
  transition: background 0.25s;
}
.how-card:hover { background: rgba(168,85,247,0.05); }
.how-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(168,85,247,0.08);
  border: 1px solid rgba(168,85,247,0.25);
  color: var(--pu2);
  font-family: 'Geist Mono', monospace; font-size: 0.78rem; font-weight: 700;
  margin-bottom: 16px;
}
.how-final .how-num {
  background: var(--pu); color: #fff;
  border-color: var(--pu);
  box-shadow: 0 0 20px rgba(168,85,247,0.45);
}
.how-card h4 { font-size: 0.95rem; font-weight: 600; margin: 0 0 6px; letter-spacing: -0.01em; }
.how-card p { margin: 0; font-size: 0.82rem; color: var(--txt2); line-height: 1.55; }

/* ── DEMO TABS ── */
.any-demo { padding: 96px 56px; }
.demo-tabs {
  display: inline-flex; gap: 4px;
  background: rgba(0,0,0,0.4);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 100px; padding: 4px;
  margin-top: 28px; margin-bottom: 24px;
}
.demo-tab {
  padding: 9px 20px;
  border: none; background: transparent;
  border-radius: 100px;
  font-family: inherit; font-size: 0.84rem; font-weight: 500;
  color: var(--txt3); cursor: pointer;
  transition: all 0.2s;
}
.demo-tab:hover { color: var(--txt); }
.demo-tab.on {
  background: rgba(168,85,247,0.15);
  border: 1px solid rgba(168,85,247,0.35);
  color: var(--pu2);
  text-shadow: 0 0 8px rgba(168,85,247,0.4);
}
.demo-frame {
  background: rgba(8,4,15,0.85);
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 18px;
  padding: 28px;
  min-height: 440px;
  box-shadow: 0 30px 80px -30px rgba(168,85,247,0.3);
}
.demo-panel {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 24px;
  align-items: center;
}
@media (max-width: 800px) { .demo-panel { grid-template-columns: 1fr; } }
.demo-orb-pane {
  background: radial-gradient(circle at 50% 50%, rgba(168,85,247,0.18), transparent 70%);
  border-radius: 14px;
  padding: 30px;
  display: flex; flex-direction: column; align-items: center; gap: 18px;
  min-height: 280px;
  justify-content: center;
}
.demo-orb { position: relative; width: 130px; height: 130px; }
.do-core {
  position: absolute; inset: 25px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #e9d5ff, #a855f7 50%, #6d28d9);
  box-shadow: 0 0 50px rgba(168,85,247,0.6);
  animation: orbPulse 2s ease-in-out infinite;
}
.do-r {
  position: absolute; inset: 0;
  border-radius: 50%;
  border: 1.5px solid rgba(168,85,247,0.4);
  animation: ringOut 2.4s linear infinite;
}
.do-r.r2 { animation-delay: 1.2s; }
.demo-cap {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Geist Mono', monospace; font-size: 0.78rem;
  color: var(--pu2);
  letter-spacing: 0.04em;
}
.demo-msgs { display: flex; flex-direction: column; gap: 10px; }
.dmsg {
  padding: 12px 16px;
  border-radius: 10px;
  background: rgba(255,255,255,0.04);
  font-size: 0.86rem; line-height: 1.55;
  color: var(--txt2);
  border-left: 2px solid rgba(255,255,255,0.1);
}
.dmsg.ai { border-left-color: var(--pu); }
.dmsg.coach { border-left-color: #34d399; background: rgba(52,211,153,0.06); color: var(--txt); }
.dmsg-who {
  font-family: 'Geist Mono', monospace;
  font-size: 0.62rem; font-weight: 600; letter-spacing: 0.14em;
  margin-bottom: 4px; text-transform: uppercase;
  color: var(--txt3);
}
.dmsg.ai .dmsg-who { color: var(--pu2); }
.dmsg.coach .dmsg-who { color: #6ee7b7; }
.dmsg-cursor { color: var(--pu); animation: blink 0.9s infinite; }

.demo-score { display: flex; flex-direction: column; gap: 18px; grid-template-columns: none; }
.ds-head { display: flex; justify-content: space-between; align-items: center; }
.ds-job { font-size: 1.05rem; font-weight: 600; }
.ds-meta { font-family: 'Geist Mono', monospace; font-size: 0.74rem; color: var(--txt3); margin-top: 4px; }
.ds-score { text-align: right; }
.ds-score-n {
  font-size: 3.2rem; font-weight: 700; letter-spacing: -0.04em;
  color: var(--pu2); line-height: 1;
  text-shadow: 0 0 20px rgba(168,85,247,0.3);
}
.ds-score-tag { font-family: 'Geist Mono', monospace; font-size: 0.74rem; color: #34d399; margin-top: 2px; }
.ds-rubric {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 24px;
  padding: 20px 0;
  border-top: 1px solid rgba(168,85,247,0.15);
  border-bottom: 1px solid rgba(168,85,247,0.15);
}
.ds-r { display: grid; grid-template-columns: 130px 1fr 30px; gap: 12px; align-items: center; font-size: 0.82rem; color: var(--txt2); }
.ds-r-bar { height: 5px; background: rgba(255,255,255,0.07); border-radius: 3px; overflow: hidden; }
.ds-r-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--pu), #c084fc); }
.ds-r b { font-family: 'Geist Mono', monospace; color: var(--txt); text-align: right; }
.ds-share {
  display: flex; align-items: center; gap: 12px;
  font-family: 'Geist Mono', monospace; font-size: 0.82rem;
}
.ds-share code {
  padding: 6px 12px;
  background: rgba(168,85,247,0.1);
  border: 1px solid rgba(168,85,247,0.3);
  border-radius: 6px;
  color: var(--pu2);
}
.ds-share span { color: var(--txt3); font-size: 0.74rem; }

.demo-drill { display: flex; flex-direction: column; gap: 12px; grid-template-columns: none; }
.dd-h { font-family: 'Geist Mono', monospace; font-size: 0.74rem; letter-spacing: 0.14em; color: var(--pu2); margin-bottom: 6px; }
.dd-row {
  display: grid; grid-template-columns: 50px 1fr auto; gap: 16px; align-items: center;
  padding: 16px 18px;
  background: rgba(168,85,247,0.04);
  border: 1px solid rgba(168,85,247,0.15);
  border-radius: 12px;
}
.dd-n {
  font-family: 'Geist Mono', monospace; font-weight: 700;
  font-size: 1.2rem; color: var(--pu2);
}
.dd-t { font-size: 0.95rem; font-weight: 600; margin-bottom: 4px; }
.dd-d { font-size: 0.84rem; color: var(--txt2); line-height: 1.5; }
.dd-tag {
  font-family: 'Geist Mono', monospace; font-size: 0.62rem;
  letter-spacing: 0.14em;
  padding: 4px 10px;
  background: rgba(168,85,247,0.1);
  border: 1px solid rgba(168,85,247,0.3);
  border-radius: 4px;
  color: var(--pu2);
}

/* ── PROOF / TESTIMONIALS ── */
.any-proof { padding: 96px 56px; }
.testi-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin-top: 36px;
}
@media (max-width: 900px) { .testi-grid { grid-template-columns: 1fr; } }
.testi-card {
  padding: 26px 24px;
  background: rgba(11,6,18,0.7);
  border: 1px solid rgba(168,85,247,0.16);
  border-radius: 16px;
  display: flex; flex-direction: column; gap: 18px;
  transition: all 0.25s;
}
.testi-card:hover {
  transform: translateY(-3px);
  border-color: rgba(168,85,247,0.36);
  box-shadow: 0 18px 50px -16px rgba(168,85,247,0.25);
}
.testi-flag {
  display: inline-flex; align-items: center; gap: 8px;
  align-self: flex-start;
  padding: 5px 12px;
  background: rgba(52,211,153,0.1);
  border: 1px solid rgba(52,211,153,0.3);
  border-radius: 100px;
  font-family: 'Geist Mono', monospace; font-size: 0.74rem; letter-spacing: 0.06em;
  color: #6ee7b7;
}
.testi-flag span { color: #6ee7b7; }
.testi-quote {
  margin: 0; flex: 1;
  font-size: 0.94rem; line-height: 1.6;
  color: var(--txt);
  text-wrap: pretty;
}
.testi-foot { display: flex; align-items: center; gap: 12px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,0.06); }
.testi-avatar {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--pu), #c084fc);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 0.84rem;
  color: #fff;
}
.testi-name { font-size: 0.92rem; font-weight: 600; }
.testi-meta { font-size: 0.78rem; color: var(--txt3); margin-top: 1px; }

.proof-logos { margin-top: 40px; padding-top: 32px; border-top: 1px solid rgba(255,255,255,0.06); text-align: center; }
.pl-eyebrow {
  font-family: 'Geist Mono', monospace; font-size: 0.7rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--txt3); margin-bottom: 18px;
}
.pl-row {
  display: flex; flex-wrap: wrap; gap: 32px; justify-content: center;
  font-family: 'Geist', sans-serif;
  font-size: 1rem; font-weight: 600; letter-spacing: -0.01em;
  color: var(--txt2);
  opacity: 0.75;
}
.pl-row span { transition: color 0.2s, opacity 0.2s; }
.pl-row span:hover { color: var(--txt); opacity: 1; }

/* ── RISK ROW (under pricing) ── */
.risk-row {
  margin-top: 36px;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
}
@media (max-width: 800px) { .risk-row { grid-template-columns: repeat(2, 1fr); } }
.risk-item {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 18px 14px;
  background: rgba(168,85,247,0.04);
  border: 1px solid rgba(168,85,247,0.15);
  border-radius: 12px;
  text-align: center;
}
.risk-item > span:first-child { font-size: 1.4rem; margin-bottom: 4px; }
.risk-item b { font-size: 0.86rem; font-weight: 600; color: var(--txt); }
.risk-item > span:last-child { font-size: 0.74rem; color: var(--txt3); }

/* ── FAQ ── */
.any-faq { padding: 96px 56px; }
.faq-list {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: 36px;
  max-width: 880px;
}
.faq-row {
  width: 100%;
  text-align: left;
  background: rgba(11,6,18,0.6);
  border: 1px solid rgba(168,85,247,0.14);
  border-radius: 12px;
  padding: 18px 22px;
  cursor: pointer;
  font-family: inherit;
  color: var(--txt);
  transition: all 0.2s;
}
.faq-row:hover { border-color: rgba(168,85,247,0.3); }
.faq-row.open { border-color: rgba(168,85,247,0.4); background: rgba(168,85,247,0.04); }
.faq-q {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.95rem; font-weight: 500;
  letter-spacing: -0.005em;
}
.faq-toggle {
  font-size: 1.4rem; font-weight: 300;
  color: var(--pu2);
  margin-left: 16px;
}
.faq-a {
  margin-top: 12px;
  font-size: 0.88rem; line-height: 1.65;
  color: var(--txt2);
  text-wrap: pretty;
}

/* ── final cta refinements ── */
.afv-fineprint {
  position: relative; z-index: 2;
  margin-top: 14px;
  font-family: 'Geist Mono', monospace; font-size: 0.7rem;
  color: var(--txt3); letter-spacing: 0.04em;
}

/* keep purple v3 hero readable on bokeh */
.anytime-v3 .any-h1-v2 em {
  text-shadow: 0 0 50px rgba(168,85,247,0.5), 0 0 100px rgba(168,85,247,0.18);
}

/* ════════════════════════════════════════════════════════════════════════
   ANYTIME · v4 — credentialed-advocate redesign
   ════════════════════════════════════════════════════════════════════════ */

/* ── video / photo placeholders ─────────────────────────────────────────── */
.vid-ph {
  position: relative;
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  background: linear-gradient(135deg, #1a0f2e 0%, #0a0612 60%, #1a0820 100%);
  border: 1px solid rgba(168,85,247,0.22);
  box-shadow: 0 28px 70px -20px rgba(0,0,0,0.55), inset 0 1px 0 rgba(168,85,247,0.18);
  isolation: isolate;
}
/* Live mode — VideoPlaceholder rendering an actual <video> instead of a placeholder. */
.vid-ph.vid-ph-live { background: #07060d; }
.vid-ph.vid-ph-live > video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.vid-ph-purple {
  background: linear-gradient(135deg, #2a1450 0%, #160726 50%, #2a0e3e 100%);
  border-color: rgba(192,132,252,0.35);
}
.vid-ph-dim {
  background: linear-gradient(135deg, #14091e 0%, #0a0612 100%);
  border-color: rgba(255,255,255,0.06);
}
.vid-ph-stripes {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(
    135deg,
    rgba(168,85,247,0.05) 0 12px,
    transparent 12px 24px
  );
  pointer-events: none;
}
.vid-ph-frame {
  position: relative;
  width: 100%; height: 100%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px;
  text-align: center;
  padding: 24px;
}
.vid-ph-play {
  width: 56px; height: 56px;
  fill: rgba(168,85,247,0.18);
  stroke: rgba(218,180,255,0.85);
  stroke-width: 1.5;
  filter: drop-shadow(0 0 18px rgba(168,85,247,0.45));
}
.vid-ph-play path { fill: rgba(218,180,255,0.95); stroke: none; }
.vid-ph-label {
  font-family: 'Geist Mono', monospace;
  font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(218,180,255,0.85);
}
.vid-ph-sub {
  font-size: 0.78rem; color: var(--txt3); max-width: 22ch;
  line-height: 1.45;
}
.vid-ph-dim .vid-ph-play {
  fill: rgba(255,255,255,0.06);
  stroke: rgba(255,255,255,0.45);
  filter: none;
}
.vid-ph-dim .vid-ph-play path { fill: rgba(255,255,255,0.7); }
.vid-ph-dim .vid-ph-label { color: rgba(255,255,255,0.65); }

.photo-ph {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, #3a1e6b, #1a0a30);
  border: 1px solid rgba(168,85,247,0.4);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Geist Mono', monospace;
  font-size: 0.85rem; letter-spacing: 0.08em;
  color: rgba(218,180,255,0.95);
  font-weight: 600;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.06);
}
.photo-ph-purple {
  background: linear-gradient(135deg, #4a2a8a, #20103d);
}

/* ── HERO v4 ────────────────────────────────────────────────────────────── */
.any-hero-v4 .any-hero-grid {
  grid-template-columns: 1.05fr 0.95fr;
  gap: 64px;
  align-items: center;
}
.any-hero-right-v4 {
  position: relative;
  display: flex; align-items: center; justify-content: center;
  height: auto; min-height: 480px;
}
.hero-demo {
  width: 320px;
  display: flex; flex-direction: column; gap: 12px;
  align-items: center;
}
.hero-demo .vid-ph { width: 100%; }
.hero-demo-cap {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  background: rgba(168,85,247,0.08);
  border: 1px solid rgba(168,85,247,0.22);
  border-radius: 999px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.06em; color: var(--txt2);
}
.hd-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--pu); box-shadow: 0 0 8px var(--pu);
  animation: blink 2s infinite;
}

@media (max-width: 980px) {
  .any-hero-v4 .any-hero-grid { grid-template-columns: 1fr; gap: 36px; }
  .any-hero-right-v4 { min-height: 0; }
  .hero-demo { width: 260px; }
}

/* ── TRUST BAR ──────────────────────────────────────────────────────────── */
.trust-bar {
  position: relative;
  padding: 28px 56px;
  background:
    linear-gradient(180deg, rgba(168,85,247,0.06), rgba(168,85,247,0.02)),
    rgba(8,4,15,0.55);
  border-top: 1px solid rgba(168,85,247,0.18);
  border-bottom: 1px solid rgba(168,85,247,0.18);
  backdrop-filter: blur(8px);
}
.trust-row {
  display: grid;
  grid-template-columns: 1.1fr repeat(4, 1fr) 1.1fr;
  gap: 18px;
  align-items: center;
}
.trust-cell {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 12px;
  border-right: 1px solid rgba(168,85,247,0.10);
}
.trust-cell:last-child { border-right: none; }
.trust-cell .photo-ph { width: 44px; height: 44px; font-size: 0.72rem; }
.tc-eyebrow {
  font-family: 'Geist Mono', monospace;
  font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--pu2); margin-bottom: 4px;
}
.tc-line { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.tc-line b {
  font-size: 0.82rem; font-weight: 600; color: var(--txt);
  line-height: 1.25; letter-spacing: -0.005em;
}
.tc-line span {
  font-size: 0.72rem; color: var(--txt3); line-height: 1.35;
  letter-spacing: 0.01em;
}
.trust-cite { padding-left: 0; }
.trust-stat { padding-right: 0; }

@media (max-width: 1100px) {
  .trust-row { grid-template-columns: repeat(3, 1fr); }
  .trust-cell { border-right: none; }
}
@media (max-width: 600px) {
  .trust-row { grid-template-columns: 1fr 1fr; }
}

/* ── PROBLEM ────────────────────────────────────────────────────────────── */
.any-problem { padding: 96px 56px; }
.any-problem .any-h2-v2 { max-width: 24ch; }
.any-problem-sub { max-width: 64ch; font-size: 1.1rem; line-height: 1.6; }

/* ── DIFF #1 — real questions / real schools ───────────────────────────── */
.diff-one { padding: 96px 56px; }
.diff-one-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  margin-top: 40px;
  margin-bottom: 40px;
  background: rgba(168,85,247,0.18);
  border: 1px solid rgba(168,85,247,0.18);
  border-radius: 18px;
  overflow: hidden;
}
.d1-stat {
  background: rgba(8,4,15,0.86);
  padding: 28px 24px;
  display: flex; flex-direction: column; gap: 6px;
}
.d1-n {
  font-family: 'Geist Mono', monospace;
  font-size: 2.6rem; font-weight: 700;
  color: var(--pu2);
  letter-spacing: -0.02em;
  line-height: 1;
  text-shadow: 0 0 40px rgba(168,85,247,0.4);
  margin-bottom: 4px;
}
.d1-l {
  font-size: 0.95rem; font-weight: 600; color: var(--txt);
  letter-spacing: -0.01em;
}
.d1-s {
  font-size: 0.78rem; color: var(--txt3); line-height: 1.55;
  text-wrap: pretty;
}
.d1-quote {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 20px; align-items: center;
  padding: 28px 32px;
  background:
    linear-gradient(135deg, rgba(168,85,247,0.10), rgba(168,85,247,0.03));
  border: 1px solid rgba(168,85,247,0.22);
  border-radius: 16px;
}
.d1-quote .photo-ph { width: 64px; height: 64px; font-size: 0.92rem; }
.d1-quote p {
  font-size: 1.1rem; line-height: 1.5;
  color: var(--txt); font-weight: 500;
  font-style: italic;
  text-wrap: pretty;
  margin-bottom: 8px;
}
.d1-quote footer {
  font-family: 'Geist Mono', monospace;
  font-size: 0.72rem; letter-spacing: 0.08em;
  color: var(--pu2); text-transform: uppercase;
}

@media (max-width: 980px) {
  .diff-one-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ── HOW-3 ──────────────────────────────────────────────────────────────── */
.how-3 { padding: 96px 56px; }
.how-3-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 40px;
}
.how-3-card {
  background: rgba(8,4,15,0.7);
  border: 1px solid rgba(168,85,247,0.16);
  border-radius: 16px;
  padding: 28px 24px 20px;
  display: flex; flex-direction: column; gap: 14px;
}
.how-3-num {
  font-family: 'Geist Mono', monospace;
  font-size: 0.78rem; letter-spacing: 0.18em;
  color: var(--pu2); font-weight: 600;
}
.how-3-card h4 {
  font-size: 1.15rem; font-weight: 600; line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--txt);
}
.how-3-card p {
  font-size: 0.9rem; line-height: 1.55; color: var(--txt2);
  text-wrap: pretty;
  margin-bottom: 4px;
}
.how-3-card .vid-ph { margin-top: auto; }

@media (max-width: 900px) {
  .how-3-grid { grid-template-columns: 1fr; }
}

/* ── DIFF #2 — interview families ───────────────────────────────────────── */
.diff-two { padding: 96px 56px; }
.fam-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 40px;
}
.fam-card {
  background: rgba(8,4,15,0.78);
  border: 1px solid rgba(168,85,247,0.18);
  border-radius: 14px;
  padding: 22px 20px 18px;
  display: flex; flex-direction: column; gap: 10px;
  transition: border-color 180ms ease, transform 180ms ease;
}
.fam-card:hover {
  border-color: rgba(168,85,247,0.4);
  transform: translateY(-2px);
}
.fam-icon {
  font-size: 1.4rem; line-height: 1;
}
.fam-name {
  font-size: 1rem; font-weight: 600; color: var(--txt);
  letter-spacing: -0.01em;
}
.fam-who {
  font-size: 0.76rem; color: var(--txt3); line-height: 1.5;
  flex: 1;
}
.fam-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
  padding-top: 10px;
  border-top: 1px solid rgba(168,85,247,0.12);
  font-family: 'Geist Mono', monospace;
  font-size: 0.66rem; letter-spacing: 0.06em;
}
.fam-rev { color: var(--pu2); }
.fam-state {
  padding: 2px 8px;
  border-radius: 999px;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.1em;
}
.fam-state.on  { background: rgba(34,197,94,0.14); color: #86efac; border: 1px solid rgba(34,197,94,0.3); }
.fam-state.soon{ background: rgba(168,85,247,0.10); color: var(--pu2);  border: 1px solid rgba(168,85,247,0.3); }
.fam-soon { opacity: 0.78; }

@media (max-width: 1100px) { .fam-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .fam-grid { grid-template-columns: 1fr; } }

/* ── DIFF #3 — slide-aware ──────────────────────────────────────────────── */
.diff-three { padding: 96px 56px; }
.d3-stage {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 32px;
  margin-top: 40px;
  align-items: center;
}
.d3-stage .vid-ph { aspect-ratio: 16/9; }
.d3-callouts {
  display: flex; flex-direction: column; gap: 14px;
}
.d3-callout {
  display: grid; grid-template-columns: auto 1fr;
  gap: 14px; align-items: start;
  padding: 16px 18px;
  background: rgba(8,4,15,0.74);
  border: 1px solid rgba(168,85,247,0.22);
  border-left: 3px solid var(--pu2);
  border-radius: 12px;
}
.d3-pin {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(168,85,247,0.18);
  border: 1px solid rgba(168,85,247,0.5);
  color: var(--pu2);
  display: grid; place-items: center;
  font-size: 0.85rem; font-weight: 700;
}
.d3-callout b {
  display: block;
  font-size: 0.86rem; color: var(--txt); font-weight: 600;
  margin-bottom: 2px;
  letter-spacing: -0.005em;
}
.d3-callout span {
  font-size: 0.78rem; color: var(--txt2); line-height: 1.5;
  text-wrap: pretty;
}

@media (max-width: 900px) {
  .d3-stage { grid-template-columns: 1fr; }
}

/* ── ADVOCATE CARDS — 2×2 ───────────────────────────────────────────────── */
.advocate-cards { padding: 96px 56px; }
.adv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-top: 40px;
}
.adv-card {
  background: rgba(8,4,15,0.78);
  border: 1px solid rgba(168,85,247,0.22);
  border-radius: 18px;
  padding: 26px;
  display: flex; flex-direction: column; gap: 18px;
}
.adv-card-head {
  display: flex; gap: 16px; align-items: center;
}
.adv-card-head .photo-ph { width: 64px; height: 64px; font-size: 0.95rem; }
.adv-name {
  font-size: 1.05rem; font-weight: 600; color: var(--txt);
  letter-spacing: -0.01em;
  margin-bottom: 2px;
}
.adv-cred {
  font-family: 'Geist Mono', monospace;
  font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--pu2);
  margin-bottom: 4px;
}
.adv-anchor {
  font-size: 0.78rem; color: var(--txt3);
}
.adv-quote {
  font-size: 0.95rem; line-height: 1.55;
  color: var(--txt2);
  font-style: italic;
  text-wrap: pretty;
}
.adv-badges {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding-top: 14px;
  border-top: 1px solid rgba(168,85,247,0.12);
}
.adv-badges span {
  padding: 3px 9px;
  border-radius: 999px;
  background: rgba(168,85,247,0.10);
  border: 1px solid rgba(168,85,247,0.24);
  color: var(--pu2);
  font-family: 'Geist Mono', monospace;
  font-size: 0.66rem; letter-spacing: 0.06em;
}

@media (max-width: 900px) {
  .adv-grid { grid-template-columns: 1fr; }
}

/* ── PRICING grid override (3-tier) ─────────────────────────────────────── */
.pricing-grid-3 {
  grid-template-columns: repeat(3, 1fr) !important;
  max-width: 1000px; margin: 36px auto 0;
}
@media (max-width: 900px) {
  .pricing-grid-3 { grid-template-columns: 1fr !important; }
}

/* ── PRICING grid override (2-tier) ─────────────────────────────────────── */
.pricing-grid-2 {
  grid-template-columns: repeat(2, 1fr) !important;
  max-width: 720px; margin: 36px auto 0;
}
@media (max-width: 700px) {
  .pricing-grid-2 { grid-template-columns: 1fr !important; }
}

/* ── Credit-bundles micro-line under Anytime pricing ───────────────────── */
.any-pricing-bundles {
  margin-top: 18px;
  text-align: center;
  color: rgba(220, 210, 240, 0.62);
  font-size: 0.86rem;
  font-family: 'Geist', sans-serif;
}
.any-pricing-bundles b {
  color: rgba(255, 255, 255, 0.88);
  font-weight: 600;
}

/* ── Pricing "coming soon" cards (replaces tiered pricing tables) ──────── */
.any-pricing-soon,
.r-pricing-soon {
  display: flex; justify-content: center;
  margin-top: 36px;
}
.any-pricing-soon-card,
.r-pricing-soon-card {
  width: 100%;
  max-width: 560px;
  padding: 36px 32px 28px;
  border-radius: 18px;
  text-align: left;
  background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, rgba(255,255,255,0.005) 100%);
  font-family: 'Geist', sans-serif;
}
.any-pricing-soon-card {
  border: 1px solid rgba(168,85,247,0.32);
  box-shadow: 0 0 60px rgba(168,85,247,0.10);
}
.r-pricing-soon-card {
  border: 1px solid rgba(0,229,255,0.32);
  box-shadow: 0 0 60px rgba(0,229,255,0.10);
}
.any-pricing-soon-eyebrow,
.r-pricing-soon-eyebrow {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.74rem; font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.any-pricing-soon-eyebrow { color: #c4a8ff; }
.r-pricing-soon-eyebrow   { color: #7fe9ff; }
.any-pricing-soon-points,
.r-pricing-soon-points {
  display: flex; flex-direction: column; gap: 8px;
  margin-bottom: 24px;
  color: rgba(230, 220, 245, 0.86);
  font-size: 0.96rem;
  line-height: 1.5;
}
.any-pricing-soon .lp-cta,
.r-pricing-soon .lp-cta {
  width: 100%;
  justify-content: center;
}
@media (max-width: 640px) {
  .any-pricing-soon-card,
  .r-pricing-soon-card { padding: 24px 22px; }
  .any-pricing-soon-points,
  .r-pricing-soon-points { font-size: 0.92rem; }
}

/* ── Hero kicker (cohort/design-partner scarcity, brand-typographic) ──────
   Replaces the pill — no chrome, no glow, no pulsing dot. A short
   uppercase Geist Mono line with a small accent bar before it, matching
   the existing eyebrow vocabulary the page already uses elsewhere. */
.any-hero-kicker,
.r-hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 18px;
  line-height: 1.1;
}
.any-hero-kicker::before,
.r-hero-kicker::before {
  content: '';
  width: 28px; height: 2px;
  border-radius: 1px;
  flex-shrink: 0;
}
.any-hero-kicker { color: #c4a8ff; }
.any-hero-kicker::before { background: linear-gradient(90deg, transparent, #a855f7); }
.r-hero-kicker { color: #7fe9ff; }
.r-hero-kicker::before { background: linear-gradient(90deg, transparent, #00e5ff); }

.any-hero-kicker em,
.r-hero-kicker em {
  font-style: normal;
  color: #ffffff;
  font-weight: 700;
}

@media (max-width: 640px) {
  .any-hero-kicker, .r-hero-kicker {
    font-size: 0.68rem; gap: 10px;
  }
  .any-hero-kicker::before, .r-hero-kicker::before { width: 18px; }
}



/* ============================================================
   RECRUIT V2 — conversion-focused additions
   ============================================================ */

/* Trust banner — pinned above nav, always visible */
.r-trust-banner {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: 38px;
  display: flex; align-items: center; justify-content: center; gap: 14px;
  padding: 0 24px;
  background: linear-gradient(90deg, rgba(0,255,255,0.08), rgba(0,255,255,0.14), rgba(0,255,255,0.08));
  border-bottom: 1px solid rgba(0,255,255,0.18);
  font-family: 'Geist Mono', monospace;
  font-size: 0.72rem; letter-spacing: 0.04em;
  color: var(--txt);
  backdrop-filter: blur(10px);
}
.r-trust-banner strong { color: var(--cy); font-weight: 600; }
.r-tb-dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--cy);
  box-shadow: 0 0 8px var(--cy);
  animation: blink 2s infinite;
  flex-shrink: 0;
}
.r-tb-sep { color: var(--txt3); }
.r-tb-cta {
  margin-left: 10px;
  color: var(--cy); font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid rgba(0,255,255,0.4);
  padding-bottom: 1px;
  transition: all 0.18s;
}
.r-tb-cta:hover { color: #fff; border-bottom-color: #fff; }

/* Page sits flush at top now that the trust banner is gone */
.recruit-page { padding-top: 0; }

.r-nav.lp-nav-recruit { top: 0; transition: padding 0.2s, background 0.2s; }
.r-nav.lp-nav-recruit.is-compact {
  background: rgba(2,8,12,0.92);
  border-bottom-color: rgba(0,255,255,0.16);
}
.r-nav-cta {
  /* always-visible primary CTA in nav */
  font-size: 0.86rem;
  font-weight: 600;
}

/* ============================================================
   HERO V2 — split layout: copy LEFT, dashboard tile RIGHT,
   world map BELOW (kept gorgeous, no longer dominates)
   ============================================================ */

.r-hero-v2 {
  min-height: auto;
  padding: 100px 48px 60px;
  align-items: stretch;
  justify-content: stretch;
  text-align: left;
  display: block;
}
.r-hero-grid-layout {
  position: relative;
  max-width: 1280px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 56px;
  align-items: center;
  padding-top: 44px;
}

.r-hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 14px; border-radius: 999px;
  background: rgba(0,255,255,0.06);
  border: 1px solid rgba(0,255,255,0.18);
  font-family: 'Geist Mono', monospace;
  font-size: 0.66rem; letter-spacing: 0.18em;
  color: var(--cy2);
  margin-bottom: 22px;
}
.r-hero-eyebrow .pilot-dot {
  width: 6px; height: 6px; background: var(--cy); border-radius: 50%;
  box-shadow: 0 0 8px var(--cy); animation: blink 2s infinite;
}

.r-hero-h1 {
  text-align: left;
  margin: 0 0 20px 0;
  font-size: clamp(2.4rem, 4.6vw, 4.2rem);
  line-height: 1;
}
.r-hero-h1 em {
  display: inline-block;
  font-style: normal;
  font-size: 1.18em;
  letter-spacing: -0.04em;
  background: linear-gradient(135deg, #34d399 0%, #00E5FF 60%, #74f0ff 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: 0 0 60px rgba(0,229,255,0.35);
}
.r-bignum {
  font-variant-numeric: tabular-nums;
}

.r-hero-sub {
  text-align: left;
  max-width: 520px;
  margin: 0 0 26px 0;
  font-size: 1.05rem;
}
.r-hero-sub strong { color: var(--txt); font-weight: 600; }

.r-hero-microstats {
  display: flex; gap: 24px;
  margin-bottom: 28px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.74rem; color: var(--txt2);
  letter-spacing: 0.04em;
}
.r-hero-microstats div { display: flex; align-items: baseline; gap: 6px; }
.r-hero-microstats strong { color: var(--cy); font-weight: 600; font-size: 0.94rem; }

.r-hero-ctas-v2 {
  display: flex; gap: 12px;
  margin: 0 0 18px 0;
  justify-content: flex-start;
}
.r-cta-lg { padding: 14px 26px; font-size: 0.94rem; }

.r-hero-risk {
  display: flex; gap: 18px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem;
  color: var(--txt2);
  letter-spacing: 0.04em;
}
.r-hero-risk span { display: inline-flex; align-items: center; gap: 4px; }

/* Hero dashboard preview tile */
.r-hero-tile { position: relative; }
.r-hero-dash {
  background: linear-gradient(160deg, rgba(0,255,255,0.04), rgba(0,255,255,0.01));
  border: 1px solid rgba(0,255,255,0.18);
  border-radius: 16px;
  padding: 14px;
  box-shadow: 0 24px 60px rgba(0,255,255,0.12), 0 0 1px rgba(0,255,255,0.4) inset;
  position: relative;
  transform: perspective(1400px) rotateY(-3deg) rotateX(2deg);
  transform-origin: center;
}
.r-hero-dash::before {
  content: 'PREVIEW';
  position: absolute; top: -10px; right: 16px;
  padding: 3px 10px;
  background: var(--cy); color: #001014;
  font-family: 'Geist Mono', monospace;
  font-size: 0.6rem; font-weight: 700;
  letter-spacing: 0.14em;
  border-radius: 4px;
  z-index: 2;
}
.r-hero-dash-head {
  display: flex; align-items: center; gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(0,255,255,0.1);
  margin-bottom: 10px;
}
.r-hd-dot {
  width: 6px; height: 6px; border-radius: 50%; background: #34d399;
  box-shadow: 0 0 6px #34d399;
}
.r-hd-title {
  font-family: 'Geist Mono', monospace;
  font-size: 0.66rem; color: var(--txt2);
  letter-spacing: 0.04em;
  flex: 1;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.r-hd-time {
  font-family: 'Geist Mono', monospace;
  font-size: 0.64rem; color: var(--cy2);
  letter-spacing: 0.06em;
}

.r-hero-dash-rows { display: flex; flex-direction: column; gap: 6px; }
.r-hd-row {
  display: grid; grid-template-columns: 28px 1fr 60px 28px 80px;
  align-items: center; gap: 10px;
  padding: 8px 10px;
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.04);
  border-radius: 8px;
  opacity: 0;
  animation: rHdRowIn 0.5s forwards;
  animation-delay: inherit;
}
@keyframes rHdRowIn {
  from { opacity: 0; transform: translateX(-6px); }
  to   { opacity: 1; transform: translateX(0); }
}
.r-hd-av {
  width: 24px; height: 24px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Geist Mono', monospace;
  font-size: 0.6rem; font-weight: 700; color: #001014;
  letter-spacing: 0.04em;
}
.r-hd-name { font-size: 0.78rem; color: var(--txt); font-weight: 500; }
.r-hd-bar {
  height: 4px; background: rgba(255,255,255,0.06); border-radius: 2px;
  overflow: hidden;
}
.r-hd-bar > span {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--cy3), var(--cy));
  box-shadow: 0 0 6px var(--cy-glow);
}
.r-hd-score {
  font-family: 'Geist Mono', monospace;
  font-size: 0.78rem; font-weight: 600;
  color: var(--cy); text-align: right;
}
.r-hd-v {
  font-family: 'Geist Mono', monospace;
  font-size: 0.58rem; font-weight: 600;
  letter-spacing: 0.1em;
  padding: 3px 6px;
  border-radius: 4px;
  text-align: center;
}
.r-hd-v-r { background: rgba(16,185,129,0.12); color: #34d399; border: 1px solid rgba(16,185,129,0.25); }
.r-hd-v-y { background: rgba(245,158,11,0.12); color: #fbbf24; border: 1px solid rgba(245,158,11,0.25); }

.r-hero-dash-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 10px; margin-top: 10px;
  border-top: 1px solid rgba(0,255,255,0.08);
  font-family: 'Geist Mono', monospace;
  font-size: 0.62rem;
  color: var(--txt2);
}
.r-hd-deeplink { color: var(--cy); text-decoration: none; }
.r-hd-deeplink:hover { color: #fff; }

/* World map: secondary, sized smaller below the hero copy */
.r-hero-map-wrap {
  margin-top: 80px;
  max-width: 1280px;
  margin-left: auto; margin-right: auto;
  position: relative;
}
.r-hero-map-eyebrow {
  display: flex; justify-content: center; align-items: center; gap: 10px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.16em;
  color: var(--cy2);
  margin-bottom: 14px;
}
.r-hero-map-eyebrow .pilot-dot {
  width: 6px; height: 6px; background: var(--cy); border-radius: 50%;
  box-shadow: 0 0 8px var(--cy); animation: blink 2s infinite;
}
.r-hero-map-wrap .recruit-worldmap {
  /* keep aspect tied to the world SVG, but constrain max */
  max-width: 1100px; margin: 0 auto;
}

/* ============================================================
   LIVE PILOT FOOTAGE — labeled badge + trust stats
   ============================================================ */

.r-clip-grid { grid-template-columns: 1.5fr 1fr; gap: 32px; align-items: stretch; }

.r-clip-real-badge {
  position: absolute; top: 14px; left: 14px;
  z-index: 3;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  background: rgba(2,8,12,0.85);
  border: 1px solid rgba(0,255,255,0.4);
  border-radius: 999px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.6rem;
  color: var(--cy);
  letter-spacing: 0.14em; text-transform: uppercase;
  backdrop-filter: blur(8px);
  box-shadow: 0 0 16px var(--cy-glow);
}
.r-clip-real-badge .pilot-dot {
  width: 5px; height: 5px; background: var(--cy); border-radius: 50%;
  box-shadow: 0 0 6px var(--cy); animation: blink 1.6s infinite;
}

.r-live-side {
  display: flex; flex-direction: column; gap: 18px;
}
.r-live-trust {
  background: linear-gradient(160deg, rgba(0,255,255,0.04), rgba(0,255,255,0.01));
  border: 1px solid rgba(0,255,255,0.12);
  border-radius: 14px;
  padding: 18px 20px;
}
.r-live-trust-h {
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.08em;
  color: var(--cy2);
  margin-bottom: 12px;
}
.r-live-trust-list { list-style: none; display: flex; flex-direction: column; gap: 8px; padding: 0; margin: 0; }
.r-live-trust-list li {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: 0.84rem; color: var(--txt); line-height: 1.5;
}
.r-lt-check {
  flex-shrink: 0;
  width: 16px; height: 16px; border-radius: 4px;
  background: rgba(0,255,255,0.1);
  border: 1px solid rgba(0,255,255,0.3);
  color: var(--cy);
  font-size: 0.6rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  margin-top: 2px;
}

.r-live-stats {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.r-live-stat {
  padding: 14px 16px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
}
.r-ls-n {
  font-size: 1.5rem; font-weight: 700; letter-spacing: -0.02em;
  color: var(--cy);
}
.r-ls-l {
  font-family: 'Geist Mono', monospace;
  font-size: 0.62rem; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--txt3);
  margin-top: 2px;
}
.r-live-cta {
  align-self: flex-start;
  margin-top: 4px;
}

/* ============================================================
   DASHBOARD — CTA row beneath
   ============================================================ */

.r-dash-cta-row {
  display: flex; justify-content: center; align-items: center; gap: 14px;
  margin-top: 28px;
}

/* ============================================================
   ROI CALCULATOR — the conversion engine
   ============================================================ */

.r-roi-section {
  background: linear-gradient(180deg, rgba(0,255,255,0.02), transparent);
  border-top: 1px solid rgba(0,255,255,0.08);
  border-bottom: 1px solid rgba(0,255,255,0.08);
}

.r-roi-grid {
  display: grid; grid-template-columns: 1fr 1.05fr; gap: 32px;
  margin-top: 36px;
}

.r-roi-inputs {
  display: flex; flex-direction: column; gap: 22px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px;
  padding: 28px;
}

.r-roi-input { display: flex; flex-direction: column; gap: 8px; }
.r-roi-input-head {
  display: flex; justify-content: space-between; align-items: baseline;
}
.r-roi-input-head label {
  font-family: 'Geist Mono', monospace;
  font-size: 0.74rem; letter-spacing: 0.06em;
  color: var(--txt2);
}
.r-roi-input-val {
  font-family: 'Geist Mono', monospace;
  font-size: 1.05rem; font-weight: 600;
  color: var(--cy);
}
.r-roi-input input[type=range] {
  width: 100%; height: 4px;
  appearance: none; -webkit-appearance: none;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
}
.r-roi-input input[type=range]::-webkit-slider-thumb {
  appearance: none; -webkit-appearance: none;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--cy);
  box-shadow: 0 0 12px var(--cy-glow), 0 2px 6px rgba(0,0,0,0.5);
  border: 2px solid #001014;
  cursor: pointer;
}
.r-roi-input input[type=range]::-moz-range-thumb {
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--cy);
  box-shadow: 0 0 12px var(--cy-glow);
  border: 2px solid #001014;
  cursor: pointer;
}
.r-roi-input-foot {
  display: flex; justify-content: space-between;
  font-family: 'Geist Mono', monospace;
  font-size: 0.6rem; color: var(--txt3);
  letter-spacing: 0.06em;
}

.r-roi-output {
  background: linear-gradient(160deg, rgba(0,255,255,0.06), rgba(0,255,255,0.01));
  border: 1px solid rgba(0,255,255,0.22);
  border-radius: 16px;
  padding: 28px;
  display: flex; flex-direction: column; gap: 18px;
  box-shadow: 0 24px 80px rgba(0,255,255,0.08);
}
.r-roi-output-head {
  display: flex; justify-content: space-between; align-items: center;
}
.r-roi-eyebrow {
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.12em;
  color: var(--cy2); text-transform: uppercase;
}
.r-roi-pill {
  font-family: 'Geist Mono', monospace;
  font-size: 0.66rem; letter-spacing: 0.06em;
  padding: 4px 10px;
  background: rgba(0,255,255,0.08);
  border: 1px solid rgba(0,255,255,0.2);
  border-radius: 999px;
  color: var(--cy);
}
.r-roi-saved {
  text-align: center;
  padding: 18px 0 10px;
  border-bottom: 1px solid rgba(0,255,255,0.12);
}
.r-roi-saved-label {
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.18em;
  color: var(--txt3); text-transform: uppercase;
  margin-bottom: 6px;
}
.r-roi-saved-num {
  font-size: clamp(2.6rem, 5.4vw, 4.2rem);
  font-weight: 700; letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
  background: linear-gradient(135deg, #34d399 0%, #00E5FF 70%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: 0 0 60px rgba(52,211,153,0.3);
  line-height: 1;
}
.r-roi-saved-sub {
  font-size: 0.86rem; color: var(--txt2);
  margin-top: 6px;
}
.r-roi-rows { display: flex; flex-direction: column; gap: 10px; }
.r-roi-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.88rem;
  color: var(--txt2);
}
.r-roi-row-total {
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,0.06);
  color: var(--txt);
  font-weight: 500;
}
.r-roi-old { font-family: 'Geist Mono', monospace; color: var(--txt3); text-decoration: line-through; }
.r-roi-new { font-family: 'Geist Mono', monospace; color: var(--cy); font-weight: 600; }

.r-roi-cta { align-self: stretch; justify-content: center; padding: 14px 26px; font-size: 0.94rem; }
.r-roi-fineprint {
  font-size: 0.72rem; color: var(--txt3);
  line-height: 1.55;
}

/* ============================================================
   PILOT OFFER — risk reversal block
   ============================================================ */

.r-pilot-offer { padding: 60px 48px; }
.r-po-card {
  max-width: 1100px; margin: 0 auto;
  background: linear-gradient(160deg, rgba(0,255,255,0.05), rgba(0,255,255,0.01));
  border: 1px solid rgba(0,255,255,0.22);
  border-radius: 24px;
  padding: 52px 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.r-po-card::before {
  content:''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 80% at 50% 0%, rgba(0,255,255,0.1), transparent 70%);
  pointer-events: none;
}
.r-po-tag {
  position: relative;
  display: inline-block;
  padding: 6px 14px;
  background: rgba(0,255,255,0.1);
  border: 1px solid rgba(0,255,255,0.3);
  border-radius: 999px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.66rem; letter-spacing: 0.16em;
  color: var(--cy);
  margin-bottom: 18px;
}
.r-po-h {
  position: relative;
  font-size: clamp(2rem, 3.8vw, 3rem);
  font-weight: 700; letter-spacing: -0.03em;
  margin: 0 0 14px 0;
  text-wrap: balance;
}
.r-po-h em { font-style: normal; color: var(--cy2); }
.r-po-sub {
  position: relative;
  color: var(--txt2);
  font-size: 1rem; line-height: 1.65;
  max-width: 720px; margin: 0 auto 32px;
  text-wrap: pretty;
}

.r-po-grid {
  position: relative;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  margin-bottom: 30px;
}
.r-po-item {
  padding: 18px 16px;
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(0,255,255,0.12);
  border-radius: 12px;
}
.r-po-num {
  font-size: 1.4rem; font-weight: 700; letter-spacing: -0.025em;
  color: var(--cy);
  margin-bottom: 4px;
}
.r-po-lbl {
  font-family: 'Geist Mono', monospace;
  font-size: 0.66rem; letter-spacing: 0.06em;
  color: var(--txt2); text-transform: uppercase;
}

.r-po-ctas {
  position: relative;
  display: flex; gap: 12px; justify-content: center;
  margin-bottom: 18px;
}
.r-po-fineprint {
  position: relative;
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; color: var(--txt3);
  letter-spacing: 0.04em;
  line-height: 1.55;
}

/* ============================================================
   PRICING — directional, transparent
   ============================================================ */

.r-pricing-section { padding: 100px 48px; }

.r-pricing-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin-top: 48px;
}
.r-price-tier {
  position: relative;
  padding: 32px 26px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px;
  display: flex; flex-direction: column; gap: 14px;
}
.r-price-tier-feat {
  background: linear-gradient(160deg, rgba(0,255,255,0.06), rgba(0,255,255,0.02));
  border-color: rgba(0,255,255,0.32);
  box-shadow: 0 24px 60px rgba(0,255,255,0.08);
  transform: translateY(-8px);
}
.r-price-flag {
  position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
  padding: 4px 12px;
  background: var(--cy); color: #001014;
  font-family: 'Geist Mono', monospace;
  font-size: 0.6rem; font-weight: 700;
  letter-spacing: 0.14em;
  border-radius: 4px;
  white-space: nowrap;
}
.r-price-name {
  font-family: 'Geist Mono', monospace;
  font-size: 0.76rem; letter-spacing: 0.16em;
  color: var(--cy2); text-transform: uppercase;
}
.r-price-amount { display: flex; align-items: baseline; gap: 8px; }
.r-price-amount .big {
  font-size: 2.4rem; font-weight: 700; letter-spacing: -0.035em;
  color: var(--txt);
  line-height: 1;
}
.r-price-amount .per {
  font-family: 'Geist Mono', monospace;
  font-size: 0.74rem; color: var(--txt3);
  letter-spacing: 0.04em;
}
.r-price-detail {
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; color: var(--txt2);
  letter-spacing: 0.04em;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.r-price-feats {
  list-style: none; display: flex; flex-direction: column; gap: 10px;
  flex: 1; padding: 0; margin: 0;
}
.r-price-feats li {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: 0.86rem; color: var(--txt); line-height: 1.5;
}
.r-price-feats li::before {
  content: '✓';
  color: var(--cy); font-weight: 600;
  flex-shrink: 0;
}
.r-price-cta {
  margin-top: 8px;
  justify-content: center;
}
.r-price-foot {
  margin-top: 36px;
  text-align: center;
  font-family: 'Geist Mono', monospace;
  font-size: 0.78rem; color: var(--txt2);
  letter-spacing: 0.04em;
}
.r-price-foot a { color: var(--cy); text-decoration: none; border-bottom: 1px solid rgba(0,255,255,0.3); }
.r-price-foot a:hover { color: #fff; border-bottom-color: #fff; }

/* ============================================================
   SECURITY STRIP — single horizontal row
   ============================================================ */

.r-security-strip {
  padding: 56px 48px;
  background: rgba(0,0,0,0.3);
  border-top: 1px solid rgba(0,255,255,0.08);
  border-bottom: 1px solid rgba(0,255,255,0.08);
}
.r-sec-wrap {
  display: grid; grid-template-columns: 280px 1fr; gap: 36px;
  align-items: center;
}
.r-sec-h {
  font-size: 1.4rem; font-weight: 600; letter-spacing: -0.02em;
  margin: 8px 0 0 0;
  color: var(--txt);
  text-wrap: balance;
}
.r-sec-badges {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
}
.r-sec-badge {
  padding: 14px 14px;
  background: rgba(0,255,255,0.03);
  border: 1px solid rgba(0,255,255,0.1);
  border-radius: 10px;
}
.r-sec-badge-l {
  font-size: 0.86rem; font-weight: 600; color: var(--cy2);
  letter-spacing: -0.01em;
  margin-bottom: 4px;
}
.r-sec-badge-s {
  font-family: 'Geist Mono', monospace;
  font-size: 0.62rem; color: var(--txt3);
  letter-spacing: 0.04em;
}

/* ============================================================
   FINAL CTA — three differentiated paths
   ============================================================ */

.r-final-cta { padding: 100px 48px 120px; }
.r-final-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 14px; border-radius: 999px;
  background: rgba(0,255,255,0.08);
  border: 1px solid rgba(0,255,255,0.22);
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.14em;
  color: var(--cy);
  margin-bottom: 24px;
  position: relative;
}
.r-final-eyebrow .pilot-dot {
  width: 6px; height: 6px; background: var(--cy); border-radius: 50%;
  box-shadow: 0 0 8px var(--cy); animation: blink 2s infinite;
}

.r-final-paths {
  position: relative;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
  max-width: 1100px; margin: 36px auto 0;
}
.r-final-path {
  display: flex; flex-direction: column; gap: 8px;
  padding: 28px 24px;
  border-radius: 16px;
  text-align: left;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.02);
  transition: all 0.2s;
  position: relative;
}
.r-final-path:hover {
  transform: translateY(-4px);
  border-color: rgba(0,255,255,0.3);
  background: rgba(0,255,255,0.04);
  box-shadow: 0 16px 40px rgba(0,255,255,0.08);
}
.r-fp-step {
  font-family: 'Geist Mono', monospace;
  font-size: 0.62rem; letter-spacing: 0.16em;
  color: var(--txt3); text-transform: uppercase;
}
.r-fp-title {
  font-size: 1.15rem; font-weight: 600; letter-spacing: -0.02em;
  color: var(--txt);
}
.r-fp-sub {
  font-size: 0.84rem; color: var(--txt2); line-height: 1.55;
  flex: 1;
}
.r-fp-go {
  font-family: 'Geist Mono', monospace;
  font-size: 0.78rem; font-weight: 600;
  color: var(--cy);
  letter-spacing: 0.06em;
  margin-top: 6px;
}
.r-fp-go-hot { color: var(--cy); }
.r-final-path-hot {
  background: linear-gradient(160deg, rgba(0,255,255,0.08), rgba(0,255,255,0.02));
  border-color: rgba(0,255,255,0.3);
}
.r-final-path-hot .r-fp-step { color: var(--cy2); }

.r-final-trust {
  position: relative;
  text-align: center;
  margin-top: 36px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.72rem; color: var(--txt3);
  letter-spacing: 0.08em;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1024px) {
  .r-hero-grid-layout { grid-template-columns: 1fr; gap: 40px; }
  .r-roi-grid { grid-template-columns: 1fr; }
  .r-pricing-grid { grid-template-columns: 1fr; }
  .r-price-tier-feat { transform: none; }
  .r-final-paths { grid-template-columns: 1fr; }
  .r-sec-wrap { grid-template-columns: 1fr; }
  .r-sec-badges { grid-template-columns: repeat(2, 1fr); }
  .r-clip-grid { grid-template-columns: 1fr; }
  .r-po-grid { grid-template-columns: repeat(2, 1fr); }
  .r-hero-microstats { flex-wrap: wrap; gap: 12px 18px; }
}

@media (max-width: 720px) {
  .r-trust-banner { font-size: 0.62rem; gap: 6px; padding: 0 12px; height: auto; min-height: 38px; flex-wrap: wrap; padding-top: 6px; padding-bottom: 6px; }
  .r-trust-banner .r-tb-sep { display: none; }
  .recruit-page { padding-top: 0; }
  .r-nav.lp-nav-recruit { top: 0; }
  .r-hero-v2 { padding: 80px 20px 40px; }
  .r-pilot-offer, .r-pricing-section, .r-final-cta, .r-security-strip { padding: 60px 20px; }
  .r-hero-microstats { font-size: 0.66rem; }
  .r-hero-ctas-v2 { flex-direction: column; align-items: stretch; }
  .r-hero-risk { flex-wrap: wrap; gap: 8px 14px; }
  .r-sec-badges { grid-template-columns: 1fr; }
}


/* ============================================================
   ANYTIME V5 — conversion rebuild additions
   ============================================================ */

/* Hero V5 — outcome row + scorecard tile + founder line */
.any-sub-v5 {
  font-size: 1.05rem;
  max-width: 540px;
  line-height: 1.55;
}

.hero-outcome-row {
  display: flex; align-items: center;
  gap: 12px;
  margin: 22px 0 18px;
  padding: 16px 18px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(180,140,255,0.18);
  border-radius: 14px;
  max-width: 540px;
}
.hor-cell {
  flex: 1;
  text-align: left;
}
.hor-n {
  font-size: 1.35rem; font-weight: 700;
  letter-spacing: -0.025em;
  color: #c4a8ff;
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
}
.hor-l {
  font-family: 'Geist Mono', monospace;
  font-size: 0.62rem; color: rgba(220,210,240,0.6);
  letter-spacing: 0.04em; text-transform: uppercase;
  margin-top: 3px;
}
.hor-sep {
  width: 1px; height: 28px;
  background: linear-gradient(180deg, transparent, rgba(180,140,255,0.18), transparent);
  flex-shrink: 0;
}

/* Hero visual: video + tilted scorecard + founder line */
.hero-visual-v5 { position: relative; }
.hero-scorecard {
  position: absolute;
  bottom: 60px; right: -28px;
  width: 280px;
  background: linear-gradient(160deg, rgba(28,18,42,0.96), rgba(18,12,28,0.96));
  border: 1px solid rgba(180,140,255,0.32);
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: 0 24px 60px rgba(120,80,220,0.22);
  backdrop-filter: blur(12px);
  transform: perspective(1200px) rotateY(-8deg) rotateX(4deg);
  transform-origin: center;
}
.hsc-head {
  display: flex; align-items: center; gap: 8px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(180,140,255,0.14);
  margin-bottom: 10px;
}
.hsc-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #c4a8ff;
  box-shadow: 0 0 8px #c4a8ff;
  animation: blink 2s infinite;
}
.hsc-title {
  font-family: 'Geist Mono', monospace;
  font-size: 0.62rem; color: rgba(220,210,240,0.85);
  letter-spacing: 0.04em;
  flex: 1;
}
.hsc-time {
  font-family: 'Geist Mono', monospace;
  font-size: 0.6rem; color: #c4a8ff;
  letter-spacing: 0.06em;
}
.hsc-rows { display: flex; flex-direction: column; gap: 6px; }
.hsc-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.78rem; color: rgba(230,225,245,0.92);
}
.hsc-ok { color: #b5f0c9; font-weight: 600; font-variant-numeric: tabular-nums; }
.hsc-warn { color: #ffd28e; font-weight: 600; font-variant-numeric: tabular-nums; }
.hsc-foot {
  margin-top: 10px; padding-top: 8px;
  border-top: 1px solid rgba(180,140,255,0.12);
  font-family: 'Geist Mono', monospace;
  font-size: 0.6rem; color: rgba(220,210,240,0.65);
  letter-spacing: 0.04em;
}
.hsc-foot b { color: #c4a8ff; }

.hero-founder-line {
  display: flex; align-items: flex-start; gap: 8px;
  margin-top: 18px;
  padding: 10px 14px;
  background: rgba(255,255,255,0.025);
  border: 1px dashed rgba(180,140,255,0.2);
  border-radius: 10px;
  font-size: 0.78rem;
  color: rgba(220,210,240,0.75);
  line-height: 1.5;
  max-width: 380px;
}
.hero-founder-line b { color: #c4a8ff; font-weight: 600; }
.hfl-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #c4a8ff;
  box-shadow: 0 0 6px #c4a8ff;
  margin-top: 7px;
  flex-shrink: 0;
}

/* Trust bar V5 — 4 cells, no avatars */
.trust-row-v5 {
  grid-template-columns: repeat(4, 1fr) !important;
  display: grid;
  gap: 14px;
}

/* ============================================================
   AUDIENCE PICKER
   ============================================================ */

.audience-picker { padding-top: 60px; padding-bottom: 60px; }

.ap-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin-top: 36px;
}
.ap-card {
  display: flex; flex-direction: column; gap: 10px;
  padding: 26px 22px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(180,140,255,0.16);
  border-radius: 16px;
  text-decoration: none;
  color: inherit;
  transition: all 0.2s;
  position: relative;
  overflow: hidden;
}
.ap-card::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 80% at 50% 0%, rgba(180,140,255,0.08), transparent 70%);
  opacity: 0; transition: opacity 0.25s;
  pointer-events: none;
}
.ap-card:hover {
  transform: translateY(-4px);
  border-color: rgba(180,140,255,0.4);
  background: rgba(180,140,255,0.04);
  box-shadow: 0 20px 50px rgba(120,80,220,0.18);
}
.ap-card:hover::after { opacity: 1; }

.ap-emoji { font-size: 2rem; line-height: 1; }
.ap-tag {
  font-family: 'Geist Mono', monospace;
  font-size: 0.62rem; letter-spacing: 0.06em;
  color: rgba(220,210,240,0.55);
  text-transform: uppercase;
}
.ap-card h4 {
  font-size: 1.15rem; font-weight: 600; letter-spacing: -0.02em;
  margin: 4px 0 0 0;
  color: #f0eaff;
  text-wrap: balance;
}
.ap-card p {
  font-size: 0.86rem; color: rgba(220,210,240,0.7);
  line-height: 1.55;
  flex: 1;
  margin: 0;
}
.ap-go {
  font-family: 'Geist Mono', monospace;
  font-size: 0.78rem; font-weight: 600;
  color: #c4a8ff;
  letter-spacing: 0.06em;
  margin-top: 4px;
}

/* ============================================================
   SLIDE-AWARE — mid-page CTA
   ============================================================ */

.sa-mid-cta {
  display: flex; align-items: center; justify-content: center; gap: 18px;
  margin-top: 36px;
  flex-wrap: wrap;
}
.sa-mid-fine {
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem;
  color: rgba(220,210,240,0.55);
  letter-spacing: 0.04em;
}

/* ============================================================
   PROBLEM V5 — three painful scenarios + truth wedge
   ============================================================ */

.any-problem-v5 .any-h2-v2 { margin-bottom: 36px; }

.prob-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin-bottom: 36px;
}
.prob-card {
  display: flex; flex-direction: column; gap: 10px;
  padding: 26px 22px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(180,140,255,0.14);
  border-radius: 14px;
}
.prob-pin {
  font-size: 1.6rem; line-height: 1;
}
.prob-card h4 {
  font-size: 1.05rem; font-weight: 600; letter-spacing: -0.02em;
  margin: 0;
  color: #f0eaff;
  text-wrap: balance;
}
.prob-card p {
  font-size: 0.88rem; color: rgba(220,210,240,0.72);
  line-height: 1.6;
  margin: 0;
}
.prob-card p em { color: #c4a8ff; font-style: italic; }

.prob-truth {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
  padding: 24px 28px;
  background: linear-gradient(160deg, rgba(180,140,255,0.06), rgba(180,140,255,0.01));
  border: 1px solid rgba(180,140,255,0.22);
  border-radius: 14px;
}
.pt-line {
  display: flex; flex-direction: column; gap: 6px;
}
.pt-num {
  font-size: 1.8rem; font-weight: 700; letter-spacing: -0.03em;
  color: #c4a8ff;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.pt-l {
  font-size: 0.86rem; color: rgba(220,210,240,0.78);
  line-height: 1.5;
}
.pt-l b { color: #f0eaff; font-weight: 600; }

/* ============================================================
   OUTCOMES — pilot framing
   ============================================================ */

.any-outcomes { padding-top: 80px; padding-bottom: 80px; }

.any-eyebrow-pilot {
  display: inline-flex !important;
  align-items: center; gap: 8px;
  padding: 6px 14px !important;
  background: rgba(180,140,255,0.08);
  border: 1px solid rgba(180,140,255,0.3) !important;
  border-radius: 999px !important;
  color: #c4a8ff !important;
}
.aep-pulse {
  width: 6px; height: 6px; border-radius: 50%;
  background: #c4a8ff;
  box-shadow: 0 0 8px #c4a8ff;
  animation: blink 2s infinite;
}

.outc-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  margin-top: 36px;
}
.outc-card {
  position: relative;
  padding: 22px 20px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(180,140,255,0.16);
  border-radius: 14px;
}
.outc-pin {
  position: absolute; top: 14px; right: 14px;
  font-size: 0.5rem; color: #c4a8ff;
  filter: drop-shadow(0 0 6px #c4a8ff);
}
.outc-n {
  font-size: 2rem; font-weight: 700; letter-spacing: -0.035em;
  color: #f0eaff;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  margin-bottom: 8px;
}
.outc-l {
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.04em;
  color: #c4a8ff;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.outc-s {
  font-size: 0.78rem; color: rgba(220,210,240,0.6);
  line-height: 1.5;
}

.outc-quotes {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  margin-top: 28px;
}
.outc-q {
  margin: 0;
  padding: 22px 24px;
  background: rgba(255,255,255,0.02);
  border-left: 2px solid rgba(180,140,255,0.4);
  border-radius: 0 12px 12px 0;
}
.outc-q p {
  font-size: 0.94rem;
  color: rgba(240,234,255,0.92);
  line-height: 1.6;
  margin: 0 0 12px 0;
  font-style: italic;
}
.outc-q footer {
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem;
  color: rgba(220,210,240,0.55);
  letter-spacing: 0.04em;
}

.outc-fineprint {
  margin-top: 28px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.74rem;
  color: rgba(220,210,240,0.5);
  line-height: 1.6;
  text-align: center;
  max-width: 720px;
  margin-left: auto; margin-right: auto;
}

/* Advocate "soon" note */
.adv-soon-note {
  display: block;
  margin-top: 10px;
  font-family: 'Geist Mono', monospace;
  font-size: 0.78rem;
  color: rgba(220,210,240,0.55);
  letter-spacing: 0.02em;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1024px) {
  .ap-grid { grid-template-columns: 1fr; }
  .prob-grid { grid-template-columns: 1fr; }
  .prob-truth { grid-template-columns: 1fr; gap: 16px; }
  .outc-grid { grid-template-columns: repeat(2, 1fr); }
  .outc-quotes { grid-template-columns: 1fr; }
  .trust-row-v5 { grid-template-columns: repeat(2, 1fr) !important; }
  .hero-outcome-row { flex-wrap: wrap; gap: 14px 18px; max-width: 100%; }
  .hor-sep { display: none; }
  .hor-cell { flex: 0 0 calc(50% - 9px); }
  .hero-scorecard {
    position: static;
    transform: none;
    width: 100%;
    margin-top: -40px;
    margin-bottom: 12px;
  }
  .hero-founder-line { max-width: 100%; }
}

@media (max-width: 720px) {
  .outc-grid { grid-template-columns: 1fr; }
  .trust-row-v5 { grid-template-columns: 1fr !important; }
  .sa-mid-cta { flex-direction: column; gap: 10px; }
}


/* ═══════════════════════════════════════════════════════════════════
   HOVER VIDEO REEL — chooser splash
   ─────────────────────────────────────────────────────────────────── */
.hvr {
  position: absolute; top: 0; bottom: 0;
  width: 50%;
  pointer-events: none;
  z-index: 1;
  overflow: hidden;
}
.hvr-anytime { left: 0; }
.hvr-recruit { right: 0; }

/* item = card + caption stacked, slides in as a unit */
.hvr-item {
  position: absolute;
  width: 268px;
  opacity: 0;
  will-change: transform, opacity;
}

.hvr-card {
  width: 100%; height: 156px;
  border-radius: 14px;
  overflow: hidden;
  background: #07060d;
  position: relative;
}
.hvr-card video {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.hvr-card-glow {
  position: absolute; inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,0.55));
  z-index: 2;
}

/* accent treatment per side */
.hvr-anytime .hvr-card {
  box-shadow:
    0 0 0 1px rgba(168,85,247,0.30),
    0 24px 60px rgba(0,0,0,0.55),
    0 0 32px rgba(168,85,247,0.18);
}
.hvr-recruit .hvr-card {
  box-shadow:
    0 0 0 1px rgba(0,229,255,0.26),
    0 24px 60px rgba(0,0,0,0.55),
    0 0 32px rgba(0,229,255,0.16);
}

/* SYMMETRIC vertical stack — same x, equal rhythm */
.hvr-anytime .hvr-item { left: 8%;  }
.hvr-recruit .hvr-item { right: 8%; }

.hvr-item-0 { top: 6%;  }
.hvr-item-1 { top: 28%; }
.hvr-item-2 { top: 50%; }
.hvr-item-3 { top: 72%; }

/* slide-in animations on the whole item (card + caption together) */
.hvr-anytime .hvr-item {
  animation: hvrSlideInLeft 0.55s cubic-bezier(0.22, 0.7, 0.32, 1) both;
}
.hvr-recruit .hvr-item {
  animation: hvrSlideInRight 0.55s cubic-bezier(0.22, 0.7, 0.32, 1) both;
}

@keyframes hvrSlideInLeft {
  0%   { transform: translateX(-180%) scale(0.92); opacity: 0; }
  60%  { opacity: 1; }
  100% { transform: translateX(0) scale(1); opacity: 1; }
}
@keyframes hvrSlideInRight {
  0%   { transform: translateX(180%) scale(0.92); opacity: 0; }
  60%  { opacity: 1; }
  100% { transform: translateX(0) scale(1); opacity: 1; }
}

/* feature tag — top-left corner of card */
.hvr-tag {
  position: absolute; top: 10px; left: 10px;
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.6rem; font-weight: 600;
  letter-spacing: 0.14em;
  padding: 4px 8px;
  border-radius: 4px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
  z-index: 3;
}
.hvr-anytime .hvr-tag {
  color: #e9d5ff;
  box-shadow: inset 0 0 0 1px rgba(168,85,247,0.4);
}
.hvr-recruit .hvr-tag {
  color: #b6f7ff;
  box-shadow: inset 0 0 0 1px rgba(0,229,255,0.4);
}
/* live indicator pulse on recruit tag */
.hvr-recruit .hvr-tag::before {
  content: ''; display: inline-block;
  width: 6px; height: 6px; border-radius: 50%;
  background: #00FFFF;
  margin-right: 6px; vertical-align: middle;
  box-shadow: 0 0 8px rgba(0,255,255,0.8);
  animation: hvrLivePulse 1.4s ease-in-out infinite;
}
@keyframes hvrLivePulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.35; }
}

/* SOFT caption — sits under the card, dim, lightweight */
.hvr-cap {
  margin-top: 10px;
  padding: 0 2px;
  font-family: 'Geist', sans-serif;
  font-size: 0.74rem; font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.005em;
  color: rgba(255,255,255,0.62);
  text-align: left;
}

/* responsive trims */
@media (max-width: 1180px) {
  .hvr-item { width: 226px; }
  .hvr-card { height: 132px; }
}

/* Smaller laptops (≤1280px) — push the hover expansion further and tighten
   the text column so it can never collide with the reel videos.
   Breakpoint deliberately above 1180px to cover the 1181–1280px gap where
   the default 65/35 split still left ~30px of overlap at 1080p/1366p laptops. */
@media (max-width: 1280px) {
  .chooser-content { max-width: 360px; }

  .chooser.hover-anytime .chooser-half.anytime,
  .chooser.hover-recruit .chooser-half.recruit { width: 72%; }
  .chooser.hover-anytime .chooser-half.recruit,
  .chooser.hover-recruit .chooser-half.anytime { width: 28%; }

  .chooser.hover-anytime .chooser-bg-anytime { right: 28%; }
  .chooser.hover-anytime .chooser-bg-recruit { left: 72%; }
  .chooser.hover-recruit .chooser-bg-anytime { right: 72%; }
  .chooser.hover-recruit .chooser-bg-recruit { left: 28%; }

  .chooser.hover-anytime .chooser-divider,
  .chooser.hover-anytime .chooser-divider-orb { left: 72%; }
  .chooser.hover-recruit .chooser-divider,
  .chooser.hover-recruit .chooser-divider-orb { left: 28%; }

  /* Hug the outer edge so videos clear the text further on small screens. */
  .hvr-anytime .hvr-item { left: 3%; }
  .hvr-recruit .hvr-item { right: 3%; }

  .chooser.hover-anytime .chooser-half.anytime:hover .chooser-content {
    transform: translate(80px, -6px);
  }
  .chooser.hover-recruit .chooser-half.recruit:hover .chooser-content {
    transform: translate(-80px, -6px);
  }
}
@media (max-width: 920px) {
  .hvr { display: none; }
}


/* ============================================================
   MOBILE POLISH (≤640px) — comprehensive phone responsive layer
   Sits at the end so it overrides earlier desktop-first rules.
   ============================================================ */

@media (max-width: 640px) {
  /* ── Global ── */
  html, body { -webkit-text-size-adjust: 100%; }
  body { font-size: 15px; }

  /* ── Chooser splash ── */
  .chooser { display: flex !important; flex-direction: column !important; position: static !important; inset: auto !important; height: auto !important; min-height: 100vh; overflow-y: auto !important; }
  .chooser-half {
    position: relative !important;
    width: 100% !important; height: auto !important; min-height: 50vh !important;
    left: auto !important; right: auto !important; top: auto !important; bottom: auto !important;
    padding: 56px 22px !important;
  }
  .chooser-half.anytime .chooser-content,
  .chooser-half.recruit .chooser-content {
    margin: 0 auto !important; max-width: 100% !important; padding: 0 !important;
    align-items: center !important; text-align: center !important;
  }
  .chooser-bg-anytime, .chooser-bg-recruit {
    position: absolute !important;
    left: 0 !important; right: 0 !important; width: 100% !important;
  }
  .chooser-bg-anytime { top: 0 !important; bottom: auto !important; height: 50vh !important; }
  .chooser-bg-recruit { top: 50vh !important; bottom: auto !important; height: 50vh !important; }
  .chooser-divider { left: 0 !important; right: 0 !important; top: 50vh !important; bottom: auto !important; width: 100% !important; height: 1px !important; transform: translateY(-0.5px); }
  /* Hide center wordmark (ANYTIME · TAKTUME · RECRUIT) and OR orb on phones —
     they collide with the stacked halves and add noise without value. */
  .chooser-wordmark    { display: none !important; }
  .chooser-divider-orb { display: none !important; }
  .chooser-side { padding: 40px 22px !important; min-height: 50vh; }
  .chooser-h1 { font-size: clamp(1.7rem, 8vw, 2.4rem) !important; line-height: 1.05 !important; }
  .chooser-sub { font-size: 0.92rem !important; margin-top: 10px !important; }
  .chooser-bullets { font-size: 0.78rem !important; gap: 10px !important; flex-wrap: wrap; }
  .chooser-bullets li { white-space: nowrap; }
  .chooser-cta-row { flex-direction: column !important; gap: 10px !important; align-items: stretch !important; }
  .chooser-cta-row > * { width: 100%; justify-content: center; }
  .chooser-mark { transform: scale(0.78); }
  /* Hide heavy bg motion on phone for perf */
  #anytime-bokeh { opacity: 0.55; }
  .chooser-nodes svg { opacity: 0.5; }

  /* ── Shared nav ── */
  .lp-nav { padding: 12px 16px !important; }
  .lp-nav-links { display: none !important; }
  .lp-brand-name { font-size: 0.95rem !important; }
  .lp-nav-actions { gap: 6px !important; }
  .lp-nav-back { padding: 8px 10px !important; font-size: 0.74rem !important; }
  .lp-cta, .r-nav-cta, .a-nav-cta {
    padding: 10px 14px !important; font-size: 0.78rem !important; min-height: 40px;
  }

  /* ── Recruit hero ── */
  .r-trust-banner { font-size: 0.6rem !important; padding: 6px 12px !important; }
  .r-hero-v2 { padding: 80px 18px 36px !important; }
  .r-hero-grid-layout { grid-template-columns: 1fr !important; gap: 28px !important; }
  .r-hero-h1 { font-size: clamp(1.9rem, 9vw, 2.7rem) !important; line-height: 1.05 !important; }
  .r-hero-sub, .r-hero-deck { font-size: 0.94rem !important; }
  .r-hero-cta-row { flex-direction: column !important; align-items: stretch !important; gap: 10px !important; }
  .r-hero-cta-row > * { width: 100%; justify-content: center; }
  .r-hero-stats, .r-hero-trust { gap: 12px !important; flex-wrap: wrap; font-size: 0.74rem !important; }
  .r-world-map-wrap, .r-hero-visual { min-height: 320px !important; }
  .r-world-map-wrap svg { max-width: 100%; height: auto; }

  /* ── Recruit content sections ── */
  .recruit-page section,
  .r-pilot-offer, .r-pricing-section, .r-final-cta, .r-security-strip,
  .r-roi-section, .r-howit-section, .r-features-section, .r-ats-section,
  .vroadmap-section { padding: 56px 18px !important; }
  .r-section-title, .r-pilot-title, .r-final-cta h2, .recruit-page h2 {
    font-size: clamp(1.6rem, 6.5vw, 2.2rem) !important; line-height: 1.1 !important;
  }
  .r-roi-grid, .r-features-grid, .r-howit-grid, .r-ats-grid,
  .vroadmap-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
  .vrc-row { grid-template-columns: 28px 1fr 44px !important; gap: 8px !important; padding: 12px !important; }
  .vrc-path { grid-column: 1 / -1 !important; }

  /* ── Anytime hero V4 ── */
  .any-hero-v4 .any-hero-grid, .any-hero-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .any-hero-right, .any-hero-right-v4 { min-height: 0 !important; height: auto !important; }
  .any-hero-h1, .ahv4-h1 { font-size: clamp(2rem, 9.5vw, 2.8rem) !important; line-height: 1.04 !important; }
  .any-hero-sub, .ahv4-sub { font-size: 0.96rem !important; }
  .any-hero-cta-row, .ahv4-cta-row { flex-direction: column !important; align-items: stretch !important; gap: 10px !important; }
  .any-hero-cta-row > *, .ahv4-cta-row > * { width: 100%; justify-content: center; }
  .any-hero-stats, .ahv4-trust, .ahv4-stats { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
  .ahs-cell, .ahs-l, .ahs-v { font-size: 0.78rem !important; }

  /* ── Anytime sections / grids ── */
  .anytime-page section { padding: 56px 18px !important; }
  .modes-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
  .pricing-grid, .pricing-grid-3 { grid-template-columns: 1fr !important; gap: 14px !important; }
  .testi-grid, .pain-grid, .how-grid, .how-3-grid, .gamify-row, .fam-grid, .adv-grid, .outc-grid, .diff-one-grid {
    grid-template-columns: 1fr !important; gap: 14px !important;
  }
  .trust-row, .trust-row-v5 { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
  .trust-cell { border-right: none !important; padding: 8px !important; }
  .risk-row { grid-template-columns: repeat(2, 1fr) !important; }
  .anytime-page h2, .any-section-title { font-size: clamp(1.6rem, 6.5vw, 2.2rem) !important; line-height: 1.1 !important; }

  /* ── Cards ── */
  .price-card, .mode-card, .testi-card, .pain-card, .how-card, .gamify-card, .vslot, .fam-card,
  .r-roi-card, .r-feature-card, .r-howit-card, .r-ats-card { padding: 22px 18px !important; }

  /* ── Demo / coaching panels ── */
  .demo-panel, .any-coaching-grid, .any-scorecard-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  .demo-orb-pane { min-height: 280px !important; }

  /* ── Footers / referral ── */
  .referral-card { grid-template-columns: 1fr !important; padding: 24px !important; }
  footer, .r-footer, .a-footer { text-align: center; }
  footer .footer-grid, .r-footer-grid, .a-footer-grid { grid-template-columns: 1fr !important; gap: 20px !important; text-align: left; }

  /* ── Hover-only reveals: kill on touch ── */
  .hvr { display: none !important; }

  /* ── Buttons & CTAs everywhere ── */
  button, .btn, a.cta, [role="button"] { min-height: 44px; }
}

/* Small phone (≤380px) extra trims */
@media (max-width: 380px) {
  .chooser-h1 { font-size: 1.55rem !important; }
  .r-hero-h1, .any-hero-h1, .ahv4-h1 { font-size: 1.85rem !important; }
  .lp-cta, .r-nav-cta, .a-nav-cta { padding: 9px 12px !important; font-size: 0.74rem !important; }
  .lp-nav-back { padding: 7px 9px !important; font-size: 0.7rem !important; }
}

/* ============================================================
   STICKY MOBILE CTA BAR (≤640px only)
   Persistent bottom-anchored CTA for thumb reach. Different
   colour + copy per side; hidden on desktop, hidden on chooser.
   ============================================================ */
.mobile-cta-bar { display: none; }

@media (max-width: 640px) {
  .mobile-cta-bar {
    display: flex;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 14px 18px;
    padding-bottom: calc(14px + env(safe-area-inset-bottom, 0px));
    font-family: 'Geist', sans-serif;
    font-size: 0.98rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    text-decoration: none;
    z-index: 9999;
    min-height: 56px;
    box-shadow: 0 -8px 32px rgba(0,0,0,0.45), 0 -1px 0 rgba(255,255,255,0.06) inset;
    transition: transform 0.2s ease;
    will-change: transform;
  }
  .mobile-cta-bar:active { transform: translateY(1px); }
  .mobile-cta-anytime {
    background: linear-gradient(135deg, #a855f7 0%, #d946ef 100%);
    color: #ffffff;
  }
  .mobile-cta-recruit {
    background: linear-gradient(135deg, #00e5ff 0%, #14b8a6 100%);
    color: #051418;
  }
  .mcta-arrow {
    font-size: 1.1em;
    line-height: 1;
    transition: transform 0.2s ease;
  }
  .mobile-cta-bar:hover .mcta-arrow { transform: translateX(3px); }

  /* Reserve space at the bottom of the page so the sticky bar
     doesn't cover the last section's content / footer copy. */
  .anytime-page, .recruit-page {
    padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px));
  }

  /* New-element mobile polish */
  .any-pricing-bundles {
    margin-top: 14px;
    font-size: 0.78rem;
    line-height: 1.45;
    padding: 0 8px;
  }
  .vid-ph { border-radius: 12px; }
  .vid-ph.vid-ph-live > video { border-radius: 12px; }

  /* Kicker breathes better when the text wraps to two lines */
  .any-hero-kicker, .r-hero-kicker {
    line-height: 1.4;
  }

  /* Recruit hero microstats — wrap nicely on tight screens */
  .r-hero-microstats {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px !important;
    font-size: 0.84rem;
  }

  /* Final-CTA section: extra bottom room above sticky bar */
  .any-final-v2, .r-final-cta { padding-bottom: 88px !important; }
}

/* Very tight phones — slightly smaller sticky bar text */
@media (max-width: 380px) {
  .mobile-cta-bar { font-size: 0.9rem; padding: 12px 14px; min-height: 52px; }
}

/* ============================================================
   IN-PAGE SIGNUP MODALS — Beta (Anytime) + Pilot (Recruit)
   ============================================================ */
.signup-modal {
  position: fixed; inset: 0;
  z-index: 10000;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: signupFadeIn 0.18s ease-out;
}
@keyframes signupFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.signup-backdrop {
  position: absolute; inset: 0;
  background: rgba(5, 4, 12, 0.72);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  cursor: pointer;
}
.signup-card {
  position: relative;
  max-width: 540px;
  width: 100%;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  background: linear-gradient(180deg, #14091e 0%, #0a0612 100%);
  border-radius: 18px;
  padding: 36px 32px 28px;
  box-shadow: 0 30px 80px -10px rgba(0,0,0,0.7);
  font-family: 'Geist', sans-serif;
  animation: signupCardIn 0.22s cubic-bezier(0.22, 0.7, 0.32, 1);
}
.signup-modal-anytime .signup-card {
  border: 1px solid rgba(168,85,247,0.32);
  box-shadow: 0 30px 80px -10px rgba(0,0,0,0.7),
              0 0 60px rgba(168,85,247,0.15);
}
.signup-modal-recruit .signup-card {
  border: 1px solid rgba(0,229,255,0.32);
  box-shadow: 0 30px 80px -10px rgba(0,0,0,0.7),
              0 0 60px rgba(0,229,255,0.15);
  background: linear-gradient(180deg, #061318 0%, #02080c 100%);
}
@keyframes signupCardIn {
  from { opacity: 0; transform: translateY(12px) scale(0.985); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}
.signup-close {
  position: absolute; top: 14px; right: 14px;
  width: 36px; height: 36px;
  border: none; background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.7);
  font-size: 1.4rem; line-height: 1; cursor: pointer;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s ease, color 0.15s ease;
}
.signup-close:hover { background: rgba(255,255,255,0.12); color: #fff; }

.signup-head { margin-bottom: 24px; }
.signup-head .any-hero-kicker,
.signup-head .r-hero-kicker { margin-bottom: 14px; }
.signup-h {
  font-family: 'Geist', sans-serif;
  font-size: 1.6rem; font-weight: 700; line-height: 1.15;
  color: #ffffff;
  margin: 0 0 8px;
  letter-spacing: -0.01em;
}
.signup-h em { font-style: normal; color: #c4a8ff; }
.signup-modal-recruit .signup-h em { color: #7fe9ff; }
.signup-sub {
  margin: 0;
  font-size: 0.92rem; line-height: 1.55;
  color: rgba(230, 220, 245, 0.78);
}

.signup-form { display: flex; flex-direction: column; gap: 14px; }
.signup-field { display: flex; flex-direction: column; gap: 6px; }
.signup-label {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.7rem; font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(230, 220, 245, 0.6);
}
.signup-label .signup-opt {
  font-style: normal; text-transform: none;
  font-size: 0.92em; letter-spacing: 0;
  color: rgba(230, 220, 245, 0.4);
  margin-left: 4px;
}
.signup-field input,
.signup-field select,
.signup-field textarea {
  width: 100%;
  padding: 12px 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 10px;
  color: #fff;
  font-family: 'Geist', sans-serif;
  font-size: 0.95rem;
  line-height: 1.4;
  outline: none;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.signup-field textarea { resize: vertical; min-height: 80px; }
.signup-field input::placeholder,
.signup-field textarea::placeholder { color: rgba(230, 220, 245, 0.32); }
.signup-modal-anytime .signup-field input:focus,
.signup-modal-anytime .signup-field select:focus,
.signup-modal-anytime .signup-field textarea:focus {
  border-color: rgba(168,85,247,0.6);
  background: rgba(168,85,247,0.06);
}
.signup-modal-recruit .signup-field input:focus,
.signup-modal-recruit .signup-field select:focus,
.signup-modal-recruit .signup-field textarea:focus {
  border-color: rgba(0,229,255,0.6);
  background: rgba(0,229,255,0.05);
}
.signup-field select { cursor: pointer; appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, rgba(230,220,245,0.5) 50%),
                    linear-gradient(135deg, rgba(230,220,245,0.5) 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(50% - 2px), calc(100% - 13px) calc(50% - 2px);
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 36px;
}
/* Native dropdown list — force dark background + white text so options
   are readable. Browsers ignore most CSS on <option>, but background-color
   + color work in Chrome/Firefox/Edge. */
.signup-field select option {
  background: #14091e;
  color: #ffffff;
}
.signup-modal-recruit .signup-field select option {
  background: #061318;
  color: #ffffff;
}

.signup-submit {
  margin-top: 8px;
  justify-content: center;
  width: 100%;
}
.signup-submit:disabled { opacity: 0.6; cursor: not-allowed; }

.signup-error {
  padding: 12px 14px;
  background: rgba(239, 68, 68, 0.10);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: 10px;
  color: #fca5a5;
  font-size: 0.86rem;
  line-height: 1.5;
}
.signup-error a { color: #fff; text-decoration: underline; }

.signup-fine {
  margin: 4px 0 0;
  font-size: 0.76rem;
  color: rgba(230, 220, 245, 0.45);
  text-align: center;
  line-height: 1.5;
}

.signup-consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  margin: 2px 0;
}
.signup-consent input[type="checkbox"] {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  margin-top: 2px;
  cursor: pointer;
  accent-color: #a855f7;
}
.signup-modal-recruit .signup-consent input[type="checkbox"] {
  accent-color: #00e5ff;
}
.signup-consent-text {
  font-size: 0.78rem;
  color: rgba(230, 220, 245, 0.5);
  line-height: 1.5;
}
.signup-consent-text em {
  font-style: normal;
  color: rgba(230, 220, 245, 0.32);
}

.signup-success { text-align: center; padding: 16px 0 8px; }
.signup-success-mark {
  width: 56px; height: 56px;
  margin: 0 auto 16px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem;
  background: linear-gradient(135deg, #22c55e, #16a34a);
  color: #fff;
  font-weight: 700;
}
.signup-modal-recruit .signup-success-mark {
  background: linear-gradient(135deg, #00e5ff, #14b8a6);
  color: #051418;
}
.signup-success-h {
  font-family: 'Geist', sans-serif;
  font-size: 1.35rem; font-weight: 700;
  color: #fff;
  margin: 0 0 10px;
}
.signup-success p {
  color: rgba(230, 220, 245, 0.78);
  font-size: 0.94rem; line-height: 1.55;
  margin: 0 0 20px;
}

/* Mobile — full-screen modal */
@media (max-width: 640px) {
  .signup-modal { padding: 0; align-items: stretch; }
  .signup-card {
    max-width: 100%;
    max-height: 100vh;
    border-radius: 0;
    padding: 56px 22px 28px;
    padding-bottom: calc(28px + env(safe-area-inset-bottom, 0px));
    border: none !important;
  }
  .signup-h { font-size: 1.4rem; }
  .signup-close { top: 10px; right: 10px; }
}
