/* =============================================================================
   Hiyya AI Business Review — premium, mobile-first wizard styling
   Brand: purple #8b5cf6 · indigo #6366f1 · pink #ec4899 · dark #161d24
   ============================================================================= */
:root {
  --rv-bg: #0f141a;
  --rv-bg-2: #161d24;
  --rv-surface: #1c242e;
  --rv-surface-2: #232d39;
  --rv-line: rgba(255, 255, 255, .09);
  --rv-line-strong: rgba(255, 255, 255, .16);
  --rv-text: #eef2f6;
  --rv-muted: #9aa7b4;
  --rv-faint: #6b7785;
  --rv-purple: #8b5cf6;
  --rv-indigo: #6366f1;
  --rv-pink: #ec4899;
  --rv-grad: linear-gradient(135deg, #8b5cf6 0%, #6366f1 50%, #ec4899 100%);
  --rv-radius: 18px;
  --rv-radius-sm: 12px;
  --rv-shadow: 0 24px 60px -24px rgba(0, 0, 0, .7);
  --rv-ring: 0 0 0 3px rgba(139, 92, 246, .35);
  --rv-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--rv-font);
  background: var(--rv-bg);
  color: var(--rv-text);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  line-height: 1.55;
}

/* ---- Ambient background ------------------------------------------------- */
.rv-bg { position: fixed; inset: 0; z-index: 0; overflow: hidden; background: radial-gradient(120% 90% at 50% -10%, #1d2632 0%, var(--rv-bg) 60%); }
.rv-orb { position: absolute; border-radius: 50%; filter: blur(80px); opacity: .5; }
.rv-orb-1 { width: 520px; height: 520px; background: #6d3df0; top: -180px; left: -120px; }
.rv-orb-2 { width: 480px; height: 480px; background: #ec4899; bottom: -200px; right: -120px; opacity: .32; }
.rv-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px); background-size: 46px 46px; mask-image: radial-gradient(80% 60% at 50% 30%, #000 30%, transparent 80%); }

/* ---- Top bar ------------------------------------------------------------ */
.rv-topbar { position: sticky; top: 0; z-index: 40; display: flex; align-items: center; justify-content: space-between; padding: 16px clamp(16px, 4vw, 40px); border-bottom: 1px solid transparent; transition: background .3s, backdrop-filter .3s, border-color .3s; }
.rv-topbar.scrolled { background: rgb(15 20 26 / 7%); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom-color: rgba(255,255,255,.08); }
.rv-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; color: #fff; }
.rv-logo-mark { width: 34px; height: 34px; object-fit: contain; }
.rv-logo-text { font-size: 1.25rem; letter-spacing: -.5px; font-weight: 400; }
.rv-logo-text b { font-weight: 700; }
.rv-logo-minor { font-weight: 200; opacity: .85; }
.rv-topbar-right { display: flex; align-items: center; gap: 16px; }
.rv-save-state { font-size: .78rem; color: var(--rv-faint); transition: color .3s; }
.rv-save-state.is-on { color: var(--rv-purple); }
.rv-ghost-link { color: var(--rv-muted); text-decoration: none; font-size: .88rem; }
.rv-ghost-link:hover { color: #fff; }

/* ---- App shell ---------------------------------------------------------- */
.rv-app { position: relative; z-index: 2; max-width: 760px; margin: 0 auto; padding: 8px clamp(16px, 4vw, 24px) 80px; }
.rv-results { max-width: 1080px; }

/* ---- Buttons ------------------------------------------------------------ */
.rv-btn { font-family: inherit; font-size: .98rem; font-weight: 600; border-radius: 12px; padding: 13px 22px; border: 1px solid transparent; cursor: pointer; transition: transform .12s, box-shadow .2s, background .2s, border-color .2s; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; gap: 8px; }
.rv-btn:active { transform: translateY(1px); }
.rv-btn-primary { background: var(--rv-grad); color: #fff; box-shadow: 0 10px 30px -10px rgba(139, 92, 246, .7); }
.rv-btn-primary:hover { box-shadow: 0 14px 38px -10px rgba(139, 92, 246, .9); transform: translateY(-1px); }
.rv-btn-ghost { background: rgba(255, 255, 255, .04); color: var(--rv-text); border-color: var(--rv-line); }
.rv-btn-ghost:hover { background: rgba(255, 255, 255, .09); border-color: var(--rv-line-strong); }
.rv-btn-lg { padding: 16px 30px; font-size: 1.05rem; }
.rv-btn:focus-visible, .rv-opt:focus-visible, .rv-chip:focus-visible, .rv-input:focus-visible, .rv-select:focus-visible, .rv-textarea:focus-visible { outline: none; box-shadow: var(--rv-ring); }

/* ---- Entry screen ------------------------------------------------------- */
.rv-entry { text-align: center; padding: 4vh 4px 0; animation: rvFade .6s ease; }
.rv-entry-badge { display: inline-block; padding: 7px 16px; border-radius: 999px; background: rgba(139, 92, 246, .14); border: 1px solid rgba(139, 92, 246, .3); color: #c9b8ff; font-size: .82rem; font-weight: 500; margin-bottom: 26px; }
.rv-entry-title { font-size: clamp(2rem, 6vw, 3.2rem); line-height: 1.08; font-weight: 800; letter-spacing: -1.5px; margin: 0 0 18px; }
.rv-grad { background: var(--rv-grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.rv-entry-sub { font-size: clamp(1rem, 2.4vw, 1.18rem); color: var(--rv-muted); max-width: 580px; margin: 0 auto 30px; }
.rv-entry-benefits { list-style: none; padding: 0; margin: 0 auto 34px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; max-width: 540px; text-align: left; }
.rv-entry-benefits li { display: flex; align-items: center; gap: 12px; padding: 14px 16px; background: rgba(255, 255, 255, .035); border: 1px solid var(--rv-line); border-radius: 14px; font-size: .94rem; }
.rv-entry-benefits li span { font-size: 1.2rem; }
.rv-entry-actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-bottom: 22px; }
.rv-entry-reassure { color: var(--rv-faint); font-size: .85rem; max-width: 520px; margin: 0 auto; }

/* ---- Question screen ---------------------------------------------------- */
.rv-screen { animation: rvSlide .4s cubic-bezier(.2, .7, .3, 1); }
@keyframes rvSlide { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
@keyframes rvFade { from { opacity: 0; } to { opacity: 1; } }

/* Stage rail */
.rv-rail { margin: 6px 0 26px; }
.rv-rail-stages { display: flex; gap: 6px; overflow-x: auto; padding-bottom: 8px; scrollbar-width: none; }
.rv-rail-stages::-webkit-scrollbar { display: none; }
.rv-rail-stage { display: flex; align-items: center; gap: 7px; padding: 5px 12px 5px 8px; border-radius: 999px; white-space: nowrap; border: 1px solid var(--rv-line); color: var(--rv-faint); font-size: .76rem; flex: 0 0 auto; }
.rv-rail-stage .rv-rail-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--rv-faint); }
.rv-rail-stage.active { color: #fff; border-color: rgba(139, 92, 246, .55); background: rgba(139, 92, 246, .12); }
.rv-rail-stage.active .rv-rail-dot { background: var(--rv-purple); box-shadow: 0 0 0 4px rgba(139, 92, 246, .25); }
.rv-rail-stage.done { color: var(--rv-muted); }
.rv-rail-stage.done .rv-rail-dot { background: var(--rv-indigo); }
.rv-rail-meta { display: flex; align-items: center; gap: 14px; margin-top: 6px; }
.rv-rail-track { flex: 1; height: 6px; border-radius: 999px; background: rgba(255, 255, 255, .07); overflow: hidden; }
.rv-rail-fill { height: 100%; background: var(--rv-grad); border-radius: 999px; transition: width .5s cubic-bezier(.2,.7,.3,1); }
.rv-rail-time { font-size: .78rem; color: var(--rv-faint); white-space: nowrap; }

/* Question card */
.rv-qcard { background: linear-gradient(180deg, var(--rv-surface) 0%, var(--rv-bg-2) 100%); border: 1px solid var(--rv-line); border-radius: var(--rv-radius); padding: clamp(20px, 4vw, 34px); box-shadow: var(--rv-shadow); }
.rv-qstage { font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; color: var(--rv-purple); font-weight: 600; margin-bottom: 10px; }
.rv-qlabel { font-size: clamp(1.4rem, 4vw, 1.95rem); line-height: 1.18; font-weight: 700; letter-spacing: -.6px; margin: 0 0 8px; }
.rv-req { color: var(--rv-pink); }
.rv-qhelp { color: var(--rv-muted); font-size: .98rem; margin: 0 0 22px; }

/* Cards / options */
.rv-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; }
.rv-opt { position: relative; text-align: left; background: var(--rv-surface-2); border: 1.5px solid var(--rv-line); border-radius: var(--rv-radius-sm); padding: 16px 16px 15px; cursor: pointer; color: var(--rv-text); font-family: inherit; transition: border-color .15s, background .15s, transform .12s; display: flex; flex-direction: column; gap: 4px; }
.rv-opt:hover { border-color: var(--rv-line-strong); transform: translateY(-2px); }
.rv-opt.sel { border-color: var(--rv-purple); background: rgba(139, 92, 246, .12); }
.rv-opt-ico { font-size: 1.5rem; line-height: 1; margin-bottom: 6px; }
.rv-opt-main { font-weight: 600; font-size: .98rem; }
.rv-opt-desc { font-size: .82rem; color: var(--rv-muted); }
.rv-opt-check { position: absolute; top: 12px; right: 12px; width: 22px; height: 22px; border-radius: 50%; background: var(--rv-grad); color: #fff; display: flex; align-items: center; justify-content: center; font-size: .8rem; opacity: 0; transform: scale(.5); transition: .15s; }
.rv-opt.sel .rv-opt-check { opacity: 1; transform: scale(1); }

.rv-unknown { grid-column: 1 / -1; display: flex; gap: 10px; flex-wrap: wrap; margin-top: 4px; }
.rv-unknown-btn { background: transparent; border: 1px dashed var(--rv-line-strong); color: var(--rv-muted); border-radius: 999px; padding: 9px 16px; font-family: inherit; font-size: .85rem; cursor: pointer; }
.rv-unknown-btn:hover, .rv-unknown-btn.sel { color: #fff; border-color: var(--rv-purple); background: rgba(139, 92, 246, .1); }

/* Inputs */
.rv-input, .rv-select, .rv-textarea { width: 100%; background: var(--rv-surface-2); border: 1.5px solid var(--rv-line); border-radius: var(--rv-radius-sm); color: var(--rv-text); font-family: inherit; font-size: 1.05rem; padding: 15px 16px; transition: border-color .15s; }
.rv-input::placeholder, .rv-textarea::placeholder { color: var(--rv-faint); }
.rv-input:focus, .rv-select:focus, .rv-textarea:focus { border-color: var(--rv-purple); }
.rv-textarea { resize: vertical; min-height: 110px; line-height: 1.5; }
.rv-selectwrap { position: relative; }
.rv-selectwrap::after { content: "▾"; position: absolute; right: 18px; top: 50%; transform: translateY(-50%); color: var(--rv-muted); pointer-events: none; }
.rv-select { appearance: none; }
.rv-count { text-align: right; font-size: .76rem; color: var(--rv-faint); margin-top: 6px; }

/* Chips */
.rv-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.rv-chip { background: var(--rv-surface-2); border: 1.5px solid var(--rv-line); color: var(--rv-text); border-radius: 999px; padding: 11px 18px; font-family: inherit; font-size: .92rem; cursor: pointer; transition: .15s; }
.rv-chip:hover { border-color: var(--rv-line-strong); }
.rv-chip.sel { background: rgba(139, 92, 246, .16); border-color: var(--rv-purple); color: #fff; }

/* Consent */
.rv-consents { display: flex; flex-direction: column; gap: 12px; }
.rv-consent { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px; background: var(--rv-surface-2); border: 1px solid var(--rv-line); border-radius: var(--rv-radius-sm); cursor: pointer; }
.rv-consent input { position: absolute; opacity: 0; width: 0; height: 0; }
.rv-consent-box { flex: 0 0 auto; width: 22px; height: 22px; border-radius: 6px; border: 1.5px solid var(--rv-line-strong); margin-top: 1px; transition: .15s; position: relative; }
.rv-consent input:checked + .rv-consent-box { background: var(--rv-grad); border-color: transparent; }
.rv-consent input:checked + .rv-consent-box::after { content: "✓"; color: #fff; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: .85rem; }
.rv-consent input:focus-visible + .rv-consent-box { box-shadow: var(--rv-ring); }
.rv-consent-text { font-size: .92rem; color: var(--rv-text); }
.rv-consent-legal { font-size: .78rem; color: var(--rv-faint); margin: 4px 2px 0; }

/* Warnings / errors */
.rv-warn { margin-top: 16px; padding: 12px 14px; background: rgba(236, 72, 153, .1); border: 1px solid rgba(236, 72, 153, .3); border-radius: 10px; font-size: .88rem; color: #f7b6d6; }
.rv-error { margin-top: 14px; color: #ff9db5; font-size: .9rem; }

/* Nav */
.rv-nav { display: flex; align-items: center; gap: 12px; margin-top: 26px; }
.rv-nav-center { justify-content: center; flex-wrap: wrap; }
.rv-nav .rv-btn-primary { margin-left: auto; }
.rv-nav-center .rv-btn-primary { margin-left: 0; }
.rv-hide { visibility: hidden; }
.rv-skip { background: none; border: none; color: var(--rv-faint); font-family: inherit; font-size: .86rem; cursor: pointer; text-decoration: underline; }
.rv-skip:hover { color: var(--rv-muted); }

/* ---- Review screen ------------------------------------------------------ */
.rv-review-list { display: flex; flex-direction: column; gap: 14px; margin: 8px 0 4px; }
.rv-review-sec { background: var(--rv-surface); border: 1px solid var(--rv-line); border-radius: var(--rv-radius-sm); padding: 16px 18px; }
.rv-review-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.rv-review-head h3 { margin: 0; font-size: 1rem; color: var(--rv-purple); }
.rv-edit { background: none; border: 1px solid var(--rv-line); color: var(--rv-muted); border-radius: 8px; padding: 5px 14px; font-family: inherit; font-size: .8rem; cursor: pointer; }
.rv-edit:hover { color: #fff; border-color: var(--rv-line-strong); }
.rv-review-row { display: flex; justify-content: space-between; gap: 16px; padding: 7px 0; border-top: 1px solid var(--rv-line); font-size: .9rem; }
.rv-review-q { color: var(--rv-muted); flex: 1; }
.rv-review-a { color: var(--rv-text); text-align: right; flex: 1; font-weight: 500; }

/* ---- Analysing screen --------------------------------------------------- */
.rv-analysing { text-align: center; padding: 10vh 0; }
.rv-scan { position: relative; width: 130px; height: 130px; margin: 0 auto 30px; }
.rv-scan-ring { position: absolute; inset: 0; border-radius: 50%; border: 3px solid transparent; border-top-color: var(--rv-purple); border-right-color: var(--rv-pink); animation: rvSpin 1s linear infinite; }
.rv-scan-core { position: absolute; inset: 18px; border-radius: 50%; background: var(--rv-grad); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 1.6rem; letter-spacing: -1px; box-shadow: 0 0 40px rgba(139, 92, 246, .6); }
@keyframes rvSpin { to { transform: rotate(360deg); } }
.rv-analysing h2 { font-size: 1.3rem; font-weight: 600; }
.rv-scan-steps { display: inline-flex; flex-direction: column; gap: 8px; margin-top: 18px; text-align: left; }
.rv-scan-step { color: var(--rv-muted); font-size: .92rem; animation: rvFade .4s; }
.rv-scan-step.done { color: #93e6b8; }

/* ---- Results ------------------------------------------------------------ */
.rv-results { animation: rvFade .5s; }

/* Wide results canvas: full-width hero + 3-up cards, but the narrative
   (intro, diagnosis, collapsible sections, next steps) stays centred. */
.rv-app.rv-results-mode { max-width: 1240px; }
.rv-app.rv-results-mode .rv-results { max-width: none; }
.rv-app.rv-results-mode .rv-result-hero,
.rv-app.rv-results-mode .rv-diag,
.rv-app.rv-results-mode .rv-coll,
.rv-app.rv-results-mode .rv-next { max-width: 880px; margin-left: auto; margin-right: auto; }

.rv-result-hero { text-align: center; margin-bottom: 30px; }
.rv-result-badge { display: inline-block; padding: 6px 16px; border-radius: 999px; background: rgba(139, 92, 246, .14); border: 1px solid rgba(139, 92, 246, .3); color: #c9b8ff; font-size: .8rem; margin-bottom: 16px; }
.rv-result-hero h1 { font-size: clamp(1.7rem, 4.5vw, 2.6rem); letter-spacing: -1px; line-height: 1.12; margin: 0 0 12px; }
.rv-result-hero p { color: var(--rv-muted); max-width: 640px; margin: 0 auto; }

.rv-result-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; margin-bottom: 26px; }
@media (max-width: 880px) { .rv-result-grid { grid-template-columns: 1fr; } }
.rv-rcard { background: var(--rv-surface); border: 1px solid var(--rv-line); border-radius: var(--rv-radius); padding: 22px; }
.rv-rcard-eyebrow { font-size: .74rem; letter-spacing: .1em; text-transform: uppercase; color: var(--rv-purple); font-weight: 600; margin-bottom: 8px; }
.rv-rcard h2 { margin: 0 0 6px; font-size: 1.4rem; }
.rv-rcard h3 { margin: 0 0 8px; font-size: 1.1rem; }
.rv-rcard-feature { background: linear-gradient(140deg, rgba(139,92,246,.18), rgba(99,102,241,.08)); border-color: rgba(139, 92, 246, .35); }
.rv-rcard p { color: var(--rv-muted); font-size: .92rem; margin: 0; }

.rv-score-top { display: flex; align-items: baseline; gap: 14px; margin: 4px 0 12px; }
.rv-score-num { font-size: 2.8rem; font-weight: 800; letter-spacing: -1.5px; background: var(--rv-grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.rv-score-num span { font-size: 1rem; color: var(--rv-faint); -webkit-text-fill-color: var(--rv-faint); }
.rv-score-status { padding: 5px 14px; border-radius: 999px; background: rgba(147, 230, 184, .14); color: #93e6b8; font-size: .82rem; font-weight: 600; }
.rv-score-detail summary { cursor: pointer; color: var(--rv-muted); font-size: .85rem; margin-bottom: 10px; }
.rv-score-row { margin-bottom: 10px; }
.rv-score-row-head { display: flex; justify-content: space-between; font-size: .82rem; margin-bottom: 4px; }
.rv-score-val { color: var(--rv-muted); }
.rv-score-track { height: 6px; background: rgba(255, 255, 255, .07); border-radius: 999px; overflow: hidden; }
.rv-score-fill { height: 100%; background: var(--rv-grad); }
.rv-rcard-audit .rv-audit-pending { margin-top: 14px; display: flex; align-items: center; gap: 9px; font-size: .85rem; color: var(--rv-muted); padding: 10px 12px; background: rgba(255,255,255,.04); border: 1px solid var(--rv-line); border-radius: 10px; }
.rv-audit-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--rv-purple); box-shadow: 0 0 0 0 rgba(139,92,246,.6); animation: rvPulse 1.8s infinite; }
@keyframes rvPulse { 0% { box-shadow: 0 0 0 0 rgba(139,92,246,.5); } 70% { box-shadow: 0 0 0 8px rgba(139,92,246,0); } 100% { box-shadow: 0 0 0 0 rgba(139,92,246,0); } }

/* Digital standing — screenshot + illustrative upside */
.rv-standing { margin: 0 0 40px; }
.rv-standing-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr); gap: 28px; align-items: start; }
.rv-standing-shot { position: relative; border-radius: 16px; overflow: hidden; border: 1px solid rgba(255,255,255,.1); background: #0c1116; aspect-ratio: 16 / 11; box-shadow: 0 24px 60px -28px rgba(0,0,0,.7); }
.rv-shot-skeleton { position: absolute; inset: 0; background: linear-gradient(110deg, #11171e 30%, #1a232c 50%, #11171e 70%); background-size: 220% 100%; animation: rvShimmer 1.4s ease-in-out infinite; }
@keyframes rvShimmer { 0% { background-position: 120% 0; } 100% { background-position: -120% 0; } }
.rv-standing-img { position: relative; z-index: 1; width: 100%; height: 100%; object-fit: cover; object-position: top center; opacity: 0; transition: opacity .5s ease; }
.rv-standing-shot.loaded .rv-standing-img { opacity: 1; }
.rv-standing-shot.loaded .rv-shot-skeleton { display: none; }
.rv-standing-shot.failed .rv-standing-img { display: none; }
.rv-standing-shot.failed::after { content: "Snapshot loading on our side — your strategist will include it."; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; text-align: center; padding: 24px; color: var(--rv-muted); font-size: .9rem; z-index: 2; }
.rv-shot-tag { position: absolute; left: 12px; bottom: 12px; z-index: 2; font-size: .7rem; letter-spacing: .04em; text-transform: uppercase; color: #fff; background: rgba(10,14,18,.66); backdrop-filter: blur(6px); border: 1px solid rgba(255,255,255,.14); border-radius: 999px; padding: 5px 12px; }
.rv-standing-shot-empty { display: flex; align-items: center; justify-content: center; }
.rv-shot-empty-inner { text-align: center; padding: 28px; color: var(--rv-muted); }
.rv-shot-empty-inner span { font-size: 2rem; display: block; margin-bottom: 10px; }
.rv-standing-claim-h { font-size: clamp(1.4rem, 3.4vw, 2.05rem); letter-spacing: -.6px; line-height: 1.18; margin: 0 0 8px; }
.rv-standing-big { background: linear-gradient(100deg, #8b5cf6, #ec4899); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; white-space: nowrap; }
.rv-standing-illus { color: var(--rv-faint); font-size: .82rem; margin: 0 0 18px; }
.rv-standing-metrics { display: flex; flex-direction: column; gap: 16px; margin-bottom: 22px; }
.rv-standing-metric-head { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; margin-bottom: 6px; }
.rv-standing-metric-label { font-weight: 600; font-size: .92rem; }
.rv-standing-metric-vals { font-size: .82rem; color: var(--rv-muted); }
.rv-standing-metric-vals b { color: #cdd3da; }
.rv-standing-pot { color: #93e6b8 !important; }
.rv-standing-arrow { opacity: .6; }
.rv-standing-track { position: relative; height: 8px; border-radius: 999px; background: rgba(255,255,255,.07); overflow: hidden; }
.rv-standing-fill-pot { position: absolute; left: 0; top: 0; height: 100%; border-radius: 999px; background: linear-gradient(90deg, rgba(147,230,184,.4), rgba(147,230,184,.6)); }
.rv-standing-fill-cur { position: absolute; left: 0; top: 0; height: 100%; border-radius: 999px; background: linear-gradient(90deg, #8b5cf6, #6366f1); transition: width 1s cubic-bezier(.2,.8,.2,1); }
.rv-standing-note { font-size: .82rem; color: var(--rv-muted); margin: 7px 0 0; }
.rv-standing-cta { width: 100%; }
@media (max-width: 760px) { .rv-standing-grid { grid-template-columns: 1fr; gap: 18px; } }

/* Diagnosis & education */
.rv-diag { margin-bottom: 38px; }
.rv-kicker-pill { display: inline-block; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: #93e6b8; background: rgba(147,230,184,.12); border: 1px solid rgba(147,230,184,.28); border-radius: 999px; padding: 5px 14px; margin-bottom: 14px; font-weight: 600; }
.rv-diag h2 { font-size: clamp(1.4rem, 3.5vw, 2rem); letter-spacing: -.6px; margin: 0 0 6px; }
.rv-diag-list { display: flex; flex-direction: column; gap: 10px; }
/* collapsible accordion item */
.rv-diag-item { background: var(--rv-surface); border: 1px solid var(--rv-line); border-left: 3px solid var(--rv-pink); border-radius: var(--rv-radius-sm); overflow: hidden; transition: border-color .25s, background .25s; }
.rv-diag-item.open { background: var(--rv-surface-2); }
.rv-diag-head { width: 100%; display: flex; align-items: center; gap: 14px; padding: 16px 18px; background: none; border: none; cursor: pointer; text-align: left; color: var(--rv-text); font-family: inherit; }
.rv-diag-num { flex: 0 0 auto; width: 30px; height: 30px; border-radius: 50%; background: rgba(236,72,153,.16); color: #f7b6d6; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .9rem; }
.rv-diag-title { flex: 1; font-size: 1.05rem; font-weight: 600; line-height: 1.3; }
.rv-diag-chev { flex: 0 0 auto; color: var(--rv-muted); font-size: 1.2rem; transition: transform .35s cubic-bezier(.2,.8,.2,1); }
.rv-diag-item.open .rv-diag-chev { transform: rotate(180deg); color: var(--rv-pink); }
/* slick open/close via grid-template-rows 0fr -> 1fr */
.rv-diag-panel { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .42s cubic-bezier(.2,.8,.2,1); }
.rv-diag-item.open .rv-diag-panel { grid-template-rows: 1fr; }
.rv-diag-panel-inner { overflow: hidden; opacity: 0; transition: opacity .3s ease .05s; }
.rv-diag-item.open .rv-diag-panel-inner { opacity: 1; }
.rv-diag-problem { color: var(--rv-muted); font-size: .92rem; margin: 0 18px 14px; }
.rv-diag-rows { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; padding: 0 18px; }
.rv-diag-row span { display: block; font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 600; margin-bottom: 3px; }
.rv-diag-row p { margin: 0; font-size: .88rem; color: var(--rv-text); }
.rv-diag-cost span { color: var(--rv-pink); }
.rv-diag-fix span { color: #93e6b8; }
.rv-diag-evidence { margin: 14px 18px 18px; font-size: .8rem; color: var(--rv-faint); border-top: 1px solid var(--rv-line); padding-top: 10px; }
.rv-diag-rows + .rv-diag-evidence { margin-top: 14px; }
.rv-diag-panel-inner > .rv-diag-rows:last-child { padding-bottom: 18px; }
@media (max-width: 560px) { .rv-diag-rows { grid-template-columns: 1fr; } }

/* Collapsible main sections (opportunity map / platform / roadmap) */
.rv-coll-head { width: 100%; display: flex; align-items: center; gap: 14px; background: none; border: none; padding: 6px 0; cursor: pointer; text-align: left; color: inherit; font-family: inherit; border-bottom: 1px solid var(--rv-line); margin-bottom: 14px; }
.rv-coll-head h2 { flex: 1; margin: 0 !important; }
.rv-coll-chev { flex: 0 0 auto; color: var(--rv-muted); font-size: 1.5rem; line-height: 1; transition: transform .38s cubic-bezier(.2,.8,.2,1); }
.rv-coll.open > .rv-coll-head .rv-coll-chev { transform: rotate(180deg); color: var(--rv-purple); }
.rv-coll-panel { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .44s cubic-bezier(.2,.8,.2,1); }
.rv-coll.open > .rv-coll-panel { grid-template-rows: 1fr; }
.rv-coll-inner { overflow: hidden; opacity: 0; transition: opacity .3s ease .06s; }
.rv-coll.open > .rv-coll-panel > .rv-coll-inner { opacity: 1; }

/* Opportunity map */
.rv-omap { margin-bottom: 34px; }
.rv-omap h2, .rv-platform h2, .rv-next h2 { font-size: clamp(1.4rem, 3.5vw, 2rem); letter-spacing: -.6px; margin: 0 0 6px; }
.rv-omap-sub { color: var(--rv-muted); margin: 0 0 20px; font-size: .95rem; }
.rv-omap-group { margin-bottom: 22px; }
.rv-omap-gtitle { font-size: .95rem; font-weight: 700; margin: 0 0 12px; display: inline-flex; align-items: center; gap: 8px; padding: 5px 14px; border-radius: 999px; }
.rv-omap-immediate { background: rgba(147,230,184,.14); color: #93e6b8; }
.rv-omap-core { background: rgba(139,92,246,.16); color: #c9b8ff; }
.rv-omap-growth { background: rgba(99,102,241,.16); color: #a5b4fc; }
.rv-omap-advanced { background: rgba(236,72,153,.14); color: #f7b6d6; }
.rv-omap-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 14px; }
.rv-ocard { background: var(--rv-surface); border: 1px solid var(--rv-line); border-radius: var(--rv-radius-sm); padding: 18px; }
.rv-ocard-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 6px; }
.rv-ocard-top h4 { margin: 0; font-size: 1.05rem; }
.rv-ocard-cx { font-size: .72rem; padding: 3px 9px; border-radius: 999px; background: rgba(255,255,255,.06); color: var(--rv-muted); white-space: nowrap; }
.rv-ocard-problem { color: var(--rv-muted); font-size: .88rem; margin: 0 0 12px; font-style: italic; }
.rv-ocard-flow { margin: 0; display: flex; flex-direction: column; gap: 8px; }
.rv-ocard-flow div { display: flex; flex-direction: column; gap: 1px; }
.rv-ocard-flow dt { font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; color: var(--rv-purple); font-weight: 600; }
.rv-ocard-flow dd { margin: 0; font-size: .86rem; color: var(--rv-text); }

/* Platform board */
.rv-platform { margin-bottom: 34px; }
.rv-platform-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 14px; }
.rv-pmod { background: var(--rv-surface); border: 1px solid var(--rv-line); border-radius: var(--rv-radius-sm); padding: 16px 18px; }
.rv-pmod.is-you { border-color: rgba(139, 92, 246, .4); }
.rv-pmod-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 6px; }
.rv-pmod-head h4 { margin: 0; font-size: 1rem; }
.rv-pmod p { color: var(--rv-muted); font-size: .86rem; margin: 0; }
.rv-tag { font-size: .68rem; padding: 3px 9px; border-radius: 999px; font-weight: 600; white-space: nowrap; }
.rv-tag-you { background: rgba(139,92,246,.2); color: #c9b8ff; }
.rv-tag-hiyya { background: rgba(255,255,255,.07); color: var(--rv-muted); }

/* Roadmap */
.rv-roadmap { margin-bottom: 34px; }
.rv-roadmap-track { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
.rv-phase { background: var(--rv-surface); border: 1px solid var(--rv-line); border-radius: var(--rv-radius-sm); padding: 16px; }
.rv-phase-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; padding-bottom: 10px; border-bottom: 1px solid var(--rv-line); }
.rv-phase-name { font-weight: 700; font-size: .95rem; }
.rv-phase-count { font-size: .72rem; background: rgba(139,92,246,.18); color: #c9b8ff; border-radius: 999px; padding: 2px 9px; }
.rv-phase-items { display: flex; flex-direction: column; gap: 10px; }
.rv-phase-item { display: flex; flex-direction: column; gap: 2px; }
.rv-phase-item strong { font-size: .9rem; font-weight: 600; }
.rv-phase-item span { font-size: .8rem; color: var(--rv-muted); }

/* Next steps */
.rv-next { text-align: center; background: linear-gradient(140deg, rgba(139,92,246,.14), rgba(236,72,153,.08)); border: 1px solid rgba(139, 92, 246, .3); border-radius: var(--rv-radius); padding: 34px; }
.rv-next-actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin: 18px 0 12px; }
.rv-next-note { color: var(--rv-muted); font-size: .88rem; margin: 0; }

/* ---- Resume modal ------------------------------------------------------- */
.rv-modal-overlay { position: fixed; inset: 0; z-index: 50; background: rgba(8, 11, 15, .8); backdrop-filter: blur(6px); display: flex; align-items: center; justify-content: center; padding: 20px; }
.rv-modal-overlay[hidden] { display: none; }
.rv-modal { background: var(--rv-surface); border: 1px solid var(--rv-line-strong); border-radius: var(--rv-radius); padding: 30px; max-width: 420px; box-shadow: var(--rv-shadow); animation: rvSlide .35s; }
.rv-modal h2 { margin: 0 0 8px; }
.rv-modal p { color: var(--rv-muted); margin: 0 0 22px; }
.rv-modal-actions { display: flex; gap: 12px; justify-content: flex-end; }

/* ---- Responsive --------------------------------------------------------- */
@media (max-width: 560px) {
  .rv-entry-benefits { grid-template-columns: 1fr; }
  .rv-nav { flex-wrap: wrap; }
  .rv-nav .rv-btn-primary { width: 100%; margin-left: 0; order: -1; }
  .rv-review-row { flex-direction: column; gap: 2px; }
  .rv-review-a { text-align: left; }
}

/* ---- Reduced motion ----------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .rv-scan-ring { border-top-color: var(--rv-purple); }
}

/* ---- Print (save review) ------------------------------------------------ */
@media print {
  .rv-bg, .rv-topbar, .rv-next-actions, .rv-modal-overlay { display: none !important; }
  body { background: #fff; color: #111; }
  .rv-rcard, .rv-ocard, .rv-pmod, .rv-omap-group { break-inside: avoid; border-color: #ddd; background: #fff; }
  .rv-grad, .rv-score-num { -webkit-text-fill-color: #6d28d9; color: #6d28d9; }
}
