*{box-sizing:border-box;margin:0;padding:0}
:root{--ac:#7C3AED;--ac2:#A78BFA;--bg:#07070D;--bg2:#0F0F1C;--bg3:#111120;--brd:#1A1A2E;--nav:#090910}
html,body{height:100%;background:var(--bg);overflow:hidden}
body{font-family:'Outfit',sans-serif;color:#F0F0FF;-webkit-font-smoothing:antialiased}
#root{position:fixed;inset:0;max-width:430px;margin:0 auto;overflow:hidden;transition:background .35s}

/* ── Screens ─────────────────────────────────────────────────────────────── */
.page{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .22s ease,transform .22s ease;transform:translateX(12px)}
.page.on{opacity:1;pointer-events:all;transform:none}

/* Scrollable content pages (have bottom nav) */
.scroll-page{position:absolute;top:0;left:0;right:0;bottom:72px;overflow-y:auto;overflow-x:hidden;padding:56px 15px 20px;scrollbar-width:none}
.scroll-page::-webkit-scrollbar{display:none}

/* Full-screen pages (no nav) */
.full-page{position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}
.full-page::-webkit-scrollbar{display:none}

/* ── Status bar ─────────────────────────────────────────────────────────── */
/* Status bar removed — user's phone provides this */

/* ── Bottom nav ─────────────────────────────────────────────────────────── */
#bnav{position:absolute;bottom:0;left:0;right:0;height:72px;border-top:1px solid #16162A;display:flex;align-items:center;justify-content:space-around;padding:0 2px 10px;z-index:30;background:var(--nav);transition:background .35s}
.ni{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 8px;cursor:pointer;border-radius:12px;min-width:50px;-webkit-tap-highlight-color:transparent}
.ni svg{width:19px;height:19px;stroke:#35355A;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s}
.ni.a svg{stroke:var(--ac)}
.nicta{border-radius:16px;padding:9px 14px;margin-top:-10px;background:var(--ac);transition:background .35s}
.nicta svg{width:22px;height:22px;stroke:#fff!important}
.nlb{font-size:10px;color:#35355A;font-weight:500;transition:color .2s}
.ni.a .nlb{color:var(--ac)}
.nicta .nlb{color:rgba(255,255,255,.8)}

/* ── Cards ──────────────────────────────────────────────────────────────── */
.hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px;padding-top:3px}
.ht{font-size:18px;font-weight:800;letter-spacing:-.03em}
.card{background:var(--bg2);border:1px solid var(--brd);border-radius:14px;padding:14px;margin-bottom:9px}
.sl{font-size:10px;font-weight:700;letter-spacing:.1em;color:#35355A;margin-bottom:7px;text-transform:uppercase}

/* ── Pills ──────────────────────────────────────────────────────────────── */
.pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:9999px;font-size:10px;font-weight:700}
.pg{background:rgba(16,185,129,.1);color:#10B981;border:1px solid rgba(16,185,129,.25)}
.pr{background:rgba(239,68,68,.1);color:#EF4444;border:1px solid rgba(239,68,68,.25)}
.po{background:rgba(245,158,11,.1);color:#F59E0B;border:1px solid rgba(245,158,11,.25)}
.pp{background:rgba(124,58,237,.1);color:var(--ac2);border:1px solid rgba(124,58,237,.3)}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn{width:100%;height:50px;border:none;border-radius:13px;color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:'Outfit',sans-serif;background:var(--ac);transition:background .35s,opacity .15s,transform .1s;-webkit-tap-highlight-color:transparent}
.btn:active{transform:scale(.97);opacity:.85}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn-ghost{width:100%;height:44px;background:transparent;border:1.5px solid var(--brd);border-radius:12px;color:#7A7A9D;font-size:13px;font-weight:600;cursor:pointer;font-family:'Outfit',sans-serif;margin-top:9px;-webkit-tap-highlight-color:transparent}
.btn-sm{height:34px;padding:0 14px;border:none;border-radius:9px;color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:'Outfit',sans-serif;background:var(--ac)}

/* ── Inputs ─────────────────────────────────────────────────────────────── */
.inp{width:100%;height:50px;background:var(--bg3);border:1.5px solid var(--brd);border-radius:13px;color:#F0F0FF;font-family:'Outfit',sans-serif;font-size:14px;padding:0 16px;outline:none;margin-bottom:10px;transition:border-color .2s;-webkit-appearance:none}
.inp:focus{border-color:var(--ac)}
.inp::placeholder{color:#35355A}

/* ── Platform switcher ──────────────────────────────────────────────────── */
.psw-wrap{display:flex;background:var(--bg3);border:1px solid var(--brd);border-radius:10px;padding:3px;gap:2px}
.psw{padding:4px 9px;border-radius:7px;font-size:10px;font-weight:700;cursor:pointer;transition:all .22s;border:1.5px solid transparent;font-family:'Outfit',sans-serif;color:#35355A;-webkit-tap-highlight-color:transparent}
.psw.on{color:var(--ac);border-color:var(--ac);background:rgba(255,255,255,.04)}

/* ── Progress bars ──────────────────────────────────────────────────────── */
.trk{height:4px;background:#16162A;border-radius:9999px;overflow:hidden}
.tf{height:100%;border-radius:9999px;width:0;transition:width 1.1s cubic-bezier(.22,1,.36,1)}

/* ── Toggle ─────────────────────────────────────────────────────────────── */
.tog{width:40px;height:22px;border-radius:11px;background:#1A1A2E;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.tog.on{background:var(--ac)}
.tog::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s}
.tog.on::after{transform:translateX(18px)}

/* ── Icon button ─────────────────────────────────────────────────────────── */
.ibt{width:32px;height:32px;background:var(--bg3);border:1px solid var(--brd);border-radius:9px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}
.ibt svg{width:15px;height:15px;stroke:#7A7A9D;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* ── Live dot ─────────────────────────────────────────────────────────────── */
.live{width:6px;height:6px;border-radius:50%;background:#10B981;display:inline-block;animation:blink 2s ease-in-out infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ── Analyze tabs ────────────────────────────────────────────────────────── */
.tab3{display:flex;gap:3px;background:var(--bg3);border:1px solid var(--brd);border-radius:9px;padding:3px}
.t3{flex:1;text-align:center;padding:6px 0;border-radius:7px;font-size:11px;font-weight:700;color:#35355A;cursor:pointer;transition:all .18s;border:none;background:transparent;font-family:'Outfit',sans-serif;-webkit-tap-highlight-color:transparent}
.t3.on{background:var(--ac);color:#fff}

/* ── Step rows ───────────────────────────────────────────────────────────── */
.step-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid #111120;opacity:.3}
.step-row.done,.step-row.act{opacity:1}
.step-row:last-child{border-bottom:none}
.step-ic{width:16px;height:16px;border-radius:50%;background:#1A1A2E;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.step-ic.done{background:rgba(16,185,129,.15)}
.step-ic.act{background:rgba(124,58,237,.15)}
.step-lbl{font-size:11px;color:#7A7A9D}
.step-lbl.done{color:#F0F0FF}
.step-lbl.act{color:var(--ac2)}

/* ── Agent bubble ────────────────────────────────────────────────────────── */
.ab{border-left:3px solid;border-radius:0 11px 11px 11px;padding:9px 12px;margin-bottom:7px;background:var(--bg3);animation:fadeUp .3s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ── Insight row ─────────────────────────────────────────────────────────── */
.ir{display:flex;align-items:flex-start;gap:8px;padding:7px 0;border-bottom:1px solid #111120}
.ir:last-child{border-bottom:none}
.idot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:4px}

/* ── Blocker row ─────────────────────────────────────────────────────────── */
.bkr{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid #111120}
.bkr:last-child{border-bottom:none}

/* ── Rival card ──────────────────────────────────────────────────────────── */
.rv-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #111120}
.rv-row:last-child{border-bottom:none}

/* ── Account chip ────────────────────────────────────────────────────────── */
.ac-chip{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:9px;cursor:pointer;border:1.5px solid var(--brd);transition:all .2s;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.ac-chip.sel{border-color:var(--ac);background:rgba(255,255,255,.04)}

/* ── Sparkbar ────────────────────────────────────────────────────────────── */
.spk{border-radius:2px 2px 0 0;transition:height .9s cubic-bezier(.22,1,.36,1)}

/* ── Niche bar ───────────────────────────────────────────────────────────── */
.nb-t{height:5px;background:#16162A;border-radius:9999px;overflow:hidden}
.nb-f{height:100%;border-radius:9999px;width:0;transition:width 1.2s cubic-bezier(.22,1,.36,1)}

/* ── Modal ───────────────────────────────────────────────────────────────── */
#modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.72);z-index:100;display:none;align-items:flex-end;justify-content:center}
#modal-overlay.open{display:flex}
.modal-sheet{background:var(--bg2);border-radius:20px 20px 0 0;padding:16px 15px 32px;width:100%;max-height:88%;overflow-y:auto;scrollbar-width:none}
.modal-sheet::-webkit-scrollbar{display:none}
.mh{width:40px;height:4px;background:#35355A;border-radius:2px;margin:0 auto 16px}

/* ── Toast ───────────────────────────────────────────────────────────────── */
#toast{position:absolute;top:58px;left:15px;right:15px;border-radius:11px;padding:11px 14px;z-index:300;display:flex;align-items:center;gap:8px;transition:opacity .3s;opacity:0;pointer-events:none;background:#10B981}
#toast.show{opacity:1}
#toast.err{background:#EF4444}

/* ── Spinner ─────────────────────────────────────────────────────────────── */
.spin{width:28px;height:28px;border:3px solid var(--brd);border-top-color:var(--ac);border-radius:50%;animation:rot .7s linear infinite;margin:20px auto;display:block}
@keyframes rot{to{transform:rotate(360deg)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Action chip ─────────────────────────────────────────────────────────── */
.achip{display:inline-flex;align-items:center;padding:6px 11px;border-radius:9px;background:var(--bg3);border:1px solid var(--brd);font-size:11px;font-weight:600;color:var(--ac2);cursor:pointer;margin:0 5px 5px 0;font-family:'Outfit',sans-serif;-webkit-tap-highlight-color:transparent}

/* ── Trend window ────────────────────────────────────────────────────────── */
.tw{border-radius:13px;padding:12px 13px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}

/* ── Settings row ────────────────────────────────────────────────────────── */
.sr{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid #111120;cursor:pointer;-webkit-tap-highlight-color:transparent}
.sr:last-child{border-bottom:none}

/* ─────────────────────────────────────────────────────────────────────────
   ONBOARDING
───────────────────────────────────────────────────────────────────────── */

/* Landing (step 0 — the psychological hook) */
/* ─── BACKGROUND ORBS ─────────────────────────────────────────────────────── */
.orb{position:fixed;border-radius:50%;pointer-events:none;z-index:0;filter:blur(90px);will-change:transform}
#orb1{width:340px;height:340px;background:#4C1D95;top:-100px;right:-80px;opacity:.22;animation:drift1 15s ease-in-out infinite alternate}
#orb2{width:280px;height:280px;background:#1E3A5F;bottom:80px;left:-90px;opacity:.17;animation:drift2 11s ease-in-out infinite alternate}
#orb3{width:200px;height:200px;background:#134E4A;top:55%;right:-50px;opacity:.13;animation:drift3 9s ease-in-out infinite alternate}
@keyframes drift1{from{transform:translate(0,0) scale(1)}to{transform:translate(-28px,44px) scale(1.1)}}
@keyframes drift2{from{transform:translate(0,0) scale(1)}to{transform:translate(36px,-28px) scale(1.08)}}
@keyframes drift3{from{transform:translate(0,0) scale(1)}to{transform:translate(-18px,22px) scale(1.14)}}

/* ─── LANDING (single page, no scroll-snap) ──────────────────────────────── */
.land-ghost2{width:100%;height:42px;background:transparent;border:1.5px solid var(--brd);border-radius:12px;color:#7A7A9D;font-size:13px;font-weight:600;cursor:pointer;font-family:'Outfit',sans-serif;margin-top:8px;-webkit-tap-highlight-color:transparent}

/* ─── STORIES WELCOME SCREEN v2 ──────────────────────────────────────────── */
@keyframes welBrPls{0%,100%{opacity:.5;}50%{opacity:1;}}
@keyframes welDp{from{opacity:0;transform:scale(0);}to{opacity:1;transform:scale(1);}}
@keyframes welSbGw{from{width:0;}}
@keyframes welFlash{0%{transform:translateY(-50%) scale(0);opacity:1;}100%{transform:translateY(-50%) scale(1);opacity:0;}}
.wel-flash{position:absolute;top:50%;width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.14);pointer-events:none;transform:translateY(-50%) scale(0);opacity:0;}
.wel-tap-left .wel-flash{left:20px;}.wel-tap-right .wel-flash{right:20px;}
.wel-flash.go{animation:welFlash .32s ease forwards;}
.wel-brain-svg{width:100%;margin-bottom:10px;}.wel-brain-svg svg{width:100%;height:auto;display:block;}
.wel-brain-pills{display:flex;flex-wrap:wrap;gap:5px;width:100%;margin-bottom:8px;}
.wel-br-pill{font-family:var(--fb,'DM Sans',sans-serif);font-size:9px;font-weight:700;padding:3px 8px;border-radius:99px;letter-spacing:.06em;text-transform:uppercase;opacity:0;animation:welDp .3s ease both;}
.wel-gen-box{width:100%;background:rgba(255,255,255,.025);border:1px solid #1A1A2E;border-radius:13px;padding:13px;margin-bottom:10px;}
.wel-gen-row{display:flex;align-items:center;gap:9px;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.04);}.wel-gen-row:last-child{border-bottom:none;}
.wel-gen-label{font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:.04em;flex-shrink:0;width:82px;line-height:1.15;}
.wel-gen-age{font-family:var(--fb,'DM Sans',sans-serif);font-size:9px;color:#35355A;font-weight:500;flex-shrink:0;width:36px;}
.wel-gen-bw{flex:1;height:4px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden;}
.wel-gen-bf{height:100%;border-radius:99px;animation:welSbGw .9s ease both;}
.wel-gen-pct{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:.02em;min-width:34px;text-align:right;}
.wel-vs-table{width:100%;background:rgba(255,255,255,.025);border:1px solid #1A1A2E;border-radius:13px;overflow:hidden;margin-bottom:10px;}
.wel-vs-head{display:flex;border-bottom:1px solid #1A1A2E;}
.wel-vs-col-h{flex:1;padding:8px 10px;text-align:center;font-family:var(--fb,'DM Sans',sans-serif);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;}
.wel-vs-col-h.them{background:rgba(239,68,68,.06);color:rgba(239,68,68,.5);}
.wel-vs-col-h.us{background:rgba(124,58,237,.08);color:#A78BFA;}
.wel-vs-row{display:flex;border-top:1px solid rgba(255,255,255,.04);}
.wel-vs-cell{flex:1;padding:8px 10px;font-family:var(--fb,'DM Sans',sans-serif);font-size:clamp(10px,2.8vw,11px);line-height:1.4;display:flex;align-items:center;gap:5px;}
.wel-vs-cell.them{color:#7A7A9D;}.wel-vs-cell.us{color:#C0C0D8;}
.wel-vs-x{color:#EF4444;font-weight:700;flex-shrink:0;}
.wel-vs-ch{color:#10B981;font-weight:700;flex-shrink:0;}
.wel-vs-note{width:100%;background:rgba(124,58,237,.06);border:1px solid rgba(124,58,237,.18);border-radius:11px;padding:10px 13px;}
.wel-vs-note-t{font-family:var(--fb,'DM Sans',sans-serif);font-size:12px;font-weight:700;color:#A78BFA;margin-bottom:2px;}
.wel-vs-note-b{font-family:var(--fb,'DM Sans',sans-serif);font-size:11px;color:#7A7A9D;line-height:1.5;}
.wel-pain-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
#ob-landing{display:flex;flex-direction:column;overflow:hidden;width:100%;height:100%;}
#ob-landing .wel-segs{display:flex;gap:3px;padding:12px 12px 0;z-index:100;}
#ob-landing .wel-seg{flex:1;height:2px;background:rgba(255,255,255,.1);border-radius:99px;overflow:hidden;}
#ob-landing .wel-seg-fill{height:100%;background:rgba(167,139,250,.9);width:0%;border-radius:99px;}
#ob-landing .wel-pi{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%) scale(0);width:46px;height:46px;background:rgba(7,7,13,.85);border:1px solid rgba(124,58,237,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:200;transition:transform .12s;pointer-events:none;}
#ob-landing .wel-pi.show{transform:translate(-50%,-50%) scale(1);}
#ob-landing .wel-va{flex:1;min-height:0;position:relative;overflow:hidden;cursor:pointer;}
#ob-landing .wel-tap-zone{position:absolute;top:0;bottom:0;z-index:50;cursor:pointer;}
#ob-landing .wel-tap-left{left:0;width:32%;}
#ob-landing .wel-tap-right{right:0;width:32%;}
#ob-landing .wel-tap-mid{left:32%;width:36%;}
#ob-landing .wel-tap-hint{position:absolute;bottom:18px;font-family:'DM Sans',sans-serif;font-size:9px;font-weight:500;color:rgba(255,255,255,.12);letter-spacing:.06em;text-transform:uppercase;pointer-events:none;opacity:1;transition:opacity 1.5s ease 2s;}
#ob-landing .wel-tap-hint.hide{opacity:0;}
#ob-landing .wel-tap-left .wel-tap-hint{left:10px;}
#ob-landing .wel-tap-right .wel-tap-hint{right:10px;}
#ob-landing .wel-sc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:clamp(36px,8vw,44px) clamp(16px,4.5vw,20px) 16px;opacity:0;pointer-events:none;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-webkit-overflow-scrolling:touch;transition:opacity .6s ease;}
#ob-landing .wel-sc::-webkit-scrollbar{display:none;}
#ob-landing .wel-sc.on{opacity:1;pointer-events:all;}
#ob-landing .wel-sc.leaving{opacity:0;pointer-events:none;transition:opacity .5s ease;}
#ob-landing .wel-fu{opacity:0;transform:translateY(10px);animation:none;}
#ob-landing .wel-fi{opacity:0;animation:none;}
#ob-landing .wel-sc.entered .wel-fu{animation:wel-fu .55s cubic-bezier(.4,0,.2,1) forwards;}
#ob-landing .wel-sc.entered .wel-fi{animation:wel-fi .5s ease forwards;}
@keyframes wel-fu{to{opacity:1;transform:translateY(0);}}
@keyframes wel-fi{to{opacity:1;}}
.wd0{animation-delay:0s;}.wd1{animation-delay:.12s;}.wd2{animation-delay:.26s;}.wd3{animation-delay:.42s;}.wd4{animation-delay:.60s;}.wd5{animation-delay:.80s;}.wd6{animation-delay:1.02s;}
#ob-landing .wel-ab{flex-shrink:0;background:rgba(7,7,13,.97);border-top:1px solid var(--brd);padding:10px 16px 14px;display:flex;flex-direction:column;gap:7px;z-index:150;}
#ob-landing .wel-ab-label{text-align:center;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:500;color:#35355A;letter-spacing:.03em;}
#ob-landing .wel-ab-row{display:flex;gap:8px;}
#ob-landing .wel-ab-btn{flex:1;height:46px;border-radius:12px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;border:none;display:flex;align-items:center;justify-content:center;transition:transform .12s,opacity .12s;}
#ob-landing .wel-ab-btn:active{transform:scale(.96);opacity:.85;}
#ob-landing .wel-ab-btn.wp{background:var(--ac);color:#fff;}
#ob-landing .wel-ab-btn.ws{background:transparent;border:1.5px solid rgba(124,58,237,.3);color:#A78BFA;}
/* Welcome scene specifics */
#ob-landing .wel-glow{position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,.16) 0%,transparent 68%);animation:wel-gp 3.5s ease infinite;pointer-events:none;}
@keyframes wel-gp{0%,100%{opacity:.5;transform:scale(1);}50%{opacity:1;transform:scale(1.1);}}
#ob-landing .wel-li{width:80px;height:80px;background:var(--ac);border-radius:20px;display:flex;align-items:center;justify-content:center;position:relative;z-index:2;}
#ob-landing .wel-ro{width:50px;height:50px;border-radius:50%;border:4px solid rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;animation:wel-rs 2.8s linear infinite;position:relative;}
@keyframes wel-rs{to{transform:rotate(360deg);}}
#ob-landing .wel-ro::before{content:'';position:absolute;width:56px;height:56px;border-radius:50%;border:4px solid transparent;border-top-color:rgba(255,255,255,.3);animation:wel-rs 1.4s ease-in-out infinite;}
#ob-landing .wel-ri2{width:33px;height:33px;border-radius:50%;border:3px solid rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;animation:wel-rs 2.2s linear infinite reverse;}
#ob-landing .wel-rc{width:12px;height:10px;border-radius:50%;background:var(--ac);border:2px solid rgba(255,255,255,.9);}
#ob-landing .wel-logo-name{font-family:'Bebas Neue',sans-serif;font-size:36px;color:#F0F0FF;letter-spacing:.04em;margin-top:16px;position:relative;z-index:2;}
#ob-landing .wel-logo-name span{color:#A78BFA;}
#ob-landing .wel-logo-tag{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:400;color:#7A7A9D;letter-spacing:.12em;text-transform:uppercase;margin-top:8px;position:relative;z-index:2;}
#ob-landing .wel-hl{font-family:'Bebas Neue',sans-serif;font-size:44px;color:#F0F0FF;letter-spacing:.04em;line-height:1.0;text-align:center;width:100%;margin-bottom:6px;}
#ob-landing .wel-hl em{font-style:normal;color:#A78BFA;}
#ob-landing .wel-sub{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:400;color:#7A7A9D;text-align:center;margin-bottom:16px;max-width:280px;line-height:1.55;}
#ob-landing .wel-pain-list{width:100%;display:flex;flex-direction:column;gap:7px;}
#ob-landing .wel-pain-row{background:var(--bg2);border:1px solid var(--brd);border-radius:11px;padding:11px 13px;display:flex;align-items:center;gap:11px;}
#ob-landing .wel-pain-em{font-size:18px;flex-shrink:0;}
#ob-landing .wel-pain-title{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:#F0F0FF;margin-bottom:1px;}
#ob-landing .wel-pain-desc{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:400;color:#7A7A9D;}
#ob-landing .wel-pain-num{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.02em;flex-shrink:0;}
/* VS trials scene */
#ob-landing .wel-vs-hl{font-family:'Bebas Neue',sans-serif;font-size:40px;color:#F0F0FF;letter-spacing:.04em;line-height:1.0;text-align:center;width:100%;margin-bottom:6px;}
#ob-landing .wel-vs-hl em{font-style:normal;color:#EF4444;}
#ob-landing .wel-vs-sub{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:400;color:#7A7A9D;text-align:center;margin-bottom:18px;max-width:280px;line-height:1.55;}
#ob-landing .wel-vs-list{width:100%;display:flex;flex-direction:column;gap:7px;}
#ob-landing .wel-vs-row{background:var(--bg2);border:1px solid var(--brd);border-radius:11px;padding:11px 13px;display:flex;align-items:center;gap:11px;}
#ob-landing .wel-vs-em{font-size:18px;flex-shrink:0;}
#ob-landing .wel-vs-title{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:#F0F0FF;margin-bottom:1px;}
#ob-landing .wel-vs-desc{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:400;color:#7A7A9D;}
#ob-landing .wel-vs-x{font-family:'Bebas Neue',sans-serif;font-size:20px;color:#EF4444;flex-shrink:0;}
#ob-landing .wel-tag{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ac);margin-bottom:6px;align-self:flex-start;}
#ob-landing .wel-mf-hl{font-family:'Bebas Neue',sans-serif;font-size:40px;color:#F0F0FF;letter-spacing:.04em;line-height:1.0;width:100%;margin-bottom:4px;}
#ob-landing .wel-mf-hl span{color:#A78BFA;}
#ob-landing .wel-mf-sub{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:400;color:#7A7A9D;margin-bottom:14px;width:100%;line-height:1.5;}
#ob-landing .wel-mf-grid{display:grid;grid-template-columns:repeat(20,1fr);gap:3px;width:100%;margin-bottom:12px;}
#ob-landing .wel-mf-dot{width:100%;aspect-ratio:1;border-radius:50%;background:var(--ac);opacity:0;animation:wel-dp .06s ease forwards;}
#ob-landing .wel-mf-dot.gone{background:#EF4444;opacity:.22!important;}
@keyframes wel-dp{from{opacity:0;transform:scale(0);}to{opacity:1;transform:scale(1);}}
#ob-landing .wel-mf-stats{display:flex;width:100%;background:var(--bg2);border:1px solid var(--brd);border-radius:11px;overflow:hidden;}
#ob-landing .wel-mf-stat{flex:1;text-align:center;padding:10px 0;border-right:1px solid var(--brd);}
#ob-landing .wel-mf-stat:last-child{border-right:none;}
#ob-landing .wel-mf-stat-n{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:.04em;line-height:1;}
#ob-landing .wel-mf-stat-l{font-family:'DM Sans',sans-serif;font-size:9px;font-weight:600;color:#35355A;margin-top:2px;letter-spacing:.08em;text-transform:uppercase;}
#ob-landing .wel-ret-hl{font-family:'Bebas Neue',sans-serif;font-size:42px;color:#F0F0FF;letter-spacing:.04em;line-height:1.0;width:100%;margin-bottom:5px;}
#ob-landing .wel-ret-hl em{font-style:normal;color:#A78BFA;}
#ob-landing .wel-ret-sub{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:400;color:#7A7A9D;width:100%;margin-bottom:13px;line-height:1.5;}
#ob-landing .wel-ret-box{width:100%;background:rgba(255,255,255,.025);border:1px solid var(--brd);border-radius:13px;padding:13px;}
#ob-landing .wel-drop-row{display:flex;align-items:center;gap:9px;background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.18);border-radius:9px;padding:9px 11px;margin-top:10px;}
#ob-landing .wel-drop-t{font-family:'Bebas Neue',sans-serif;font-size:18px;color:#EF4444;letter-spacing:.04em;flex-shrink:0;}
#ob-landing .wel-drop-b{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:400;color:#7A7A9D;flex:1;line-height:1.4;}
#ob-landing .wel-drop-f{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:700;color:#10B981;white-space:nowrap;}
#ob-landing .wel-score-bg{position:absolute;font-family:'Bebas Neue',sans-serif;font-size:200px;color:rgba(124,58,237,.04);line-height:1;pointer-events:none;letter-spacing:.04em;}
#ob-landing .wel-score-wrap{display:flex;flex-direction:column;align-items:center;position:relative;z-index:2;}
#ob-landing .wel-score-ey{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#35355A;margin-bottom:4px;}
#ob-landing .wel-score-n{font-family:'Bebas Neue',sans-serif;font-size:130px;color:#F0F0FF;letter-spacing:.02em;line-height:1;}
#ob-landing .wel-score-vd{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;color:#7A7A9D;margin-top:5px;}
#ob-landing .wel-score-bars{display:flex;gap:10px;margin-top:18px;}
#ob-landing .wel-sb-col{display:flex;flex-direction:column;align-items:center;gap:5px;}
#ob-landing .wel-sb-tr{width:38px;height:66px;background:rgba(255,255,255,.04);border-radius:7px;overflow:hidden;display:flex;align-items:flex-end;}
#ob-landing .wel-sb-fi{width:100%;border-radius:5px;animation:wel-sbu 1s ease both;}
@keyframes wel-sbu{from{height:0;}}
#ob-landing .wel-sb-lb{font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:.06em;}
#ob-landing .wel-tr-hl{font-family:'Bebas Neue',sans-serif;font-size:44px;color:#F0F0FF;letter-spacing:.04em;line-height:1.0;text-align:center;width:100%;margin-bottom:5px;}
#ob-landing .wel-tr-hl span{color:#10B981;}
#ob-landing .wel-tr-sub{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:400;color:#7A7A9D;text-align:center;max-width:268px;line-height:1.55;margin-bottom:16px;}
#ob-landing .wel-tr-cmp{display:flex;align-items:center;gap:10px;width:100%;margin-bottom:14px;}
#ob-landing .wel-tr-card{flex:1;border-radius:13px;padding:14px 10px;text-align:center;background:rgba(255,255,255,.025);border:1px solid var(--brd);}
#ob-landing .wel-tr-card.ok{background:rgba(16,185,129,.05);border-color:rgba(16,185,129,.22);}
#ob-landing .wel-tr-n{font-family:'Bebas Neue',sans-serif;font-size:52px;letter-spacing:.02em;line-height:1;}
#ob-landing .wel-tr-l{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-top:3px;color:#35355A;}
#ob-landing .wel-tr-card.ok .wel-tr-l{color:rgba(16,185,129,.55);}
#ob-landing .wel-tr-arr{font-family:'Bebas Neue',sans-serif;font-size:24px;color:#35355A;}
#ob-landing .wel-tr-fixes{display:flex;flex-direction:column;gap:6px;width:100%;}
#ob-landing .wel-tr-fix{display:flex;align-items:center;gap:8px;background:rgba(16,185,129,.05);border:1px solid rgba(16,185,129,.13);border-radius:9px;padding:8px 11px;}
#ob-landing .wel-tr-d{width:5px;height:5px;border-radius:50%;background:#10B981;flex-shrink:0;}
#ob-landing .wel-tr-t{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:400;color:#C0C0D8;}

/* ─── ONBOARDING STEPS (horizontal snap) ──────────────────────────────────── */
#ob-steps{
  position:absolute;inset:0;
  background:var(--bg);
  display:none;
  overflow:hidden;
}
#ob-steps.on{display:flex;flex-direction:column}
#ob-track{
  display:flex;
  width:400%;
  height:100%;
  transition:transform .38s cubic-bezier(.22,1,.36,1);
}
.ob-slide{
  width:25%;
  height:100%;
  flex-shrink:0;
  overflow-y:auto;
  overflow-x:hidden;
  scrollbar-width:none;
}
.ob-slide::-webkit-scrollbar{display:none}
.ob-inner{
  min-height:100%;
  padding:56px 22px 32px;
  display:flex;
  flex-direction:column;
}
.ob-dots{display:flex;gap:5px;margin-bottom:24px}
.ob-dot{flex:1;height:3px;border-radius:9999px;background:#1A1A2E;transition:background .35s}
.ob-dot.on{background:var(--ac);opacity:.85}
.ob-dot.done{background:var(--ac);opacity:.4}
/* duplicate ob-steps removed — defined above */

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Tablet & Desktop
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Tablet (641px – 1024px) ─────────────────────────────────────────────── */
@media (min-width:641px) {
  #root{max-width:720px}
  .scroll-page{padding:56px 28px 24px}
  .ob-inner{padding:56px 36px 32px}
  .hdr{margin-bottom:16px}
  .ht{font-size:21px}
  .card{padding:18px;border-radius:16px}
  .btn{height:52px;font-size:15px;max-width:400px;margin-left:auto;margin-right:auto;display:block}
  .btn-ghost{max-width:400px;margin-left:auto;margin-right:auto;display:block}
  .inp{height:52px;font-size:15px}
  .tab3{max-width:400px}
  .t3{padding:8px 0;font-size:12px}
  #bnav{height:64px;padding-bottom:6px}
  .ni{min-width:60px;padding:6px 12px}
  .ni svg{width:21px;height:21px}
  .nlb{font-size:11px}
  .modal-sheet{max-width:560px;margin:0 auto;border-radius:20px 20px 0 0}
  #toast{left:28px;right:28px;max-width:500px;margin:0 auto}
  /* Analyze — wider drop zone */
  #drop-zone{height:200px}
  /* Audience DNA — 3-col brain map */
  #dna-brain-map{grid-template-columns:1fr 1fr 1fr}
  /* Cohort stats — wider */
  #dna-cohort-stats{gap:8px}
  #dna-cohort-graph{height:180px}
}

/* ── Desktop (1025px+) ───────────────────────────────────────────────────── */
@media (min-width:1025px) {
  #root{max-width:1120px;border-left:1px solid #16162A;border-right:1px solid #16162A}
  .scroll-page{padding:48px 40px 24px}
  .ob-inner{padding:48px 60px 40px}
  .hdr{margin-bottom:18px;padding-top:6px}
  .ht{font-size:24px}
  .card{padding:20px 22px;border-radius:18px;margin-bottom:12px}
  .sl{font-size:11px;margin-bottom:8px}
  .btn{height:54px;font-size:15px;max-width:440px;border-radius:14px}
  .btn-ghost{max-width:440px;border-radius:13px}
  .btn-sm{height:38px;font-size:13px}
  .inp{height:54px;font-size:15px;border-radius:14px}
  .tab3{max-width:420px}
  .t3{font-size:13px;padding:9px 0}
  .pill{font-size:11px;padding:3px 10px}
  #bnav{height:56px;padding-bottom:4px}
  .ni{padding:4px 16px;min-width:80px}
  .ni svg{width:20px;height:20px}
  .nlb{font-size:11px}
  .nicta{padding:8px 18px}
  .modal-sheet{max-width:640px;margin:0 auto}
  #toast{max-width:560px;left:50%;right:auto;transform:translateX(-50%)}
  /* Analyze layout */
  #drop-zone{height:220px;max-width:600px;margin-left:auto;margin-right:auto}
  /* Score reveal — bigger */
  #az-stage-1{min-height:500px;max-width:600px;margin:0 auto}
  #az-stage-1 svg{width:220px;height:220px}
  /* Stage 2 — constrain width */
  #az-stage-2{max-width:700px;margin:0 auto}
  /* Stage 3 — 2-column grid for signal bars + mirofish */
  #az-stage-3{max-width:900px;margin:0 auto}
  /* Audience DNA — wider graphs */
  #dna-cohort-graph{height:200px}
  #dna-brain-map{grid-template-columns:1fr 1fr 1fr}
  /* Video preview — wider */
  #az-video-preview{max-width:600px;margin-left:auto;margin-right:auto}
  /* Edit tab — constrain */
  #az-ed-ready{max-width:700px;margin:0 auto}
}

/* ── Wide Desktop (1280px+) — 2-column layouts ───────────────────────────── */
@media (min-width:1280px) {
  #root{max-width:1320px}
  .scroll-page{padding:48px 52px 24px}
  /* Analyze stage 3 — side-by-side panels */
  .az-desktop-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
  /* Generation cards — 2 per row */
  #dna-gen-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  #dna-gen-cards > div{margin-bottom:0!important}
  /* Advanced tool buttons — don't need wrap */
  #az-stage-3 .btn{max-width:320px}
}

/* ── Onboarding — keep centered/mobile feel even on desktop ──────────────── */
@media (min-width:641px) {
  #ob-landing{max-width:480px;margin:0 auto}
  #ob-landing .wel-hl{font-size:52px}
  #ob-landing .wel-sub{max-width:360px;font-size:14px}
  #ob-landing .wel-ab{max-width:480px;margin:0 auto;border-radius:20px 20px 0 0}
  #ob-steps{max-width:640px;margin:0 auto}
  .ob-inner{max-width:480px;margin:0 auto}
}
