/* =========================================================================
   COACH OS by 9 Catalyst — shared stylesheet (v3: BRIGHT editorial)
   Theme: warm paper #f5f2ec + near-black text, indigo accent #5b54e6 + teal secondary. Oversized uppercase display type. Live abstract 3D hero motif.
   Fonts: Barlow Condensed + Barlow (athletic) + IBM Plex Mono (labels/clock).
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&family=Space+Grotesk:wght@500;700&display=swap');

/* ----------------------------------------------------------------- tokens */
:root {
  /* surfaces — clean cool BRIGHT (mature SaaS) */
  --bg: #f7f8fb;          /* cool off-white page */
  --bg-deep: #eef0f5;     /* deeper cool tint (footer/marquee/panels) */
  --surface: #ffffff;     /* cards */
  --surface-2: #f1f3f7;   /* nested surface */
  --surface-3: #e7eaf1;   /* hover / chips */
  --line: rgba(15,18,28,.12);
  --line-2: rgba(15,18,28,.06);

  /* text — cool near-black */
  --text: #0e1117;        /* primary (~16:1 on bg) */
  --text-mut: #565d6b;    /* secondary (~7:1) */
  --text-dim: #98a0ae;    /* tertiary */

  /* CLAY: vibrant violet primary + playful colour palette */
  --accent: #6d5efc;
  --accent-bright: #8b7cff;
  --accent-deep: #5a48e0;
  --amber: #0d9488;       /* teal secondary (var name kept for reuse) */
  --accent-soft: rgba(109,94,252,.11);
  --amber-soft: rgba(13,148,136,.12);
  --on-accent: #ffffff;
  --grad: linear-gradient(135deg, #6d5efc 0%, #9b5cf6 55%, #c45cf0 100%); /* playful violet→magenta */
  /* clay multi-colour accents (used per section / per card) */
  --c-violet: #6d5efc; --c-blue: #2f7cff; --c-pink: #ec4899; --c-orange: #fb7a1e;
  --c-green: #16b364; --c-yellow: #f5b400; --c-cyan: #10b3d6; --c-red: #f5455c;

  /* semantic */
  --success: #0f9d58;
  --success-soft: rgba(15,157,88,.13);
  --warn: #b45309;

  /* type */
  --font-display: 'Inter', system-ui, -apple-system, sans-serif;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;
  --font-mono: 'IBM Plex Mono', ui-monospace, 'SF Mono', monospace;

  /* spacing (4/8) */
  --s-1: 4px; --s-2: 8px; --s-3: 12px; --s-4: 16px; --s-5: 24px;
  --s-6: 32px; --s-7: 48px; --s-8: 64px; --s-9: 96px; --s-10: 128px;

  /* radius */
  --r-sm: 9px; --r-md: 16px; --r-lg: 24px; --r-xl: 32px; --r-pill: 999px;

  /* elevation (dark: glow + depth) */
  --sh-1: 0 1px 2px rgba(15,18,28,.07);
  --sh-2: 0 12px 30px rgba(15,18,28,.09);
  --sh-3: 0 24px 60px rgba(15,18,28,.13);
  --sh-accent: 0 12px 30px rgba(91,84,230,.30);

  --container: 1200px;
  --nav-h: 68px;
  --z-base: 0; --z-raised: 10; --z-sticky: 40; --z-overlay: 100; --z-top: 1000;

  --t-fast: 150ms cubic-bezier(.4,0,.2,1);
  --t: 220ms cubic-bezier(.4,0,.2,1);
  --t-slow: 300ms cubic-bezier(.16,1,.3,1);
}

/* ------------------------------------------------------------------ reset */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: var(--font-body);
  font-size: 17px; line-height: 1.65;
  color: var(--text); background: var(--bg);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  overflow-x: clip; /* clip (not hidden) so <body> never becomes the scroll container */
}
html { overflow-x: clip; }
img, svg { display: block; max-width: 100%; }
img { height: auto; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul { list-style: none; padding: 0; }
::selection { background: var(--accent); color: var(--on-accent); }
:focus-visible { outline: 3px solid var(--accent); outline-offset: 3px; border-radius: 4px; }

/* ------------------------------------------------------------- typography */
h1,h2,h3,h4 { font-family: var(--font-display); line-height: 1.1; letter-spacing: -.02em; font-weight: 700; color: var(--text); text-wrap: balance; }
h1 { font-size: clamp(2.5rem, 5.2vw, 4.1rem); font-weight: 800; line-height: 1.04; letter-spacing: -.035em; }
h2 { font-size: clamp(1.85rem, 3.4vw, 2.85rem); font-weight: 700; letter-spacing: -.03em; line-height: 1.08; }
h3 { font-size: clamp(1.25rem, 1.9vw, 1.55rem); letter-spacing: -.02em; font-weight: 600; }
h4 { font-size: 1.08rem; letter-spacing: -.01em; font-weight: 600; }
p  { color: var(--text-mut); }
/* Restated-hero line: heading-level prominence without being in the heading hierarchy. */
.band-restate { font-family: var(--font-display); font-size: clamp(1.85rem, 3.4vw, 2.85rem); font-weight: 700; letter-spacing: -.03em; line-height: 1.08; color: var(--text); text-wrap: balance; margin: 12px 0 16px; }
strong { color: var(--text); font-weight: 600; }

/* editorial section numbering */
.s-num { font-family: var(--font-mono); font-size: .72rem; font-weight: 500; letter-spacing: .1em; color: var(--text-dim); display: inline-flex; align-items: center; gap: 10px; }
.s-num::before { content: ''; width: 28px; height: 1px; background: var(--accent); display: inline-block; }

.eyebrow { font-family: var(--font-mono); font-size: .74rem; font-weight: 500; letter-spacing: .18em; text-transform: uppercase; color: var(--text-dim); display: inline-flex; align-items: center; gap: var(--s-2); }
.eyebrow::before { content: ''; width: 22px; height: 1px; background: var(--accent); }
.eyebrow.amber { color: var(--amber); }
.lead { font-size: clamp(1.05rem, 1.6vw, 1.3rem); color: var(--text-mut); max-width: 60ch; }
.mono { font-family: var(--font-mono); }

/* --------------------------------------------------------------- layout */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--s-5); }
section { padding-block: clamp(var(--s-8), 9vw, var(--s-10)); position: relative; }
.section-tint { background: var(--surface); }
.section-dark { background: var(--bg-deep); }
.section-head { max-width: 64ch; margin-bottom: var(--s-7); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head h2 { margin-top: var(--s-3); }
.section-head p { margin-top: var(--s-4); font-size: 1.12rem; }

.grid { display: grid; gap: var(--s-5); }
@media (min-width: 760px) { .g-2 { grid-template-columns: repeat(2,1fr); } .g-3 { grid-template-columns: repeat(3,1fr); } .g-4 { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1040px) { .g-4 { grid-template-columns: repeat(4,1fr); } }

/* --------------------------------------------------------------- buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2); font-family: var(--font-body); font-weight: 700; font-size: .98rem; letter-spacing: -.005em; padding: 14px 24px; border-radius: var(--r-pill); min-height: 48px; transition: transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow var(--t), filter var(--t), background var(--t), color var(--t), border-color var(--t); white-space: nowrap; }
.btn:active { transform: translateY(0) scale(.97); }
.btn-primary { background: var(--grad); color: #fff; box-shadow: 0 8px 22px -6px rgba(109,94,252,.6); }
.btn-primary:hover { transform: translateY(-2px) scale(1.03); filter: saturate(1.1) brightness(1.04); box-shadow: 0 14px 32px -8px rgba(155,92,246,.6); }
.btn-dark { background: var(--surface-3); color: var(--text); border: 1px solid var(--line); }
.btn-dark:hover { background: var(--surface-2); transform: translateY(-2px); }
.btn-ghost { background: transparent; color: var(--text); border: 1.5px solid var(--line); }
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-2px); }
.btn-ghost.on-dark { color: var(--text); border-color: var(--line); }
.btn-ghost.on-dark:hover { border-color: var(--accent); color: var(--accent); }
.btn-lg { padding: 17px 34px; font-size: 1.08rem; min-height: 56px; }
.btn-sm { padding: 10px 18px; font-size: .9rem; min-height: 42px; }
.btn-block { width: 100%; }
.btn-row { display: flex; flex-wrap: wrap; gap: var(--s-3); }

/* live-demo button = highest emphasis, pulsing online dot */
.btn-live { background: var(--grad); color: #fff; box-shadow: 0 8px 22px -6px rgba(109,94,252,.6); position: relative; }
.btn-live:hover { transform: translateY(-2px) scale(1.03); filter: saturate(1.1) brightness(1.04); box-shadow: 0 14px 32px -8px rgba(155,92,246,.6); }
.live-dot { width: 9px; height: 9px; border-radius: 50%; background: #15a05a; position: relative; }
.live-dot::after { content: ''; position: absolute; inset: 0; border-radius: 50%; background: #15a05a; animation: pulse-dot 1.8s ease-out infinite; }
@keyframes pulse-dot { 0% { box-shadow: 0 0 0 0 rgba(21,160,90,.5);} 70% { box-shadow: 0 0 0 9px rgba(21,160,90,0);} 100% { box-shadow: 0 0 0 0 rgba(21,160,90,0);} }

/* --------------------------------------------------------- pills / chips */
.pill { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: .72rem; font-weight: 500; letter-spacing: .04em; padding: 6px 12px; border-radius: var(--r-pill); background: var(--surface-3); color: var(--text); border: 1px solid var(--line-2); }
.pill svg { width: 14px; height: 14px; color: var(--accent); }
.pill.on-dark { background: rgba(20,18,14,.05); color: var(--text); }
.pill.accent { background: var(--accent-soft); color: var(--accent-bright); border-color: rgba(91,84,230,.3); }
/* clay-coloured trust pills (hero) */
.pill.violet { background: rgba(109,94,252,.12); color: var(--accent-deep); border-color: rgba(109,94,252,.28); }
.pill.violet svg { color: var(--c-violet); }
.pill.green { background: rgba(22,179,100,.13); color: #0e8f4f; border-color: rgba(22,179,100,.30); }
.pill.green svg { color: var(--c-green); }
.pill.blue { background: rgba(47,124,255,.12); color: #1f64e6; border-color: rgba(47,124,255,.28); }
.pill.blue svg { color: var(--c-blue); }
.pill.violet:hover, .pill.green:hover, .pill.blue:hover { transform: translateY(-2px); transition: transform var(--t-fast); }
/* hero badge — vibrant gradient pill replacing the eyebrow */
.hero-tag { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono); font-size: .73rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--accent-deep); padding: 8px 16px 8px 12px; border-radius: var(--r-pill); background: linear-gradient(118deg, rgba(109,94,252,.14), rgba(196,92,240,.13) 52%, rgba(47,124,255,.12)); border: 1px solid rgba(109,94,252,.26); box-shadow: 0 10px 26px -14px rgba(109,94,252,.7), inset 0 1px 0 rgba(255,255,255,.5); }
.hero-tag .ht-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--c-green); position: relative; flex: none; box-shadow: 0 0 0 4px rgba(22,179,100,.18); }
.hero-tag .ht-dot::after { content: ''; position: absolute; inset: 0; border-radius: 50%; background: var(--c-green); animation: pulse-dot 1.8s ease-out infinite; }
.chip { display: inline-flex; align-items: center; gap: 6px; font-size: .82rem; font-weight: 600; padding: 7px 13px; border-radius: var(--r-pill); background: var(--surface-2); border: 1px solid var(--line); color: var(--text-mut); }
.chip svg { width: 15px; height: 15px; color: var(--accent); flex: none; }
.badge-cap { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: .74rem; font-weight: 600; letter-spacing: .04em; color: var(--amber); background: var(--amber-soft); padding: 8px 14px; border-radius: var(--r-pill); }
/* section note — twin training lead-time pill */
.s-train { display: inline-flex; align-items: center; gap: 8px; margin-top: 18px; font-family: var(--font-mono); font-size: .72rem; font-weight: 500; letter-spacing: .02em; color: var(--accent-deep); background: var(--accent-soft); border: 1px solid rgba(109,94,252,.26); padding: 7px 14px; border-radius: var(--r-pill); }
.s-train svg { width: 14px; height: 14px; color: var(--accent); flex: none; }

/* ------------------------------------------------------------------- nav */
.nav { position: sticky; top: 0; z-index: var(--z-sticky); background: rgba(247,248,251,.72); backdrop-filter: saturate(180%) blur(18px); border-bottom: 1px solid var(--line-2); transition: box-shadow var(--t), background var(--t), border-color var(--t); }
.nav.scrolled { box-shadow: 0 8px 30px rgba(15,18,28,.07); background: rgba(247,248,251,.9); border-bottom-color: var(--line); }
.nav-inner { height: var(--nav-h); display: flex; align-items: center; justify-content: space-between; gap: var(--s-5); }
.logo { display: inline-flex; align-items: center; gap: 11px; font-family: var(--font-display); font-weight: 800; font-size: 1.16rem; letter-spacing: -.01em; color: var(--text); }
.logo .mark { width: 32px; height: 32px; flex: none; border-radius: 9px; box-shadow: 0 6px 16px -6px rgba(109,94,252,.55); transition: transform var(--t); }
.logo:hover .mark { transform: rotate(-6deg) scale(1.06); }
.logo small { font-family: var(--font-mono); font-size: .6rem; font-weight: 600; letter-spacing: .22em; color: var(--accent); display: block; line-height: 1; margin-top: 3px; }
.nav-links { display: none; align-items: center; gap: var(--s-2); }
.nav-links a { font-weight: 600; font-size: .94rem; color: var(--text-mut); white-space: nowrap; padding: 8px 14px; border-radius: var(--r-pill); transition: color var(--t-fast), background var(--t-fast); }
.nav-links a:hover { color: var(--accent-deep); background: var(--accent-soft); }
.nav-links a[aria-current="page"] { color: var(--text); }
.nav-cta { display: flex; align-items: center; gap: var(--s-3); }
.nav-toggle { display: inline-flex; width: 44px; height: 44px; align-items: center; justify-content: center; border-radius: var(--r-sm); color: var(--text); }
.nav-toggle svg { width: 24px; height: 24px; }
@media (min-width: 1080px) { .nav-links { display: flex; } .nav-toggle { display: none; } }
.mobile-menu { display: none; flex-direction: column; gap: var(--s-2); padding: var(--s-4) var(--s-5) var(--s-6); border-bottom: 1px solid var(--line); background: var(--bg); }
.mobile-menu.open { display: flex; }
.mobile-menu a { padding: 12px 8px; font-weight: 600; border-radius: var(--r-sm); color: var(--text); }
.mobile-menu a:hover { background: var(--surface-2); }
@media (min-width: 1080px) { .mobile-menu { display: none !important; } }

/* ------------------------------------------------------------- EKG motif */
.ekg { width: 100%; height: 38px; color: var(--accent); overflow: visible; }
.ekg path { fill: none; stroke: currentColor; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.ekg .lead-line { stroke-dasharray: 1400; stroke-dashoffset: 1400; animation: ekg-draw 3.4s cubic-bezier(.4,0,.2,1) infinite; }
@keyframes ekg-draw { 0% { stroke-dashoffset: 1400; } 55% { stroke-dashoffset: 0; } 100% { stroke-dashoffset: -1400; } }
.divider-ekg { padding-block: var(--s-6); }
.divider-ekg .ekg { height: 30px; opacity: .9; }

/* ------------------------------------------------------- 3D WebGL hero */
.hero-cinematic { position: relative; min-height: 100svh; display: flex; align-items: center; background:
  radial-gradient(720px 560px at 80% 6%, rgba(109,94,252,.22), transparent 60%),
  radial-gradient(640px 500px at 99% 52%, rgba(47,124,255,.18), transparent 60%),
  radial-gradient(560px 460px at 8% 84%, rgba(236,72,153,.13), transparent 62%),
  radial-gradient(560px 460px at 58% 98%, rgba(22,179,100,.13), transparent 62%),
  radial-gradient(520px 440px at 92% 90%, rgba(251,122,30,.14), transparent 60%),
  radial-gradient(620px 520px at 30% 18%, rgba(196,92,240,.10), transparent 60%),
  var(--bg);
  overflow: hidden; padding-top: calc(var(--nav-h) + 36px); padding-bottom: clamp(56px, 6vw, 96px); color: var(--text); }
#hero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; display: block; }
#hero-canvas.hero-static { background-size: contain; background-position: center; background-repeat: no-repeat; }
.hero-cinematic .container { position: relative; z-index: 2; width: 100%; }
.hero-grid { display: grid; gap: var(--s-8); align-items: center; }
@media (min-width: 1000px) { .hero-grid { grid-template-columns: 1fr 1fr; gap: clamp(var(--s-8), 6vw, 104px); } }
.hero h1 { margin: var(--s-5) 0 var(--s-6); }
.hero h1 .hl { color: var(--accent); }
.hero h1 .hl-amber { color: var(--amber); }
.hero .lead { margin-bottom: var(--s-6); line-height: 1.6; }
.hero-badges { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-top: var(--s-5); }
/* secondary CTA — quiet text link with arrow, so it doesn't compete with the primary */
.hero-copy .btn-row { align-items: center; }
.btn-link-secondary { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; font-size: 1rem; color: var(--text-mut); padding: 10px 6px; transition: color var(--t-fast), gap var(--t-fast); }
.btn-link-secondary:hover { color: var(--accent-deep); gap: 9px; }
.btn-link-secondary .bl-arrow { width: 17px; height: 17px; flex: none; transition: transform var(--t-fast); }
.btn-link-secondary:hover .bl-arrow { transform: translateX(2px); }
/* CTA microcopy — small reassurance directly under the buttons */
.btn-microcopy { margin-top: var(--s-3); font-size: .82rem; color: var(--text-dim); }
/* outcome stat — subtle credibility line near the social proof */
.hero-stat { margin-top: var(--s-3); font-size: .9rem; color: var(--text-mut); }
.hero-stat .hs-num { font-family: var(--font-display); font-weight: 800; font-size: 1.05rem; color: var(--accent-deep); }
/* social-proof line — muted, supports the CTAs */
.hero-social { margin-top: var(--s-5); }
.hs-text { font-size: .84rem; font-weight: 500; color: var(--text-mut); }
/* social-proof micro-line — low-key, supports the CTAs without competing */
.hero-proof { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: var(--s-4); font-size: .84rem; color: var(--text-mut); }
.hero-proof .hp-live { width: 7px; height: 7px; border-radius: 50%; background: var(--c-green); flex: none; box-shadow: 0 0 0 3px rgba(22,179,100,.16); }
.hero-proof a { color: var(--accent-deep); font-weight: 600; text-decoration: underline; text-decoration-color: rgba(109,94,252,.3); text-underline-offset: 3px; transition: text-decoration-color var(--t-fast); }
.hero-proof a:hover { text-decoration-color: var(--accent); }

.scroll-cue { position: absolute; left: 50%; bottom: 20px; transform: translateX(-50%); z-index: 3; display: flex; flex-direction: column; align-items: center; gap: 9px; font-family: var(--font-mono); font-size: .58rem; letter-spacing: .22em; text-transform: uppercase; color: var(--text-mut); }
.scroll-cue .line { width: 1.5px; height: 42px; background: rgba(20,18,14,.3); position: relative; overflow: hidden; border-radius: 2px; }
.scroll-cue .line::after { content: ''; position: absolute; inset: -42px 0 auto 0; height: 42px; background: linear-gradient(var(--accent), transparent); animation: cue 2.1s ease-in-out infinite; }
@keyframes cue { 0% { transform: translateY(0); } 100% { transform: translateY(84px); } }

/* ------------------------------------------------- browser frame mockup */
.browser { border-radius: var(--r-lg); background: var(--surface); border: 1px solid var(--line); box-shadow: var(--sh-3); overflow: hidden; }
.browser-bar { display: flex; align-items: center; gap: 10px; padding: 11px 14px; background: var(--surface-2); border-bottom: 1px solid var(--line); }
.browser-dots { display: flex; gap: 6px; flex: none; }
.browser-dots i { width: 11px; height: 11px; border-radius: 50%; display: block; }
.browser-dots i:nth-child(1){ background:#ff5f57; } .browser-dots i:nth-child(2){ background:#febc2e; } .browser-dots i:nth-child(3){ background:#28c840; }
.browser-url { flex: 1; display: flex; align-items: center; gap: 8px; background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-pill); padding: 6px 14px; font-family: var(--font-mono); font-size: .76rem; color: var(--text-mut); min-width: 0; }
.browser-url svg { width: 13px; height: 13px; color: var(--success); flex: none; }
.browser-url span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.browser-body { background: var(--surface); }

.site-mock { position: relative; background: linear-gradient(160deg, #ffffff, #eef0f5); min-height: 330px; padding: var(--s-6); color: var(--text); }
.site-mock .sm-eyebrow { font-family: var(--font-mono); font-size: .64rem; letter-spacing: .2em; color: var(--accent); text-transform: uppercase; }
.site-mock .sm-h { font-family: var(--font-display); font-weight: 800; font-size: 1.9rem; line-height: 1.05; margin: 10px 0; max-width: min(14ch, 52%); }
.site-mock .sm-p { font-size: .9rem; color: var(--text-mut); max-width: min(30ch, 50%); }
.site-mock .sm-cta { margin-top: 16px; display: inline-flex; font-size: .82rem; font-weight: 700; background: var(--accent); color: var(--on-accent); padding: 9px 16px; border-radius: var(--r-pill); }

/* chat widget */
.chat-widget { position: absolute; right: 14px; bottom: 14px; width: min(220px, 48%); background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); box-shadow: var(--sh-3); overflow: hidden; }
.chat-head { display: flex; align-items: center; gap: 9px; padding: 11px 13px; background: var(--surface); border-bottom: 1px solid var(--line); }
.chat-head .av { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--accent-deep)); color: var(--on-accent); display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: .9rem; flex: none; }
.chat-head .meta { line-height: 1.15; min-width: 0; }
.chat-head .meta b { font-size: .82rem; color: var(--text); font-weight: 700; }
.chat-head .meta span { display: flex; align-items: center; gap: 5px; font-size: .68rem; color: var(--success); font-weight: 600; }
.chat-head .meta span i { width: 6px; height: 6px; border-radius: 50%; background: var(--success); display: block; }
.chat-body { padding: 12px; display: flex; flex-direction: column; gap: 7px; background: var(--surface-2); }
.msg { max-width: 86%; padding: 8px 11px; border-radius: 13px; font-size: .8rem; line-height: 1.4; opacity: 0; transform: translateY(8px); }
.msg.show { opacity: 1; transform: none; transition: opacity .4s ease, transform .4s cubic-bezier(.16,1,.3,1); }
.msg.user { align-self: flex-end; background: var(--accent); color: var(--on-accent); border-bottom-right-radius: 4px; }
.msg.ai { align-self: flex-start; background: var(--surface-3); color: var(--text); border: 1px solid var(--line); border-bottom-left-radius: 4px; }
.msg .tag { display: inline-flex; align-items: center; gap: 5px; margin-top: 6px; font-family: var(--font-mono); font-size: .58rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--accent); }
.msg .tag.amber { color: var(--amber); }
.msg .tag i { width: 5px; height: 5px; border-radius: 50%; background: currentColor; display: block; }
.chat-input { display: flex; align-items: center; gap: 8px; padding: 9px 11px; background: var(--surface); border-top: 1px solid var(--line); }
.chat-input .ph { flex: 1; font-size: .76rem; color: var(--text-dim); }
.chat-input .snd { width: 28px; height: 28px; border-radius: 50%; background: var(--accent); color: var(--on-accent); display: grid; place-items: center; flex: none; }
.chat-input .snd svg { width: 14px; height: 14px; }

/* --------------------------------------------------------------- marquee */
.marquee { background: var(--bg-deep); color: var(--text); padding-block: var(--s-4); overflow: hidden; border-block: 1px solid var(--line-2); }
.marquee-track { display: flex; gap: var(--s-7); white-space: nowrap; width: max-content; animation: marquee 30s linear infinite; }
.marquee-track span { display: inline-flex; align-items: center; gap: 11px; font-family: var(--font-display); font-weight: 600; font-size: 1.15rem; letter-spacing: .01em; color: var(--text); }
.marquee-track span::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--accent); flex: none; }
@keyframes marquee { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee-track { animation: none; flex-wrap: wrap; white-space: normal; justify-content: center; } }

/* ----------------------------------------------------------------- cards */
.card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: var(--s-6); transition: transform var(--t), box-shadow var(--t), border-color var(--t); position: relative; }
.card:hover { transform: translateY(-4px); box-shadow: var(--sh-3); border-color: rgba(91,84,230,.4); }
.card .ic { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: var(--accent-soft); color: var(--accent); margin-bottom: var(--s-4); }
.card .ic svg { width: 23px; height: 23px; }
.card.red-ic .ic { background: var(--amber-soft); color: var(--amber); }
.card h3 { font-size: 1.32rem; margin-bottom: var(--s-2); }
.card p { font-size: .98rem; }
.card-sweep::before { content: ''; position: absolute; inset: 0; border-radius: inherit; padding: 1.5px; background: linear-gradient(120deg, var(--accent), var(--amber), var(--accent)); background-size: 200% 200%; -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; opacity: 0; transition: opacity var(--t); }
.card-sweep:hover::before { opacity: 1; animation: sweep 2.2s linear infinite; }
@keyframes sweep { to { background-position: 200% 0; } }

/* two-door cards */
.door { border-radius: var(--r-xl); padding: var(--s-7); color: var(--text); position: relative; overflow: hidden; display: flex; flex-direction: column; gap: var(--s-4); min-height: 340px; transition: transform var(--t), box-shadow var(--t); border: 1px solid var(--line); }
.door:hover { transform: translateY(-5px); box-shadow: var(--sh-3); }
.door.coach { background: var(--surface); }
.door.client { background: var(--surface); }
.door.coach::after, .door.client::after { content: ''; position: absolute; width: 300px; height: 300px; border-radius: 50%; top: -130px; right: -100px; pointer-events: none; }
.door.coach::after { background: radial-gradient(circle, rgba(91,84,230,.10), transparent 66%); }
.door.client::after { background: radial-gradient(circle, rgba(13,148,136,.10), transparent 66%); }
.door h3 { color: var(--text); font-size: 1.7rem; }
.door p { color: var(--text-mut); }
.door .door-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; position: relative; z-index: 1; }
.door .door-chips .chip { background: rgba(20,18,14,.05); border-color: var(--line); color: var(--text); }
.door .door-link { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; color: var(--accent); margin-top: var(--s-2); position: relative; z-index: 1; }
.door .door-link svg { width: 18px; height: 18px; transition: transform var(--t); }
.door:hover .door-link svg { transform: translateX(4px); }

/* clarity cards */
.clarity { border-left: 4px solid var(--accent); background: var(--surface); border-radius: var(--r-md); padding: var(--s-6); box-shadow: var(--sh-1); }
.clarity.blue { border-left-color: var(--amber); }
.clarity .tag { font-family: var(--font-mono); font-size: .7rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); }
.clarity.blue .tag { color: var(--amber); }
.clarity h3 { margin: 10px 0; }

/* feature lists */
.do-list { display: flex; flex-direction: column; gap: var(--s-3); margin-top: var(--s-4); }
.do-list li { display: flex; gap: 11px; font-size: 1rem; color: var(--text-mut); }
.do-list li strong { color: var(--text); }
.do-list .tick { flex: none; width: 22px; height: 22px; border-radius: 50%; background: var(--accent-soft); color: var(--accent); display: grid; place-items: center; margin-top: 2px; }
.do-list .tick svg { width: 13px; height: 13px; }

/* ------------------------------------------------------ module sections */
.module { display: grid; gap: var(--s-7); align-items: center; }
.module > * { min-width: 0; }
@media (min-width: 980px) { .module { grid-template-columns: 1fr 1.1fr; gap: var(--s-8); } .module.flip .m-visual { order: -1; } }
.m-index { font-family: var(--font-mono); font-size: .8rem; font-weight: 600; color: var(--accent); letter-spacing: .05em; }
.module h2 { font-size: clamp(1.7rem,3vw,2.5rem); margin: var(--s-2) 0 var(--s-3); }

/* ------------------------------------------------ dark product mockups */
.mock { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--sh-3); overflow: hidden; font-size: .85rem; max-width: 100%; }
.mock-top { display: flex; align-items: center; justify-content: space-between; padding: 13px 16px; border-bottom: 1px solid var(--line); background: var(--surface-2); }
.mock-top b { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; color: var(--text); }
.mock-top .mt-pills { display: flex; gap: 6px; }
.mock-pad { padding: 16px; }
.mock-shot { display: block; width: 100%; height: auto; }

.kpi-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; }
@media (min-width:520px){ .kpi-grid { grid-template-columns: repeat(4,1fr); } }
.kpi { background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-md); padding: 13px; }
.kpi .lbl { font-family: var(--font-mono); font-size: .62rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-dim); }
.kpi .val { font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; color: var(--text); margin-top: 4px; font-variant-numeric: tabular-nums; }
.kpi .val.red { color: var(--accent); } .kpi .val.blue { color: var(--amber); } .kpi .val.green { color: var(--success); }
.kpi .delta { font-size: .68rem; font-weight: 600; color: var(--success); }

.feed { margin-top: 14px; display: flex; flex-direction: column; gap: 9px; }
.feed-row { display: flex; align-items: center; gap: 10px; padding: 9px 11px; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-sm); }
.feed-row .fi { width: 28px; height: 28px; border-radius: 7px; display: grid; place-items: center; flex: none; }
.feed-row .fi svg { width: 14px; height: 14px; }
.fi.blue { background: var(--amber-soft); color: var(--amber); } .fi.red { background: var(--accent-soft); color: var(--accent); } .fi.green { background: var(--success-soft); color: var(--success); } .fi.purple { background: rgba(124,58,237,.12); color: #7c3aed; }
.feed-row .ft { flex: 1; min-width: 0; }
.feed-row .ft b { font-size: .82rem; color: var(--text); } .feed-row .ft span { font-size: .72rem; color: var(--text-mut); }
.feed-row time { font-family: var(--font-mono); font-size: .66rem; color: var(--text-dim); }

.kanban { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.kan-col .kc-head { display: flex; align-items: center; justify-content: space-between; font-family: var(--font-mono); font-size: .64rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-dim); padding: 0 2px 8px; }
.kan-col .kc-head .n { background: var(--surface-3); border-radius: var(--r-pill); padding: 1px 7px; }
.lead-card { background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 10px; margin-bottom: 8px; }
.lead-card .lc-top { display: flex; align-items: center; gap: 8px; }
.lead-card .lc-av { width: 24px; height: 24px; border-radius: 50%; background: var(--surface-3); color: var(--text); display: grid; place-items: center; font-size: .68rem; font-weight: 700; flex: none; }
.lead-card b { font-size: .8rem; color: var(--text); }
.lead-card .lc-pills { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 8px; }
.lc-pill { font-size: .62rem; font-weight: 600; padding: 2px 7px; border-radius: var(--r-pill); }
.lc-pill.goal { background: var(--amber-soft); color: var(--amber); }
.lc-pill.inj { background: var(--accent-soft); color: var(--accent); }
.lc-pill.heat { background: rgba(13,148,136,.14); color: var(--amber); }
.col-tint-1 { background: var(--bg-deep); border-radius: var(--r-md); padding: 10px; }

.tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }
.tabs .tab { font-family: var(--font-mono); font-size: .68rem; font-weight: 600; padding: 6px 11px; border-radius: var(--r-pill); background: var(--surface-2); color: var(--text-mut); border: 1px solid var(--line); }
.tabs .tab.active { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.ptable { width: 100%; border-collapse: collapse; font-size: .8rem; table-layout: fixed; }
.ptable th { font-family: var(--font-mono); font-size: .6rem; letter-spacing: .05em; text-transform: uppercase; color: var(--text-dim); text-align: left; padding: 7px 8px; border-bottom: 1px solid var(--line); }
.ptable td { padding: 9px 8px; border-bottom: 1px solid var(--line); color: var(--text); font-variant-numeric: tabular-nums; }
.ptable td.ex { font-weight: 600; }
.ai-strip { display: flex; align-items: center; gap: 9px; margin-top: 12px; padding: 10px 12px; border-radius: var(--r-sm); background: var(--accent-soft); border: 1px dashed rgba(91,84,230,.4); font-size: .78rem; color: var(--text); }
.ai-strip svg { width: 16px; height: 16px; color: var(--accent); flex: none; }
.macro-row { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }
.macro { flex: 1; min-width: 70px; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 8px 10px; }
.macro .mk { font-family: var(--font-mono); font-size: .58rem; text-transform: uppercase; letter-spacing: .05em; color: var(--text-dim); }
.macro .mv { font-family: var(--font-display); font-weight: 700; font-size: 1.1rem; color: var(--text); }

.tier-row { display: grid; gap: 12px; }
@media (min-width:560px){ .tier-row { grid-template-columns: repeat(3,1fr); } }
.tier { background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-md); padding: 14px; position: relative; }
.tier.best { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), var(--sh-2); }
.tier .tn { font-family: var(--font-mono); font-size: .6rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-dim); }
.tier .tp { font-family: var(--font-display); font-weight: 800; font-size: 1.6rem; margin: 4px 0; font-variant-numeric: tabular-nums; color: var(--text); }
.tier .tf { font-size: .68rem; color: var(--text-mut); }
.tier .tbadge { position: absolute; top: -10px; right: 12px; font-family: var(--font-mono); font-size: .58rem; font-weight: 600; background: var(--accent); color: var(--on-accent); padding: 3px 9px; border-radius: var(--r-pill); }
.tier .scar { margin-top: 9px; font-size: .64rem; font-weight: 600; color: var(--amber); display: flex; align-items: center; gap: 5px; }

.inbox { display: grid; grid-template-columns: 1fr; gap: 0; }
@media (min-width:620px){ .inbox { grid-template-columns: 200px 1fr; } }
.inbox-list { border-right: 1px solid var(--line); }
.inbox-item { display: flex; gap: 9px; padding: 10px; border-bottom: 1px solid var(--line); cursor: pointer; }
.inbox-item.active { background: var(--accent-soft); }
.inbox-item .iav { width: 30px; height: 30px; border-radius: 50%; background: var(--surface-3); color: var(--text); display: grid; place-items: center; font-size: .72rem; font-weight: 700; flex: none; }
.inbox-item .it { min-width: 0; flex: 1; }
.inbox-item .it b { font-size: .8rem; display: block; color: var(--text); }
.inbox-item .it span { font-size: .7rem; color: var(--text-mut); display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.inbox-item .unread { width: 18px; height: 18px; border-radius: 50%; background: var(--accent); color: var(--on-accent); font-size: .62rem; font-weight: 700; display: grid; place-items: center; flex: none; align-self: center; }
.inbox-thread { padding: 12px; display: flex; flex-direction: column; gap: 8px; background: var(--surface-2); }
.inbox-actions { display: flex; gap: 7px; margin-top: 4px; flex-wrap: wrap; }
.mini-btn { font-size: .7rem; font-weight: 700; padding: 6px 11px; border-radius: var(--r-pill); }
.mini-btn.red { background: var(--accent); color: var(--on-accent); } .mini-btn.dark { background: var(--surface-3); color: var(--text); border: 1px solid var(--line); } .mini-btn.ghost { background: transparent; border: 1px solid var(--line); color: var(--text-mut); }

.studio { display: flex; flex-direction: column; gap: 14px; }
.slider-row .sl-top { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.slider-row .sl-top b { font-size: .84rem; color: var(--text); }
.slider-row .sl-top span { font-family: var(--font-mono); font-size: .72rem; color: var(--accent); font-weight: 600; }
.slider-track { height: 8px; border-radius: var(--r-pill); background: var(--surface-2); border: 1px solid var(--line); overflow: hidden; }
.slider-fill { height: 100%; border-radius: var(--r-pill); background: linear-gradient(90deg, var(--accent), var(--accent-bright)); width: 0; transition: width 1.1s cubic-bezier(.16,1,.3,1); }
.slider-fill.red { background: linear-gradient(90deg, var(--amber), #ffd37a); }
.arch-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.arch-chips .chip.on { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.arch-chips .chip.on svg { color: var(--on-accent); }
.kb-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.kb-chip { display: inline-flex; align-items: center; gap: 6px; font-size: .72rem; font-weight: 600; padding: 6px 11px; border-radius: var(--r-sm); background: var(--surface-2); border: 1px solid var(--line); color: var(--text); }
.kb-chip svg { width: 13px; height: 13px; color: var(--accent); }
.kb-chip .w { font-family: var(--font-mono); font-size: .58rem; color: var(--amber); margin-left: 2px; }
.guarantee { display: flex; gap: 10px; padding: 12px 14px; border-radius: var(--r-md); background: var(--accent-soft); border: 1px solid rgba(91,84,230,.3); margin-top: 4px; }
.guarantee svg { width: 20px; height: 20px; color: var(--accent); flex: none; }
.guarantee p { font-size: .82rem; color: var(--text); }

.code-block { background: #15130f; border: 1px solid #2a2620; border-radius: var(--r-md); padding: 16px 18px; font-family: var(--font-mono); font-size: .78rem; color: #d8d3c8; overflow-x: auto; line-height: 1.7; box-shadow: var(--sh-2); }
.code-block .c-tag { color: var(--accent-bright); } .code-block .c-attr { color: var(--amber); } .code-block .c-str { color: var(--success); } .code-block .c-com { color: var(--text-dim); }

/* transformation / testimonial wall */
.tw-grid { display: grid; gap: var(--s-4); }
@media (min-width:680px){ .tw-grid { grid-template-columns: repeat(3,1fr); } }
.tw-card { border-radius: var(--r-md); overflow: hidden; box-shadow: var(--sh-2); border: 1px solid var(--line); background: var(--surface); transition: transform var(--t), border-color var(--t); }
.tw-card:hover { transform: translateY(-4px); border-color: rgba(91,84,230,.4); }
.tw-card img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; object-position: center; display: block; }
.tw-card .tw-cap { padding: 11px 13px; font-size: .76rem; color: var(--text-mut); display: flex; align-items: center; gap: 7px; }
.tw-card .tw-cap b { color: var(--text); }

/* --------------------------------------------------- phone-browser mock */
.phone { width: 100%; max-width: 320px; margin-inline: auto; background: var(--surface); border-radius: 30px; border: 1px solid var(--line); box-shadow: var(--sh-3); overflow: hidden; }
.phone .browser-bar { padding: 9px 12px; border-radius: 0; }
.phone .browser-url { font-size: .68rem; padding: 5px 11px; }
.phone-screen { background: var(--bg); padding: 14px; min-height: 440px; }
.app-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.app-head .greet { font-family: var(--font-display); font-weight: 700; font-size: 1.15rem; color: var(--text); }
.app-head .greet span { display: block; font-family: var(--font-mono); font-size: .58rem; letter-spacing: .08em; text-transform: uppercase; color: var(--text-dim); font-weight: 500; }
.app-head .av { width: 34px; height: 34px; border-radius: 50%; background: var(--surface-3); color: var(--text); display: grid; place-items: center; font-weight: 700; flex: none; }
.app-metrics { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 12px; }
.app-metric { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 9px; text-align: center; }
.app-metric .am-v { font-family: var(--font-display); font-weight: 800; font-size: 1.15rem; color: var(--text); }
.app-metric .am-v.red { color: var(--accent); } .app-metric .am-v.blue { color: var(--amber); }
.app-metric .am-l { font-size: .58rem; text-transform: uppercase; letter-spacing: .04em; color: var(--text-dim); font-family: var(--font-mono); }
.app-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); padding: 12px; margin-bottom: 10px; }
.app-card .ac-h { display: flex; align-items: center; justify-content: space-between; margin-bottom: 9px; }
.app-card .ac-h b { font-size: .86rem; color: var(--text); }
.app-card .ac-h .ac-tag { font-family: var(--font-mono); font-size: .58rem; color: var(--text-dim); }
.todo-item { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-top: 1px solid var(--line); font-size: .8rem; }
.todo-item:first-of-type { border-top: none; }
.todo-item .ck { width: 19px; height: 19px; border-radius: 6px; border: 1.5px solid var(--line); flex: none; display: grid; place-items: center; }
.todo-item.done .ck { background: var(--success); border-color: var(--success); color: var(--bg); }
.todo-item.done .ck svg { width: 12px; height: 12px; }
.todo-item.done .ti-name { color: var(--text-dim); text-decoration: line-through; }
.todo-item .ti-name { flex: 1; font-weight: 600; color: var(--text); }
.todo-item .ti-meta { font-family: var(--font-mono); font-size: .64rem; color: var(--text-mut); }

.set-row { display: grid; grid-template-columns: 28px 1fr 1fr 1fr; gap: 8px; align-items: center; padding: 8px 0; border-top: 1px solid var(--line); }
.set-row .sn { width: 26px; height: 26px; border-radius: 7px; background: var(--surface-2); color: var(--text); display: grid; place-items: center; font-family: var(--font-mono); font-weight: 600; font-size: .72rem; }
.set-row.logged .sn { background: var(--success); color: var(--bg); }
.set-field { background: var(--surface-2); border: 1px solid var(--line); border-radius: 7px; padding: 5px 8px; text-align: center; font-variant-numeric: tabular-nums; }
.set-field .sf-l { font-family: var(--font-mono); font-size: .52rem; text-transform: uppercase; color: var(--text-dim); display: block; }
.set-field .sf-v { font-weight: 700; font-size: .9rem; color: var(--text); }
.set-field.carry .sf-v { color: var(--text-dim); font-style: italic; }
.pr-flag { display: inline-flex; align-items: center; gap: 5px; font-size: .64rem; font-weight: 700; color: var(--accent); background: var(--accent-soft); padding: 3px 8px; border-radius: var(--r-pill); }
.rest-timer { display: flex; align-items: center; justify-content: space-between; margin-top: 10px; padding: 9px 12px; border-radius: var(--r-sm); background: var(--accent); color: var(--on-accent); }
.rest-timer .rt-v { font-family: var(--font-mono); font-weight: 600; font-size: 1.1rem; font-variant-numeric: tabular-nums; }

.scan-wrap { position: relative; border-radius: var(--r-md); overflow: hidden; background: linear-gradient(135deg,#efe9df,#e0d8c9); aspect-ratio: 16/10; display: grid; place-items: center; }
.scan-wrap .plate { width: 64%; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle at 40% 35%, #f5f0e6, #d8cdb8); box-shadow: inset 0 0 24px rgba(0,0,0,.12); }
.scan-line { position: absolute; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--accent), transparent); box-shadow: 0 0 12px 2px rgba(91,84,230,.7); animation: scan 2.6s ease-in-out infinite; }
@keyframes scan { 0%,100% { top: 8%; } 50% { top: 92%; } }
@media (prefers-reduced-motion: reduce){ .scan-line { animation: none; top: 50%; } }
.scan-readout { position: absolute; bottom: 10px; left: 10px; right: 10px; display: flex; gap: 6px; }
.scan-readout .sr { flex: 1; background: rgba(255,255,255,.95); border: 1px solid var(--line); border-radius: 7px; padding: 6px; text-align: center; }
.scan-readout .sr .v { font-family: var(--font-display); font-weight: 800; font-size: .95rem; color: var(--amber); }
.scan-readout .sr .l { font-family: var(--font-mono); font-size: .5rem; text-transform: uppercase; color: var(--text-mut); }

.cal { display: grid; grid-template-columns: repeat(7,1fr); gap: 5px; }
.cal .cd { aspect-ratio: 1; border-radius: 6px; background: var(--surface-2); display: grid; place-items: center; font-size: .64rem; color: var(--text-mut); position: relative; }
.cal .cd .dot { position: absolute; bottom: 4px; width: 5px; height: 5px; border-radius: 50%; }
.cal .cd .dot.full { background: var(--success); } .cal .cd .dot.part { background: var(--amber); } .cal .cd .dot.miss { background: var(--line); }

.chart-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); padding: 14px; }
.chart-card h4 { font-size: .9rem; margin-bottom: 4px; color: var(--text); }
.chart-card .ch-sub { font-family: var(--font-mono); font-size: .64rem; color: var(--text-mut); margin-bottom: 10px; }
.linechart { width: 100%; height: auto; }
.linechart .grid-l { stroke: var(--line); stroke-width: 1; }
.linechart .data-l { fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 1000; stroke-dashoffset: 1000; }
.linechart .data-l.draw { animation: draw-line 1.6s ease forwards; }
.linechart .data-l.blue { stroke: var(--amber); } .linechart .data-l.red { stroke: var(--accent); } .linechart .data-l.green { stroke: var(--success); }
.linechart .area { opacity: 0; transition: opacity .8s ease .6s; }
.linechart .area.show { opacity: .14; }
@keyframes draw-line { to { stroke-dashoffset: 0; } }
@media (prefers-reduced-motion: reduce){ .linechart .data-l { stroke-dashoffset: 0 !important; animation: none; } }

/* ------------------------------------------------------- comparison */
.compare { display: grid; gap: var(--s-4); }
@media (min-width:760px){ .compare { grid-template-columns: 1fr 1fr; gap: 0; align-items: stretch; } }
.compare-col { border: 1px solid var(--line); padding: var(--s-6); }
.compare-col.rent { background: var(--surface); border-radius: var(--r-lg) var(--r-lg) 0 0; }
.compare-col.own { background: var(--surface); border-radius: 0 0 var(--r-lg) var(--r-lg); border-color: rgba(91,84,230,.45); box-shadow: 0 0 0 1px rgba(91,84,230,.18), var(--sh-2); position: relative; }
@media (min-width:760px){
  .compare-col.rent { border-radius: var(--r-lg) 0 0 var(--r-lg); }
  .compare-col.own { border-radius: 0 var(--r-lg) var(--r-lg) 0; transform: scale(1.03); z-index: 1; }
}
.compare-col h3 { font-size: 1.4rem; margin-bottom: 4px; color: var(--text); }
.compare-col .ch-sub { font-family: var(--font-mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .06em; margin-bottom: var(--s-4); }
.compare-col.rent .ch-sub { color: var(--text-dim); } .compare-col.own .ch-sub { color: var(--accent-bright); }
.compare-list li { display: flex; gap: 10px; padding: 11px 0; border-top: 1px solid var(--line); font-size: .95rem; align-items: flex-start; color: var(--text-mut); }
.compare-list li .ci { flex: none; width: 20px; height: 20px; border-radius: 50%; display: grid; place-items: center; margin-top: 2px; }
.compare-list li .ci svg { width: 12px; height: 12px; }
.compare-col.rent .ci { background: var(--surface-3); color: var(--text-dim); }
.compare-col.own .ci { background: var(--accent-soft); color: var(--accent); }
.compare-col.own .compare-list li { color: var(--text); }
.compare-col.own .own-badge { position: absolute; top: -13px; right: var(--s-5); background: var(--grad); color: #fff; font-family: var(--font-mono); font-size: .62rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; padding: 6px 13px; border-radius: var(--r-pill); box-shadow: 0 8px 18px -8px rgba(109,94,252,.7); white-space: nowrap; }

/* ------------------------------------------------------- #own — cost reframe (rent vs own) */
.own-cost { display: grid; gap: var(--s-4); margin-bottom: var(--s-5); }
@media (min-width:760px){ .own-cost { grid-template-columns: 1fr 1fr; } }
.cost-card { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: var(--r-lg); padding: var(--s-5); background: var(--surface); }
.cost-card.rent { background: linear-gradient(180deg, rgba(245,69,92,.06), var(--surface)); border-color: rgba(245,69,92,.22); }
.cost-card.own { background: linear-gradient(180deg, var(--accent-soft), var(--surface)); border-color: rgba(91,84,230,.4); box-shadow: 0 0 0 1px rgba(91,84,230,.16), var(--sh-2); }
.cc-tag { font-family: var(--font-mono); font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; color: var(--c-red); margin-bottom: var(--s-5); }
.cc-tag.accent { color: var(--accent-bright); }
.cost-bars { display: flex; align-items: flex-end; gap: 8px; height: 92px; margin-bottom: calc(var(--s-4) + 12px); }
.cost-bars .cb { flex: 1; height: var(--h); min-height: 8px; border-radius: 7px 7px 0 0; position: relative; background: var(--c-red); opacity: .82; transition: height .7s cubic-bezier(.2,.7,.2,1); }
.cost-bars .cb i { position: absolute; bottom: -19px; left: 0; right: 0; text-align: center; font-family: var(--font-mono); font-style: normal; font-size: .58rem; color: var(--text-dim); }
.cost-bars.one .cb { flex: 0 0 44%; }
.cost-bars .cb.paid { background: var(--accent); opacity: 1; }
.cost-bars .cb.flat { background: var(--success); opacity: .45; }
.cc-fig { display: flex; flex-direction: column; font-size: 1.7rem; font-weight: 700; line-height: 1.1; color: var(--text); letter-spacing: -.02em; }
.cc-fig.accent { color: var(--accent-deep); }
.cc-fig span { font-size: .8rem; font-weight: 500; letter-spacing: 0; color: var(--text-mut); margin-top: 5px; }
.cc-note { font-size: .82rem; color: var(--text-mut); margin-top: auto; padding-top: 14px; }
@media (prefers-reduced-motion: reduce){ .cost-bars .cb { transition: none; } }

/* #own — in-section CTA */
.own-cta { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--s-4); margin-top: var(--s-5); padding: clamp(20px,3vw,28px) clamp(20px,3vw,32px); border-radius: var(--r-lg); background: var(--surface); border: 1px solid var(--line); box-shadow: var(--sh-2); }
.own-cta .oc-copy strong { display: block; font-size: 1.2rem; color: var(--text); }
.own-cta .oc-copy span { display: block; font-size: .9rem; color: var(--text-mut); margin-top: 3px; }
.own-cta .btn-row { margin: 0; }

/* ------------------------------------------------------- testimonials (Dev) */
.testi { display: grid; gap: var(--s-7); align-items: center; }
@media (min-width:900px){ .testi { grid-template-columns: .8fr 1.2fr; } }
.testi-photo { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-3); position: relative; border: 1px solid var(--line); }
.testi-photo img { width: 100%; aspect-ratio: 3/4; object-fit: cover; filter: grayscale(.25) contrast(1.05); }
.testi-photo .tp-badge { position: absolute; top: 14px; left: 14px; }
.testi-quote { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.4rem,2.6vw,2.1rem); line-height: 1.25; color: var(--text); }
.testi-quote .mark { color: var(--accent); }
.testi-by { display: flex; align-items: center; gap: 12px; margin-top: var(--s-5); }
.testi-by .av { width: 44px; height: 44px; border-radius: 50%; overflow: hidden; flex: none; border: 1px solid var(--line); }
.testi-by .av img { width: 100%; height: 100%; object-fit: cover; }
.testi-by .who b { color: var(--text); display: block; font-size: 1rem; }
.testi-by .who span { color: var(--text-mut); font-size: .85rem; }
.case-tiles { display: grid; grid-template-columns: repeat(2,1fr); gap: var(--s-3); margin-top: var(--s-6); }
@media (min-width:520px){ .case-tiles { grid-template-columns: repeat(4,1fr); } }
.case-tile { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); padding: var(--s-4); }
.case-tile .ct-v { font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; color: var(--accent); }
.case-tile .ct-l { font-size: .72rem; color: var(--text-mut); }

/* counters */
.counters { display: grid; grid-template-columns: repeat(2,1fr); gap: var(--s-5); }
@media (min-width:760px){ .counters { grid-template-columns: repeat(4,1fr); } }
.counter { text-align: center; }
.counter .cv { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.4rem,5vw,3.4rem); color: var(--accent); line-height: 1; font-variant-numeric: tabular-nums; }
.counter .cl { font-size: .9rem; color: var(--text-mut); margin-top: 6px; }

/* process */
.steps { display: grid; gap: var(--s-5); }
@media (min-width:760px){ .steps { grid-template-columns: repeat(4,1fr); } }
.step { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: var(--s-6); position: relative; }
.step .sn { font-family: var(--font-display); font-weight: 800; font-size: 2.4rem; color: var(--accent); line-height: 1; opacity: .35; }
.step .sd { font-family: var(--font-mono); font-size: .64rem; letter-spacing: .08em; text-transform: uppercase; color: var(--amber); margin: 8px 0 6px; }
.step h4 { margin-bottom: 6px; }
.step p { font-size: .92rem; }

/* pricing deed */
.deed { max-width: 760px; margin-inline: auto; background: var(--surface); border: 1px solid var(--accent); border-radius: var(--r-xl); padding: clamp(var(--s-6), 5vw, var(--s-8)); box-shadow: 0 0 0 1px rgba(91,84,230,.25), var(--sh-3); position: relative; overflow: hidden; }
.deed::before { content: ''; position: absolute; inset: 6px; border: 1px solid var(--line); border-radius: calc(var(--r-xl) - 6px); pointer-events: none; }
.deed-head { text-align: center; border-bottom: 1px dashed var(--line); padding-bottom: var(--s-5); margin-bottom: var(--s-5); }
.deed-head .seal { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); }
.deed-head h3 { font-size: clamp(1.8rem,4vw,2.6rem); margin: 8px 0; }
.deed-price { display: flex; align-items: baseline; justify-content: center; gap: 12px; }
.deed-price .now { font-family: var(--font-display); font-weight: 800; font-size: clamp(3rem,7vw,4.4rem); color: var(--text); line-height: 1; font-variant-numeric: tabular-nums; }
.deed-price .was { font-family: var(--font-display); font-size: 1.6rem; color: var(--text-dim); text-decoration: line-through; }
.deed-price .one { font-family: var(--font-mono); font-size: .8rem; color: var(--accent); font-weight: 600; }
.deed-terms { font-size: .88rem; color: var(--text-mut); text-align: center; margin-top: 8px; }
.deed-incl { display: grid; gap: 10px; margin: var(--s-5) 0; }
@media (min-width:600px){ .deed-incl { grid-template-columns: 1fr 1fr; } }
.deed-incl li { display: flex; gap: 9px; font-size: .92rem; align-items: flex-start; color: var(--text-mut); }
.deed-incl .tick { flex: none; width: 20px; height: 20px; border-radius: 50%; background: var(--accent-soft); color: var(--accent); display: grid; place-items: center; margin-top: 2px; }
.deed-incl .tick svg { width: 12px; height: 12px; }
/* pricing — founding offer / FOMO */
.fomo-bar { display: flex; align-items: center; gap: 9px; width: fit-content; margin: 0 auto var(--s-5); padding: 9px 16px; background: linear-gradient(135deg, #fb7a1e, #f5455c); color: #fff; font-family: var(--font-mono); font-size: .76rem; font-weight: 600; letter-spacing: .03em; border-radius: var(--r-pill); box-shadow: 0 8px 20px -8px rgba(245,69,92,.6); animation: fomopulse 2.2s ease-in-out infinite; }
.fomo-bar svg { width: 15px; height: 15px; flex: none; }
@keyframes fomopulse { 0%,100% { box-shadow: 0 8px 20px -8px rgba(245,69,92,.5); } 50% { box-shadow: 0 8px 28px -6px rgba(245,69,92,.92); } }
.save-badge { display: inline-block; margin-top: 12px; font-family: var(--font-mono); font-size: .74rem; font-weight: 700; color: var(--success); background: var(--success-soft); padding: 6px 13px; border-radius: var(--r-pill); }
.slots { max-width: 380px; margin: var(--s-5) auto 0; }
.slots-track { height: 9px; border-radius: var(--r-pill); background: var(--surface-3); overflow: hidden; }
.slots-fill { height: 100%; border-radius: var(--r-pill); background: linear-gradient(90deg, #fb7a1e, #f5455c); transition: width .8s cubic-bezier(.2,.7,.2,1); }
.slots-label { font-family: var(--font-mono); font-size: .76rem; color: var(--text-mut); margin-top: 9px; }
.slots-label strong { color: var(--c-red); }
.price-warn { display: flex; align-items: center; justify-content: center; gap: 9px; max-width: 500px; margin: var(--s-5) auto 0; padding: 10px 15px; font-size: .84rem; color: var(--warn); background: rgba(251,122,30,.1); border: 1px solid rgba(251,122,30,.28); border-radius: var(--r-md); text-align: left; }
.price-warn svg { width: 17px; height: 17px; flex: none; }
.price-warn strong { color: var(--warn); }
.cta-microcopy { text-align: center; font-family: var(--font-mono); font-size: .76rem; font-weight: 600; color: var(--c-red); margin-top: 14px; }
@media (prefers-reduced-motion: reduce) { .fomo-bar { animation: none; } .slots-fill { transition: none; } }

/* FAQ */
.faq { max-width: 800px; margin-inline: auto; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--s-4); text-align: left; padding: var(--s-5) 0; font-family: var(--font-display); font-weight: 600; font-size: 1.18rem; color: var(--text); }
.faq-q .fic { flex: none; width: 30px; height: 30px; border-radius: 50%; background: var(--surface-2); display: grid; place-items: center; transition: transform var(--t), background var(--t); }
.faq-q .fic svg { width: 17px; height: 17px; color: var(--accent); }
.faq-q[aria-expanded="true"] .fic { transform: rotate(45deg); background: var(--accent-soft); }
.faq-a { overflow: hidden; max-height: 0; transition: max-height var(--t-slow); }
.faq-a-inner { padding: 0 0 var(--s-5); color: var(--text-mut); font-size: 1rem; max-width: 68ch; }

/* CTA band */
.cta-band { background: #0f1118; border: 1px solid #1d2030; border-radius: var(--r-xl); padding: clamp(var(--s-7),6vw,var(--s-9)); text-align: center; position: relative; overflow: hidden; }
.cta-band::after { content: ''; position: absolute; width: 520px; height: 520px; border-radius: 50%; background: radial-gradient(circle, rgba(91,84,230,.28), transparent 62%); top: -200px; right: -140px; pointer-events: none; }
.cta-band h2 { color: #fff; position: relative; }
.cta-band .eyebrow { color: #9aa1ae; }
.cta-band p { color: #aab0bd; margin: var(--s-3) auto var(--s-6); max-width: 52ch; position: relative; }
.cta-band .btn-row { justify-content: center; position: relative; }
.cta-band .btn-ghost { color: #fff; border-color: rgba(255,255,255,.22); }
.cta-band .btn-ghost:hover { border-color: var(--accent-bright); color: #fff; background: rgba(255,255,255,.04); }

/* footer */
.footer { background: var(--bg-deep); color: var(--text-mut); padding-block: var(--s-8) var(--s-6); border-top: 1px solid var(--line); }
.footer-grid { display: grid; gap: var(--s-6); margin-bottom: var(--s-7); }
@media (min-width:760px){ .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; } }
.footer h5 { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-dim); margin-bottom: var(--s-4); }
.footer a { color: var(--text-mut); display: block; padding: 5px 0; transition: color var(--t-fast); }
.footer a:hover { color: var(--accent); }
.footer .f-logo { font-family: var(--font-display); font-weight: 800; font-size: 1.3rem; color: var(--text); margin-bottom: 10px; }
.footer-bottom { border-top: 1px solid var(--line); padding-top: var(--s-5); font-size: .82rem; display: flex; flex-wrap: wrap; gap: var(--s-3); justify-content: space-between; }

/* ------------------------------------------------------- cinematic / motion */
.grain::before { content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .14; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E"); }
.grain > * { position: relative; z-index: 2; }

.mesh { position: relative; isolation: isolate; overflow: hidden; }
.mesh::before { content: ''; position: absolute; inset: -10%; z-index: 0; pointer-events: none;
  background:
    radial-gradient(40% 48% at 16% 22%, rgba(91,84,230,.16), transparent 62%),
    radial-gradient(38% 46% at 84% 28%, rgba(13,148,136,.12), transparent 62%),
    radial-gradient(50% 58% at 60% 94%, rgba(91,84,230,.10), transparent 62%);
  filter: blur(10px); animation: mesh-move 20s ease-in-out infinite alternate; }
.mesh > * { position: relative; z-index: 1; }
@keyframes mesh-move { 0% { transform: translate3d(-2%,-1%,0) scale(1); } 50% { transform: translate3d(2%,2%,0) scale(1.06); } 100% { transform: translate3d(-1%,1%,0) scale(1.02); } }

.split .word { display: inline-block; overflow: hidden; vertical-align: top; padding-bottom: .09em; }
.split .word-i { display: inline-block; will-change: transform; }
[data-parallax] { will-change: transform; }
.motion-off .reveal, .motion-off [data-stagger] > * { opacity: 1 !important; transform: none !important; }
.motion-off .split .word-i { transform: none !important; }

/* Reveal baseline is VISIBLE so all content (incl. the hero) renders fully with
   JavaScript disabled or slow. The hidden start-state used for entrance animation
   is applied only once JS is confirmed, via the .js-enabled class on <html>. */
.reveal { opacity: 1; transform: none; }
.js-enabled .reveal { opacity: 0; transform: translateY(24px); transition: opacity .6s ease, transform .6s cubic-bezier(.16,1,.3,1); }
.js-enabled .reveal.in { opacity: 1; transform: none; }
.js-enabled .reveal[data-delay="1"]{ transition-delay: .08s; } .js-enabled .reveal[data-delay="2"]{ transition-delay: .16s; } .js-enabled .reveal[data-delay="3"]{ transition-delay: .24s; } .js-enabled .reveal[data-delay="4"]{ transition-delay: .32s; }
/* prefers-reduced-motion: disable every entrance/loop animation and show final state. */
@media (prefers-reduced-motion: reduce){
  .reveal, .js-enabled .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .split .word-i { transform: none !important; }
  .live-dot::after, .ekg .lead-line, .mesh::before, .scroll-cue .line::after { animation: none !important; }
  .hero-cinematic { min-height: auto; }
}

/* utilities */
.mt-2 { margin-top: var(--s-2);} .mt-4 { margin-top: var(--s-4);} .mt-5 { margin-top: var(--s-5);} .mt-6 { margin-top: var(--s-6);} .mt-7 { margin-top: var(--s-7);}
.text-center { text-align: center; }
.muted { color: var(--text-mut); }
.hide-sm { display: none; } @media (min-width:760px){ .hide-sm { display: revert; } }

/* =========================================================================
   EDITORIAL LAYER — inspired by type-led award sites (sidewave / tonymak /
   lucien): oversized type, warm monochrome, numbered sections, live clock,
   custom cursor, generous space.
   ========================================================================= */

/* more air between sections */
section { padding-block: clamp(80px, 11vw, 168px); }
section[id] { scroll-margin-top: 88px; } /* anchor links clear the sticky nav (native smooth scroll) */

/* ---- revenue journey (bright, colour-progressing timeline) ---- */
.journey-section { position: relative; padding-block: clamp(96px, 12vw, 180px); overflow: hidden;
  background: linear-gradient(180deg, #f4f3ff 0%, #f1f7ff 44%, #edfcf3 100%); }
.journey-section::before { content: ''; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(560px 440px at 12% 12%, rgba(91,84,230,.13), transparent 60%),
              radial-gradient(560px 440px at 88% 58%, rgba(22,163,74,.11), transparent 60%),
              radial-gradient(460px 380px at 62% 94%, rgba(245,180,30,.09), transparent 60%); }
.journey-section > .container { position: relative; z-index: 1; }
.journey-section .section-head p { max-width: 64ch; margin-inline: auto; }

.journey { --prog: 0; --th: 1200px; --mk: #5b54e6; max-width: 1180px; margin: var(--s-9) auto 0; position: relative; }
/* scroll-progress timeline: faint base track + colour fill + gliding marker */
.j-track { position: absolute; top: 26px; bottom: 40px; left: 30px; transform: translateX(-50%); width: 3px; border-radius: 3px; background: rgba(15,18,28,.10); z-index: 0; pointer-events: none;
  -webkit-mask-image: linear-gradient(180deg, transparent, #000 5%, #000 95%, transparent); mask-image: linear-gradient(180deg, transparent, #000 5%, #000 95%, transparent); }
@media (min-width: 900px) { .j-track { left: 50%; } }
.j-fill { position: absolute; left: 0; top: 0; width: 100%; height: calc(var(--prog) * 100%); border-radius: 3px;
  /* brand purple → green: green eases in over the final third so it fades smoothly into the "Month 1+" node */
  background: linear-gradient(180deg, #5b54e6 0%, #2f6bff 22%, #8b3df2 42%, #6d5efc 60%, #2f9e6e 82%, #16a34a 100%); background-repeat: no-repeat; background-size: 100% var(--th); box-shadow: 0 0 12px rgba(15,18,28,.10); }
.j-marker { position: absolute; left: 50%; top: calc(var(--prog) * 100%); transform: translate(-50%, -50%); width: 16px; height: 16px; border-radius: 50%; background: #fff; border: 3px solid var(--mk); box-shadow: 0 0 0 5px rgba(91,84,230,.14), 0 3px 10px rgba(15,18,28,.28); z-index: 4; }
.j-marker::after { content: ''; position: absolute; inset: -3px; border-radius: 50%; border: 1px solid var(--mk); opacity: .45; animation: mkpulse 1.9s ease-out infinite; }
@keyframes mkpulse { 0% { transform: scale(1); opacity: .5; } 100% { transform: scale(2.6); opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .j-marker::after { animation: none; } }

.j-step { --c: var(--accent); position: relative; display: grid; grid-template-columns: 60px 1fr; column-gap: var(--s-4); row-gap: var(--s-4); padding-bottom: clamp(64px, 8vw, 92px); }
.j-rail { grid-column: 1; display: flex; flex-direction: column; align-items: center; gap: 12px; position: relative; }
.j-body { grid-column: 2; }
.j-visual { grid-column: 2; }
/* desktop: alternating roadmap — content one side, big visual the other, node on the spine */
@media (min-width: 900px) {
  .j-step { grid-template-columns: minmax(0,1fr) 72px minmax(0,1fr); column-gap: var(--s-6); align-items: center; padding-bottom: clamp(56px, 6vw, 104px); }
  .j-step > * { grid-row: 1; } /* copy, rail and mockup share one row so align-items:center balances them */
  .j-body { grid-column: 1; text-align: right; }
  .j-rail { grid-column: 2; }
  .j-visual { grid-column: 3; }
  .j-step:nth-child(even) .j-body { grid-column: 3; text-align: left; }
  .j-step:nth-child(even) .j-visual { grid-column: 1; }
  .j-body .j-chips { justify-content: flex-end; }
  .j-step:nth-child(even) .j-body .j-chips { justify-content: flex-start; }
}
.j-node { width: 54px; height: 54px; border-radius: 50%; display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; font-size: 1.35rem; color: #fff; background: var(--c); border: none; box-shadow: 0 8px 22px -5px var(--c), 0 0 0 5px #fbfcfe, 0 2px 6px rgba(15,18,28,.14); position: relative; z-index: 2; flex: none; transition: transform .4s cubic-bezier(.34,1.4,.64,1), box-shadow .4s ease; }
.j-day { font-family: var(--font-mono); font-size: .62rem; font-weight: 600; letter-spacing: .07em; text-transform: uppercase; color: var(--text-mut); white-space: nowrap; transition: color .3s ease; }
/* active milestone — the one the marker is currently at */
.j-step.is-active .j-node { transform: scale(1.16); box-shadow: 0 12px 30px -4px var(--c), 0 0 0 5px #fbfcfe, 0 0 0 12px rgba(91,84,230,.10), 0 2px 6px rgba(15,18,28,.16); }
.j-step.is-active .j-day { color: var(--c); }
.j-step.is-active .j-visual > :first-child { box-shadow: 0 34px 64px -22px var(--c), 0 12px 30px rgba(15,18,28,.10); }
.j-step .j-visual > :first-child { transition: box-shadow .45s ease; }
.j-body h3 { color: var(--text); font-size: clamp(1.3rem, 2.1vw, 1.7rem); margin-bottom: 6px; }
.j-body p { color: var(--text-mut); font-size: 1rem; }
.j-body strong { color: var(--text); }
/* "live" section badge — purple-tinted pill with a gently pulsing dot */
.j-badge { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 14px; font-family: var(--font-mono); font-size: .6rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--accent-deep); background: rgba(139,61,242,.10); border: 1px solid rgba(139,61,242,.3); padding: 5px 13px 5px 10px; border-radius: var(--r-pill); }
.j-badge .dot { position: relative; width: 7px; height: 7px; border-radius: 50%; background: var(--c); flex: none; }
.j-badge .dot::after { content: ''; position: absolute; inset: 0; border-radius: 50%; background: inherit; animation: jbpulse 1.9s ease-out infinite; }
.j-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.j-chips span { font-family: var(--font-mono); font-size: .62rem; font-weight: 500; color: var(--c); background: #fff; border: 1px solid var(--line); border-radius: var(--r-pill); padding: 4px 10px; }
/* standout AI chip — solid purple gradient with a sparkle */
.j-chips span.ai { display: inline-flex; align-items: center; gap: 5px; color: #fff; font-weight: 600; background: var(--grad); border-color: transparent; box-shadow: 0 6px 16px -7px rgba(109,94,252,.7); }
.j-chips span.ai svg { width: 11px; height: 11px; flex: none; }
@keyframes jbpulse { 0% { transform: scale(1); opacity: .5; } 100% { transform: scale(2.7); opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .j-badge .dot::after, .jvd-new i::after { animation: none; } }

/* journey mini-visual surfaces — bright cards, coloured top accent */
.jv-card, .jv-web, .jv-chat, .jv-app, .jv-rev, .jv-checkout { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); box-shadow: 0 28px 56px -26px var(--c), 0 10px 26px rgba(15,18,28,.08); position: relative; }
.j-visual { position: relative; }
@media (min-width: 900px) { .j-visual > :first-child { transform: scale(1.02); } }
.jv-card, .jv-rev, .jv-checkout { padding: 14px; }
.jv-card::before, .jv-web::before, .jv-chat::before, .jv-checkout::before, .jv-rev::before { content: ''; position: absolute; left: 0; right: 0; top: 0; height: 3px; background: var(--c); border-radius: var(--r-md) var(--r-md) 0 0; z-index: 2; }
.jv-head { display: flex; align-items: center; gap: 7px; font-weight: 700; color: var(--text); font-size: .82rem; margin-bottom: 10px; }
.jv-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--c); flex: none; }
.jv-field { display: flex; justify-content: space-between; gap: 12px; font-size: .74rem; padding: 7px 0; border-top: 1px solid var(--line); }
.jv-field:first-of-type { border-top: none; }
.jv-field span { color: var(--text-mut); } .jv-field b { color: var(--text); font-weight: 600; text-align: right; }
.jv-prog { height: 6px; border-radius: 99px; background: var(--surface-2); overflow: hidden; margin-top: 12px; }
.jv-prog i { display: block; height: 100%; background: var(--c); }
.jv-note { font-family: var(--font-mono); font-size: .58rem; color: var(--success); margin-top: 9px; }

/* dynamic website mock */
.jv-web { overflow: hidden; }
.jv-bar { display: flex; align-items: center; gap: 5px; padding: 8px 11px; background: var(--surface-2); border-bottom: 1px solid var(--line); }
.jv-bar i { width: 7px; height: 7px; border-radius: 50%; background: var(--line); }
.jv-bar i:nth-child(1) { background: #ff5f57; } .jv-bar i:nth-child(2) { background: #febc2e; } .jv-bar i:nth-child(3) { background: #28c840; }
.jv-bar span { margin-left: 6px; font-family: var(--font-mono); font-size: .58rem; color: var(--text-mut); }
.jv-live { margin-left: auto; font-family: var(--font-mono); font-size: .5rem; font-weight: 600; color: var(--success); display: inline-flex; align-items: center; gap: 4px; }
.jv-live::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--success); }
.jv-web-hero { padding: 16px; color: #fff; background: linear-gradient(140deg, var(--c), #141726); }
.jv-web-ey { font-family: var(--font-mono); font-size: .5rem; letter-spacing: .12em; opacity: .85; }
.jv-web-h { font-family: var(--font-display); font-weight: 800; font-size: 1.15rem; margin: 5px 0 9px; }
.jv-web-cta { display: inline-block; background: #fff; color: var(--c); font-size: .62rem; font-weight: 800; padding: 6px 12px; border-radius: var(--r-pill); }
.jv-thumbs { display: grid; grid-template-columns: repeat(3,1fr); gap: 5px; padding: 10px; }
.jv-thumbs img { width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: 7px; }
.jv-web-stats { display: flex; gap: 8px; padding: 0 10px 12px; }
.jv-web-stats span { flex: 1; text-align: center; font-size: .48rem; color: var(--text-mut); font-family: var(--font-mono); text-transform: uppercase; }
.jv-web-stats b { display: block; font-family: var(--font-display); font-weight: 800; font-size: .95rem; color: var(--text); }
.jv-tag { display: inline-flex; align-items: center; gap: 6px; margin-top: 10px; font-family: var(--font-mono); font-size: .6rem; font-weight: 600; padding: 5px 11px; border-radius: var(--r-pill); }
.jv-tag.ok { background: var(--success-soft); color: var(--success); }

.jv-tiers { display: flex; gap: 8px; }
.jv-tiers span { flex: 1; text-align: center; background: var(--surface-2); border: 1px solid var(--line); border-radius: 8px; padding: 9px 4px; font-family: var(--font-display); font-weight: 800; color: var(--text); font-size: .92rem; }
.jv-tiers span.best { border-color: var(--c); color: var(--c); box-shadow: 0 0 0 1px var(--c); }
.jv-strip { display: flex; align-items: center; gap: 8px; margin-top: 11px; font-size: .7rem; color: var(--text-mut); background: var(--surface-2); border: 1px dashed var(--c); border-radius: 8px; padding: 9px 11px; }
.jv-strip svg { width: 15px; height: 15px; color: var(--c); flex: none; }

/* chat */
.jv-chat { display: flex; flex-direction: column; gap: 7px; padding: 13px; }
.jv-msg { max-width: 90%; font-size: .73rem; padding: 7px 10px; border-radius: 11px; line-height: 1.35; }
.jv-msg.user { align-self: flex-end; background: var(--c); color: #fff; border-bottom-right-radius: 3px; }
.jv-msg.ai { align-self: flex-start; background: var(--surface-2); color: var(--text); border: 1px solid var(--line); border-bottom-left-radius: 3px; }
.jv-fn { display: block; margin-top: 5px; font-family: var(--font-mono); font-size: .52rem; text-transform: uppercase; letter-spacing: .04em; color: var(--c); }
.jv-link { align-self: flex-start; font-family: var(--font-mono); font-size: .62rem; color: var(--success); font-weight: 600; }

/* checkout + payment gateways */
.jv-co-row { display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.jv-co-row span { font-size: .78rem; color: var(--text-mut); }
.jv-co-row b { font-family: var(--font-display); font-weight: 800; font-size: 1.2rem; color: var(--text); }
.jv-pays { display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0; }
.pay { height: 25px; min-width: 42px; display: inline-flex; align-items: center; justify-content: center; gap: 2px; border-radius: 5px; background: #fff; border: 1px solid var(--line); font-weight: 800; font-size: .62rem; padding: 0 8px; box-shadow: var(--sh-1); }
.pay.pv { color: #1a1f71; font-style: italic; letter-spacing: .03em; }
.pay.pm { gap: 0; } .pay.pm i { width: 14px; height: 14px; border-radius: 50%; display: block; } .pay.pm i:first-child { background: #eb001b; } .pay.pm i:last-child { background: #f79e1b; margin-left: -5px; }
.pay.px { color: #2e77bc; }
.pay.ps { color: #635bff; }
.pay.pp { color: #003087; }
.pay.pg { color: #5f6368; }
.jv-paid { display: flex; align-items: center; gap: 7px; background: var(--success-soft); color: #0a7a42; border: 1px solid rgba(15,157,88,.3); border-radius: 8px; padding: 8px 11px; font-size: .7rem; font-weight: 600; }
.jv-paid svg { width: 13px; height: 13px; color: var(--success); flex: none; }

/* client app rows */
.jv-app { padding: 12px; margin-top: 10px; }
.jv-app-h { font-weight: 700; color: var(--text); font-size: .8rem; margin-bottom: 8px; }
.jv-arow { display: flex; align-items: center; gap: 8px; font-size: .72rem; color: var(--text-mut); padding: 6px 0; border-top: 1px solid var(--line); }
.jv-arow:first-of-type { border-top: none; }
.jv-arow i { width: 14px; height: 14px; border-radius: 4px; border: 1.4px solid var(--line); flex: none; }
.jv-arow.done i { background: var(--success); border-color: var(--success); }

/* revenue payoff */
.jv-rev-top { display: flex; justify-content: space-between; align-items: baseline; }
.jv-rev-top span { font-family: var(--font-mono); font-size: .6rem; text-transform: uppercase; letter-spacing: .04em; color: var(--text-mut); }
.jv-rev-top b { font-family: var(--font-display); font-weight: 800; font-size: 1.8rem; color: var(--text); display: flex; align-items: baseline; gap: 8px; }
.jv-up { font-family: var(--font-mono); font-size: .58rem; font-weight: 700; color: var(--success); }
.jv-rev-chart { width: 100%; height: 72px; margin-top: 10px; display: block; }
.jv-rev-foot { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: .55rem; color: var(--text-mut); margin-top: 4px; }

/* ---- equal-size, realistic product-screenshot frames for each milestone ---- */
.jv-frame { width: 100%; aspect-ratio: 4 / 3; background: var(--surface); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; display: flex; flex-direction: column; position: relative; box-shadow: 0 28px 56px -26px var(--c), 0 10px 26px rgba(15,18,28,.08); }
.jv-frame::before { content: ''; position: absolute; left: 0; right: 0; top: 0; height: 3px; background: var(--c); z-index: 6; }
.jvf-bar { display: flex; align-items: center; gap: 5px; padding: 8px 11px; background: var(--surface-2); border-bottom: 1px solid var(--line); flex: none; }
.jvf-bar i { width: 7px; height: 7px; border-radius: 50%; }
.jvf-bar i:nth-child(1) { background: #ff5f57; } .jvf-bar i:nth-child(2) { background: #febc2e; } .jvf-bar i:nth-child(3) { background: #28c840; }
.jvf-bar span { margin-left: 6px; font-family: var(--font-mono); font-size: .56rem; color: var(--text-mut); }
.jvf-bar .jv-live { margin-left: auto; font-family: var(--font-mono); font-size: .5rem; font-weight: 600; color: var(--success); display: inline-flex; align-items: center; gap: 4px; }
.jvf-bar .jv-live::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--success); }
.jvf-screen { flex: 1; min-height: 0; overflow: hidden; display: flex; }

/* app shell (sidebar + main) used by setup / offers / inbox / dashboard */
.jvs-side { width: 40px; flex: none; background: var(--surface-2); border-right: 1px solid var(--line); display: flex; flex-direction: column; align-items: center; gap: 8px; padding-top: 12px; }
.jvs-side b { width: 22px; height: 22px; border-radius: 6px; background: var(--c); flex: none; }
.jvs-side i { width: 22px; height: 22px; border-radius: 6px; background: var(--surface-3); flex: none; }
.jvs-side i.on { background: var(--c); opacity: .85; }
.jvs-main { flex: 1; min-width: 0; padding: 13px 14px; display: flex; flex-direction: column; }
.jvs-top { display: flex; align-items: center; gap: 9px; margin-bottom: 12px; }
.jvs-ava { width: 30px; height: 30px; border-radius: 50%; background: var(--c); color: #fff; display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; font-size: .82rem; flex: none; }
.jvs-top .who b { font-size: .8rem; color: var(--text); display: block; line-height: 1.15; }
.jvs-top .who span { font-size: .58rem; color: var(--text-mut); font-family: var(--font-mono); }
.jvs-pill { margin-left: auto; font-family: var(--font-mono); font-size: .55rem; padding: 3px 8px; border-radius: var(--r-pill); white-space: nowrap; }
.jvs-pill.ok { background: var(--success-soft); color: var(--success); }
.jvs-h { font-family: var(--font-mono); font-size: .56rem; text-transform: uppercase; letter-spacing: .06em; color: var(--text-dim); margin: 2px 0 8px; }

/* setup screen */
.jvs-fr { display: flex; justify-content: space-between; gap: 10px; font-size: .68rem; padding: 8px 0; border-top: 1px solid var(--line); }
.jvs-fr:first-of-type { border-top: none; }
.jvs-fr label { color: var(--text-mut); } .jvs-fr b { color: var(--text); font-weight: 600; }
.jvs-bar2 { height: 6px; border-radius: 99px; background: var(--surface-2); overflow: hidden; margin-top: auto; }
.jvs-bar2 i { display: block; height: 100%; width: 100%; background: var(--c); }
.jvs-ok { display: flex; align-items: center; gap: 6px; margin-top: 9px; font-size: .64rem; font-weight: 600; color: var(--success); }
.jvs-ok svg { width: 13px; height: 13px; }

/* live website screen — mirrors the real devkanojia.com hero (dark #0e0e0e + lime #caf300, Space Grotesk) */
.jvw { position: relative; width: 100%; height: 100%; background: #0e0e0e; overflow: hidden; display: flex; flex-direction: column; color: #e8e5e0; }
.jvw-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 64% 14%; filter: brightness(.42) saturate(.95); }
.jvw-shade { position: absolute; inset: 0; background: linear-gradient(102deg, rgba(14,14,14,.95) 24%, rgba(14,14,14,.4) 62%, rgba(14,14,14,.05) 100%), linear-gradient(to top, #0e0e0e 1%, transparent 44%); }
.jvw > :not(.jvw-bg):not(.jvw-shade) { position: relative; z-index: 1; }
.jvw-nav { display: flex; align-items: center; gap: 8px; padding: 9px 12px; }
.jvw-logo { font-family: 'Space Grotesk', var(--font-display); font-weight: 700; font-size: .62rem; letter-spacing: .16em; text-transform: uppercase; color: #e8e5e0; }
.jvw-logo em { font-style: normal; color: #caf300; }
.jvw-nav .cta { margin-left: auto; font-family: 'Space Grotesk', var(--font-display); font-size: .5rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; background: #caf300; color: #171e00; padding: 4px 9px; border-radius: 2px; }
.jvw-hero2 { margin-top: auto; padding: 0 13px 12px; }
.jvw-eyebrow { display: inline-flex; align-items: center; gap: 6px; font-family: 'Space Grotesk', var(--font-display); font-size: .44rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: #caf300; }
.jvw-eyebrow i { width: 5px; height: 5px; border-radius: 50%; background: #caf300; flex: none; }
.jvw-h { font-family: 'Space Grotesk', var(--font-display); font-weight: 700; text-transform: uppercase; font-size: 1.55rem; line-height: .9; letter-spacing: -.02em; color: #e8e5e0; margin: 8px 0 0; }
.jvw-h .lime { color: #caf300; }
.jvw-h .dim { color: rgba(232,229,224,.22); }
.jvw-btn { display: inline-flex; margin-top: 11px; font-family: 'Space Grotesk', var(--font-display); font-size: .5rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; background: #caf300; color: #171e00; padding: 6px 13px; border-radius: 2px; }
.jvw-stats { display: flex; border-top: 1px solid rgba(232,229,224,.12); background: rgba(14,14,14,.6); }
.jvw-stats span { flex: 1; text-align: center; padding: 8px 4px; font-family: 'Space Grotesk', var(--font-display); font-size: .4rem; text-transform: uppercase; letter-spacing: .05em; color: rgba(232,229,224,.5); border-left: 1px solid rgba(232,229,224,.08); }
.jvw-stats span:first-child { border-left: none; }
.jvw-stats b { display: block; font-size: .82rem; font-weight: 700; color: #e8e5e0; margin-bottom: 2px; }

/* program-builder screenshots (real product UI) — stacked, purple-tinted frames */
.jv-frame-tall { aspect-ratio: auto; } /* frame grows to the screenshot's natural height */
.jv-shots { display: flex; flex-direction: column; gap: 16px; }
.jv-shot { border-color: rgba(139,61,242,.22); box-shadow: 0 30px 60px -28px var(--c), 0 10px 26px rgba(15,18,28,.08); }
.jv-shots img { width: 100%; height: auto; display: block; }
/* screenshot caption (e.g. USD price clarification) */
.jv-cap { padding: 8px 12px; font-family: var(--font-mono); font-size: .58rem; letter-spacing: .02em; color: var(--text-mut); background: var(--surface); border-top: 1px solid var(--line); }
.jv-cap b { color: var(--c); font-weight: 700; }
/* real client web-app phones (device showcase) */
.jv-devices { border: 1px solid rgba(22,163,74,.2); border-radius: var(--r-md); overflow: hidden; background: linear-gradient(165deg, rgba(22,163,74,.08), rgba(22,163,74,.015)); box-shadow: 0 30px 60px -28px var(--c), 0 10px 26px rgba(15,18,28,.08); }
.jv-phones { display: flex; justify-content: center; align-items: flex-end; gap: 16px; padding: 20px 16px 16px; }
.jv-phones img { width: 47%; max-width: 210px; height: auto; display: block; border-radius: 20px; border: 5px solid #0f1117; box-shadow: 0 20px 44px -16px rgba(15,18,28,.45); }
.jv-devices .jv-cap { text-align: center; background: rgba(255,255,255,.55); border-top-color: rgba(22,163,74,.16); }

/* inbox screen */
.jvi { display: flex; width: 100%; }
.jvi-list { width: 38%; border-right: 1px solid var(--line); }
.jvi-li { display: flex; align-items: center; gap: 7px; padding: 8px 9px; border-bottom: 1px solid var(--line); }
.jvi-li.on { background: var(--accent-soft); }
.jvi-av { width: 22px; height: 22px; border-radius: 50%; background: var(--surface-3); color: var(--text); display: grid; place-items: center; font-size: .54rem; font-weight: 700; flex: none; }
.jvi-li .t { min-width: 0; } .jvi-li .t b { font-size: .6rem; display: block; color: var(--text); } .jvi-li .t span { font-size: .5rem; color: var(--text-mut); display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.jvi-main { flex: 1; min-width: 0; padding: 10px; display: flex; flex-direction: column; gap: 6px; }
.jvi-msg { max-width: 92%; font-size: .6rem; padding: 6px 8px; border-radius: 9px; line-height: 1.3; }
.jvi-msg.u { align-self: flex-end; background: var(--c); color: #fff; border-bottom-right-radius: 3px; }
.jvi-msg.a { align-self: flex-start; background: var(--surface-2); color: var(--text); border: 1px solid var(--line); border-bottom-left-radius: 3px; }
.jvi-tag { font-family: var(--font-mono); font-size: .46rem; text-transform: uppercase; color: var(--c); }
.jvi-act { margin-top: auto; display: flex; gap: 6px; }
.jvi-act span { font-size: .55rem; font-weight: 700; padding: 4px 8px; border-radius: var(--r-pill); }
.jvi-act .p { background: var(--c); color: #fff; } .jvi-act .g { border: 1px solid var(--line); color: var(--text-mut); }

/* checkout screen */
.jvc { padding: 13px 14px; display: flex; flex-direction: column; width: 100%; }
.jvc-sum { display: flex; align-items: center; gap: 9px; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.jvc-sum .ic { width: 30px; height: 30px; border-radius: 7px; background: var(--c); flex: none; }
.jvc-sum .t b { font-size: .7rem; color: var(--text); display: block; } .jvc-sum .t span { font-size: .56rem; color: var(--text-mut); }
.jvc-sum .pr { margin-left: auto; font-family: var(--font-display); font-weight: 800; font-size: 1.1rem; color: var(--text); }
.jvc .jv-pays { margin: 11px 0; }
.jvc-btn { background: var(--c); color: #fff; text-align: center; font-weight: 700; font-size: .66rem; padding: 9px; border-radius: 8px; }
.jvc-done { display: flex; align-items: center; gap: 7px; margin-top: 9px; font-size: .64rem; font-weight: 600; color: var(--success); }
.jvc-done svg { width: 13px; height: 13px; }

/* dashboard / revenue screen — dark "earnings" theme: money coming in, revenue climbing */
.jvd-screen { flex: 1; min-height: 0; display: flex; background: radial-gradient(120% 90% at 100% 0%, #143024 0%, #0e1613 55%); color: #e7efe9; }
.jvd-side { width: 40px; flex: none; background: #0a100d; border-right: 1px solid rgba(255,255,255,.06); display: flex; flex-direction: column; align-items: center; gap: 8px; padding-top: 12px; }
.jvd-side b { width: 22px; height: 22px; border-radius: 6px; background: #34d36a; flex: none; box-shadow: 0 0 14px rgba(52,211,106,.6); }
.jvd-side i { width: 22px; height: 22px; border-radius: 6px; background: rgba(255,255,255,.07); flex: none; }
.jvd-side i.on { background: #34d36a; opacity: .85; }
.jvd-main { flex: 1; min-width: 0; padding: 12px 13px; display: flex; flex-direction: column; gap: 9px; }
.jvd-top { display: flex; align-items: center; justify-content: space-between; }
.jvd-h { font-family: var(--font-mono); font-size: .56rem; text-transform: uppercase; letter-spacing: .08em; color: #7f9a8b; }
.jvd-new { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: .5rem; font-weight: 600; color: #34d36a; background: rgba(52,211,106,.12); border: 1px solid rgba(52,211,106,.32); padding: 3px 9px; border-radius: var(--r-pill); }
.jvd-new i { position: relative; width: 5px; height: 5px; border-radius: 50%; background: #34d36a; flex: none; }
.jvd-new i::after { content: ''; position: absolute; inset: 0; border-radius: 50%; background: #34d36a; animation: jbpulse 1.8s ease-out infinite; }
.jvd-kpis { display: grid; grid-template-columns: repeat(2,1fr); gap: 7px; }
.jvd-kpi { border: 1px solid rgba(255,255,255,.08); border-radius: 9px; padding: 8px 9px; background: rgba(255,255,255,.03); }
.jvd-kpi small { font-family: var(--font-mono); font-size: .46rem; text-transform: uppercase; letter-spacing: .04em; color: #7f9a8b; display: block; }
.jvd-kpi b { font-family: var(--font-display); font-weight: 800; font-size: 1.04rem; color: #e7efe9; }
.jvd-kpi em { font-style: normal; font-family: var(--font-mono); font-size: .5rem; font-weight: 600; color: #34d36a; margin-left: 6px; }
.jvd-kpi.rev { background: linear-gradient(135deg, rgba(52,211,106,.18), rgba(52,211,106,.03)); border-color: rgba(52,211,106,.36); box-shadow: 0 0 24px -8px rgba(52,211,106,.4) inset; }
.jvd-kpi.rev b { color: #4ee07f; font-size: 1.28rem; }
.jvd-chart { border: 1px solid rgba(255,255,255,.08); border-radius: 9px; padding: 9px 10px; background: rgba(255,255,255,.02); }
.jvd-chart .lbl { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: .5rem; color: #7f9a8b; text-transform: uppercase; letter-spacing: .03em; margin-bottom: 4px; }
.jvd-chart svg { width: 100%; height: 56px; display: block; }
.jvd-feed { border: 1px solid rgba(255,255,255,.08); border-radius: 9px; background: rgba(255,255,255,.02); overflow: hidden; }
.jvd-feed-h { display: flex; align-items: center; justify-content: space-between; padding: 7px 10px; font-family: var(--font-mono); font-size: .5rem; text-transform: uppercase; letter-spacing: .04em; color: #7f9a8b; border-bottom: 1px solid rgba(255,255,255,.06); }
.jvd-feed-h b { color: #f5b400; font-weight: 700; }
.jvd-pay { display: flex; align-items: center; gap: 8px; padding: 7px 10px; border-top: 1px solid rgba(255,255,255,.05); }
.jvd-pay:first-of-type { border-top: none; }
.jvd-pay .av { width: 22px; height: 22px; border-radius: 50%; background: linear-gradient(135deg, #34d36a, #0e8f4f); color: #06160d; display: grid; place-items: center; font-size: .56rem; font-weight: 800; flex: none; }
.jvd-pay .t { min-width: 0; line-height: 1.2; }
.jvd-pay .t b { font-size: .62rem; color: #e7efe9; font-weight: 600; display: block; }
.jvd-pay .t span { font-size: .5rem; color: #7f9a8b; font-family: var(--font-mono); }
.jvd-pay .amt { margin-left: auto; font-family: var(--font-display); font-weight: 800; font-size: .84rem; color: #4ee07f; }

/* journey CTA (bright) */
.j-cta { text-align: center; margin-top: var(--s-8); display: flex; gap: var(--s-3); justify-content: center; flex-wrap: wrap; }

/* hairline rhythm */
.section-tint { border-block: 1px solid var(--line-2); }
.section-head h2 { margin-top: var(--s-4); }
.section-head .s-num { margin-bottom: var(--s-5); }

/* nav: live clock + minimal */
.nav-clock { display: none; font-family: var(--font-mono); font-size: .7rem; letter-spacing: .08em; color: var(--text-dim); align-items: center; gap: 8px; }
.nav-clock i { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); display: block; animation: blink 2s steps(1) infinite; }
@keyframes blink { 50% { opacity: .25; } }
@media (min-width: 1080px) { .nav-clock { display: inline-flex; } }
@media (prefers-reduced-motion: reduce) { .nav-clock i { animation: none; } }

/* custom cursor (fine pointers only; enabled by JS via .has-cursor) */
.cursor-ring { position: fixed; top: 0; left: 0; width: 32px; height: 32px; border: 1px solid var(--accent); border-radius: 50%; pointer-events: none; z-index: 9999; transform: translate(-50%, -50%); transition: width .25s ease, height .25s ease, background .25s ease, opacity .25s ease; mix-blend-mode: difference; opacity: 0; }
.has-cursor .cursor-ring { opacity: 1; }
.cursor-ring.hover { width: 58px; height: 58px; background: var(--accent); }
@media (pointer: fine) { body.has-cursor, body.has-cursor a, body.has-cursor button { cursor: none; } }
@media (pointer: coarse) { .cursor-ring { display: none; } }

/* editorial marquee — oversized kinetic type */
.marquee { background: var(--bg); border-block: 1px solid var(--line); padding-block: var(--s-5); }
.marquee { padding-block: var(--s-4); }
.marquee-track { gap: var(--s-6); }
.marquee-track span { font-family: var(--font-body); font-size: .9rem; font-weight: 500; text-transform: none; letter-spacing: .005em; color: var(--text-mut); }
.marquee-track span::before { width: 4px; height: 4px; background: var(--accent); }

/* hero: type-led */
.hero-cinematic { align-items: center; }
.hero h1 { margin: var(--s-5) 0 var(--s-6); max-width: 15ch; font-size: clamp(2.4rem, 4.6vw, 3.7rem); }
.hero h1 .hl { background: linear-gradient(118deg, #6d5efc 0%, #9b5cf6 48%, #c45cf0 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero h1 .hl-amber { background: linear-gradient(118deg, #fb7a1e 0%, #f5455c 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
/* ownership differentiator — solid accent + underline so it reads as the key claim, not a tail clause */
.hero h1 .hl-own { color: var(--accent-deep); text-decoration-line: underline; text-decoration-color: rgba(109,94,252,.3); text-decoration-thickness: 3px; text-underline-offset: 6px; }
.hero .eyebrow, .hero .lead { max-width: 46ch; }
.hero-visual { position: relative; }

/* ---- hero: floating client-app phone screens ---- */
.hero-stage { position: relative; padding: 14px 0 70px; }
.hero-floats { display: contents; } /* ≥1300px: chat + cards float around the website */
.hero-browser { position: relative; z-index: 2; width: 80%; margin: 0 auto; }
.hero-phone { --hc: var(--accent); position: absolute; z-index: 3; width: 168px; background: var(--surface); border: 1px solid var(--line); border-radius: 22px; box-shadow: 0 30px 60px -22px var(--hc), 0 12px 30px rgba(15,18,28,.12); overflow: hidden; }
.hero-phone::before { content: ''; position: absolute; left: 0; right: 0; top: 0; height: 3px; background: var(--hc); z-index: 5; }
.hero-phone-1 { left: -84px; bottom: -78px; z-index: 5; transform: rotate(-2deg); }
.hp-bar { display: flex; align-items: center; gap: 6px; padding: 7px 10px; background: var(--surface-2); border-bottom: 1px solid var(--line); }
.hp-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--hc); flex: none; }
.hp-url { font-family: var(--font-mono); font-size: .52rem; color: var(--text-mut); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hp-screen { padding: 10px; background: var(--bg); }
.hp-greet { font-weight: 700; font-size: .76rem; color: var(--text); line-height: 1.2; }
.hp-greet span { display: block; font-family: var(--font-mono); font-size: .46rem; text-transform: uppercase; letter-spacing: .04em; color: var(--text-dim); font-weight: 500; margin-top: 2px; }
.hp-chips { display: grid; grid-template-columns: repeat(3,1fr); gap: 5px; margin: 8px 0; }
.hp-chips span { background: var(--surface); border: 1px solid var(--line); border-radius: 7px; padding: 5px 2px; text-align: center; font-size: .44rem; color: var(--text-dim); font-family: var(--font-mono); text-transform: uppercase; }
.hp-chips span b { display: block; font-family: var(--font-display); font-size: .85rem; color: var(--text); font-weight: 800; margin-bottom: 1px; }
.hp-chips span.acc b { color: var(--accent); }
.hp-card { background: var(--surface); border: 1px solid var(--line); border-radius: 9px; padding: 8px; }
.hp-h { font-weight: 700; font-size: .66rem; color: var(--text); }
.hp-sub { font-family: var(--font-mono); font-size: .5rem; color: var(--text-mut); margin-bottom: 3px; }
.hp-row { display: flex; align-items: center; gap: 6px; font-size: .6rem; color: var(--text); padding: 4px 0; border-top: 1px solid var(--line); }
.hp-row:first-of-type { border-top: none; }
.hp-row i { width: 11px; height: 11px; border-radius: 3px; border: 1.4px solid var(--line); flex: none; }
.hp-row.done i { background: var(--success); border-color: var(--success); }
.hp-row em { margin-left: auto; font-family: var(--font-mono); font-size: .5rem; color: var(--text-dim); font-style: normal; }
.hp-spark { width: 100%; height: 26px; display: block; }

/* hero fitness cards: macro rings (diet) + body-composition */
.hc-rings { display: flex; justify-content: space-around; gap: 6px; margin: 10px 0 4px; }
.hc-ring { text-align: center; }
.hc-ring .ring { width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; position: relative; margin: 0 auto; background: conic-gradient(var(--rc) calc(var(--p) * 1%), var(--surface-2) 0); }
.hc-ring .ring::before { content: ''; position: absolute; inset: 5px; background: var(--surface); border-radius: 50%; }
.hc-ring .ring b { position: relative; z-index: 1; font-family: var(--font-display); font-weight: 800; font-size: .82rem; color: var(--text); }
.hc-ring small { display: block; margin-top: 4px; font-family: var(--font-mono); font-size: .46rem; text-transform: uppercase; letter-spacing: .03em; color: var(--text-mut); }
.hc-photo { position: relative; border-radius: 10px; overflow: hidden; aspect-ratio: 16 / 11; }
.hc-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 72% 22%; }
.hc-badge { position: absolute; top: 7px; left: 7px; background: var(--hc); color: #fff; font-family: var(--font-mono); font-size: .5rem; font-weight: 700; padding: 3px 7px; border-radius: var(--r-pill); }
.hc-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 5px; margin-top: 9px; }
.hc-stats > div { text-align: center; background: var(--surface-2); border: 1px solid var(--line); border-radius: 7px; padding: 6px 2px; }
.hc-stats b { font-family: var(--font-display); font-weight: 800; font-size: .82rem; color: var(--text); display: block; }
.hc-stats b small { font-size: .5rem; color: var(--text-mut); font-weight: 600; }
.hc-stats span { font-family: var(--font-mono); font-size: .42rem; text-transform: uppercase; color: var(--text-dim); }

/* hero: floating real coaching photos */
.hero-pic { --c: var(--accent); position: absolute; border-radius: 20px; overflow: hidden; border: 4px solid #fff; box-shadow: 0 26px 54px -20px var(--c), 0 12px 28px rgba(15,18,28,.16); }
.hero-pic img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-pic figcaption { position: absolute; left: 8px; bottom: 8px; background: var(--c); color: #fff; font-family: var(--font-mono); font-size: .54rem; font-weight: 600; padding: 4px 9px; border-radius: var(--r-pill); }
.hp-coach { width: 182px; height: 136px; left: 50%; margin-left: -128px; bottom: -64px; transform: rotate(2.5deg); z-index: 4; }
.hp-train { width: 168px; height: 126px; right: -12px; bottom: -98px; transform: rotate(-3deg); z-index: 3; }

/* chat as its own floating element (separate from the website) */
.hero-chat { position: absolute; top: 66px; right: -20px; bottom: auto; left: auto; width: 232px; z-index: 6; transform: rotate(-1.5deg); box-shadow: 0 34px 70px -26px rgba(91,84,230,.5), 0 14px 30px rgba(15,18,28,.14); }

/* floating bob — staggered so cards don't drift in lockstep */
[data-float] { animation: heroFloat 6s ease-in-out infinite; }
.hero-chat[data-float] { animation-duration: 7s; animation-delay: -1.5s; }
.hero-phone-1[data-float] { animation-duration: 6.6s; animation-delay: -3s; }
.hp-coach[data-float] { animation-duration: 7.4s; animation-delay: -2s; }
.hp-train[data-float] { animation-duration: 6.2s; animation-delay: -4s; }

/* ---- ≤1299px: no room to float cleanly — browser on top, cards in a spaced row ---- */
@media (max-width: 1299px) {
  .hero-stage { display: flex; flex-direction: column; gap: var(--s-5); padding: 0; }
  .hero-browser { width: 100%; margin: 0; }
  .hero-floats { display: flex; gap: var(--s-4); justify-content: center; align-items: flex-start; flex-wrap: wrap; }
  .hero-phone, .hero-pic, .hero-chat { position: relative; inset: auto; top: auto; right: auto; transform: none; animation: none; flex: 1 1 200px; min-width: 180px; max-width: 280px; box-shadow: var(--sh-2); }
  .hero-pic { height: auto; aspect-ratio: 4 / 3; }
  .hero-chat { flex-basis: 240px; align-self: stretch; }
}
/* under 560px: keep it clean — browser only */
@media (max-width: 559px) { .hero-floats { display: none; } }
@keyframes heroFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@media (prefers-reduced-motion: reduce) { [data-float] { animation: none; } }

/* big statement number/quote accents */
.testi-quote { font-weight: 700; letter-spacing: -.02em; }

/* =========================================================================
   CLAY LAYER — colourful, playful: multi-colour cards, photo strip, vibrant CTA
   ========================================================================= */
/* colourful twin feature cards */
#twin .grid > :nth-child(1) { --cc: var(--c-violet); }
#twin .grid > :nth-child(2) { --cc: var(--c-blue); }
#twin .grid > :nth-child(3) { --cc: var(--c-orange); }
#twin .grid > :nth-child(4) { --cc: var(--c-green); }
#twin .card { --cc: var(--accent); border-radius: var(--r-lg); transition: transform .35s cubic-bezier(.34,1.4,.64,1), box-shadow .35s, border-color .35s; }
#twin .card .ic { background: var(--cc); color: #fff; box-shadow: 0 8px 18px -6px var(--cc); }
#twin .card:hover { transform: translateY(-6px); border-color: var(--cc); box-shadow: 0 22px 46px -22px var(--cc), var(--sh-2); }
#twin .card-sweep::before { background: linear-gradient(120deg, var(--cc), color-mix(in srgb, var(--cc) 40%, #fff), var(--cc)); }

/* real-photo strip (clay: rounded, colourful, playful hover) */
.photo-strip { display: grid; gap: var(--s-5); margin-top: var(--s-7); }
@media (min-width: 760px) { .photo-strip { grid-template-columns: repeat(3,1fr); } }
.ps-card { --cc: var(--accent); border-radius: var(--r-lg); overflow: hidden; position: relative; box-shadow: 0 20px 44px -20px var(--cc), var(--sh-2); transition: transform .4s cubic-bezier(.34,1.4,.64,1); }
.ps-card:hover { transform: translateY(-7px) rotate(-.6deg); }
.ps-card img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; display: block; transition: transform .55s ease; }
.ps-card:hover img { transform: scale(1.07); }
.ps-card figcaption { position: absolute; left: 0; right: 0; bottom: 0; padding: 16px; color: #fff; background: linear-gradient(transparent, rgba(8,10,18,.86)); font-family: var(--font-display); font-weight: 700; font-size: 1.06rem; line-height: 1.2; }
.ps-card figcaption span { display: inline-block; background: var(--cc); color: #fff; font-family: var(--font-mono); font-size: .58rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; padding: 4px 10px; border-radius: var(--r-pill); margin-bottom: 9px; }

/* vibrant clay CTA band with a real photo */
.cta-band { background: var(--grad) !important; border: none !important; }
.cta-band::after { background: radial-gradient(circle, rgba(255,255,255,.35), transparent 62%) !important; }
.cta-band .eyebrow { color: rgba(255,255,255,.85); }
.cta-band .eyebrow::before { background: #fff; }
.cta-band h2, .cta-band p { color: #fff !important; }
.cta-band .btn-primary, .cta-band .btn-live { background: #fff; color: var(--accent-deep); box-shadow: 0 10px 26px -8px rgba(0,0,0,.3); }
.cta-band .btn-primary:hover, .cta-band .btn-live:hover { background: #fff; filter: brightness(1.02); }
.cta-band .btn-live .live-dot { background: var(--c-green); }
.cta-band .btn-ghost { color: #fff; border-color: rgba(255,255,255,.5); }
.cta-band .btn-ghost:hover { background: rgba(255,255,255,.12); border-color: #fff; color: #fff; }

/* playful colourful section eyebrows / s-num accents rotate per section */
.section-tint { background: var(--surface); }

/* small screens */
@media (max-width: 720px) { .hero-cinematic { min-height: auto; padding-bottom: 56px; } .scroll-cue { display: none; } }
@media (max-width: 560px) {
  .container { padding-inline: var(--s-4); }
  .nav-inner { gap: var(--s-2); }
  .logo { font-size: .94rem; }
  .logo small { display: none; }
  .logo .mark { width: 26px; height: 26px; }
  .nav-cta { gap: var(--s-2); }
  .nav-cta .btn-primary { padding: 9px 13px; font-size: .84rem; }
  h1 { font-size: clamp(2.1rem, 8.5vw, 2.9rem); }
  .deed-price .now { font-size: clamp(2.4rem, 12vw, 3.2rem); }
}
