/* ===== Aura — bold, dark, ego-driven looksmax UI ===== */
:root{
  --bg:#08060f; --bg2:#0e0b1c; --card:#15112a; --card2:#1c1736;
  --line:rgba(255,255,255,.08); --txt:#f3f1fb; --mut:#9a93b8; --mut2:#6f6890;
  --v1:#a855f7; --v2:#6366f1; --pink:#ec4899; --good:#34d399; --gold:#fbbf24;
  --grad:linear-gradient(135deg,#a855f7,#6366f1);
  --glow:0 0 40px rgba(124,58,237,.45);
  --maxw:520px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
[hidden]{display:none!important} /* must beat class-level display rules (.modal/.plan-list) */
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(124,58,237,.22), transparent 60%),
    radial-gradient(800px 500px at 90% 10%, rgba(99,102,241,.16), transparent 55%),
    var(--bg);
  color:var(--txt); font-family:Inter,-apple-system,Segoe UI,Roboto,sans-serif;
  min-height:100dvh; overflow-x:hidden;
}
h1,h2,h3{font-family:Sora,Inter,sans-serif;letter-spacing:-.02em;margin:0}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.muted{color:var(--mut)} .small{font-size:13px}
svg.lucide{width:18px;height:18px;stroke-width:2.25;flex:none}
#app{max-width:var(--maxw);margin:0 auto;padding:0 18px 120px}

/* ===== full-bleed top bar ===== */
#topbar{position:sticky;top:0;z-index:30;width:100%;
  background:linear-gradient(180deg,rgba(10,8,20,.96),rgba(10,8,20,.72));
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.bar-inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:8px;padding:12px 18px}
.grow{flex:1}
button{font:inherit;cursor:pointer;color:var(--txt)}
.ghost{background:none;border:none}
.brand{background:none;border:none;font-size:19px;font-weight:800;display:flex;gap:6px;align-items:center}
.brand svg.lucide{color:var(--gold);width:22px;height:22px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--line);
  border-radius:999px;font-size:13px;font-weight:600;color:var(--mut);background:rgba(255,255,255,.02)}
.pill:hover{color:var(--txt);border-color:rgba(255,255,255,.2)}
.pill svg.lucide{width:16px;height:16px}
.link{background:none;border:none;color:var(--v1);text-decoration:underline;font-weight:600;font-size:14px}
.wide{width:100%;margin-top:10px;justify-content:center}

.screen{animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.center{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70dvh;text-align:center}

/* CTA */
.cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--grad);color:#fff;
  border:none;border-radius:999px;font-weight:800;padding:15px 24px;box-shadow:var(--glow);
  transition:transform .12s,filter .2s;width:100%}
.cta:hover{filter:brightness(1.08)} .cta:active{transform:scale(.98)}
.cta:disabled{opacity:.45;box-shadow:none;cursor:not-allowed}
.cta.big{font-size:17px;padding:17px 24px}
.cta svg.lucide,.pill.wide svg.lucide{width:19px;height:19px}

/* ===== ONBOARDING (full screen) ===== */
#onboarding{position:fixed;inset:0;z-index:50;display:flex;flex-direction:column;
  background:
    radial-gradient(900px 500px at 50% 0%, rgba(124,58,237,.30), transparent 60%),
    var(--bg);
  padding:max(24px,env(safe-area-inset-top)) 22px calc(22px + env(safe-area-inset-bottom))}
.ob-skip{position:absolute;top:max(20px,env(safe-area-inset-top));right:20px;background:none;border:none;color:var(--mut);font-size:14px;z-index:2}
.ob-stage{flex:1;display:flex;overflow:hidden}
.ob-slide{min-width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:20px;padding:0 4px;transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.ob-slide h1{font-size:34px;line-height:1.08;font-weight:800}
.ob-slide p{color:var(--mut);font-size:16px;line-height:1.55;max-width:340px;margin:0}
.ob-art{height:240px;display:flex;align-items:center;justify-content:center;width:100%;position:relative}
.ringnum{width:160px;height:160px;border-radius:50%;display:grid;place-items:center;font-family:Sora;
  font-weight:800;font-size:62px;position:relative;box-shadow:var(--glow);
  background:radial-gradient(circle at 50% 35%,rgba(168,85,247,.35),transparent 70%)}
.ringnum::before{content:"";position:absolute;inset:-3px;border-radius:50%;padding:3px;background:var(--grad);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude}
.ob-zap{position:absolute;bottom:8px;right:18px;color:var(--gold)}
.ob-zap svg.lucide{width:30px;height:30px}
.ob-tag{position:absolute;bottom:18px;letter-spacing:.3em;font-size:12px;color:var(--mut);font-weight:700}
.ob-bars{flex-direction:column;gap:16px;width:300px;height:auto}
.ob-bars .b{text-align:left}
.ob-bars .b span{font-size:13px;color:var(--mut);font-weight:600}
.ob-bars .b i{display:block;height:12px;border-radius:99px;margin-top:5px;width:var(--w);background:var(--grad);box-shadow:var(--glow)}
.ob-lead{flex-direction:column;gap:10px;width:300px;height:auto}
.lr{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:12px 16px;font-weight:600}
.lr span{flex:1;text-align:left} .lr b{font-family:Sora;font-size:20px}
.lr svg.lucide{color:var(--mut)}
.lr.gold{border-color:rgba(251,191,36,.5);box-shadow:0 0 24px rgba(251,191,36,.18)}
.lr.gold svg.lucide{color:var(--gold)}
.lr.you{border-style:dashed;border-color:var(--v1);color:var(--v1)}
.lr.you svg.lucide{color:var(--v1)}
.ob-share .ob-card{width:150px;height:190px;border-radius:20px;background:var(--grad);box-shadow:var(--glow);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#fff}
.ob-share .ob-card svg.lucide{width:38px;height:38px}
.ob-share .ob-card b{font-family:Sora;font-size:46px}
.ob-foot{display:flex;flex-direction:column;align-items:center;gap:16px}
.ob-dots{display:flex;gap:8px}
.ob-dots i{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);transition:.3s}
.ob-dots i.on{background:var(--v1);width:24px;border-radius:99px}
#obNext{max-width:420px}

/* ===== HOME / UPLOAD ===== */
.hero{padding-top:18px;text-align:center}
.h-title{font-size:32px;font-weight:800;margin-bottom:6px;display:inline-flex;align-items:center;gap:8px;justify-content:center}
.h-title svg.lucide{width:30px;height:30px;color:var(--gold)}
.h-sub{color:var(--mut);font-size:15px;margin:0 0 22px;line-height:1.5}
.dropzone{display:block;border:2px dashed rgba(168,85,247,.4);border-radius:24px;background:
  linear-gradient(180deg,var(--card),rgba(21,17,42,.4));padding:34px 20px;cursor:pointer;transition:.2s;overflow:hidden}
.dropzone:hover{border-color:var(--v1);background:var(--card2)}
.dz-empty{display:flex;flex-direction:column;align-items:center;gap:10px}
.dz-icon{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;background:var(--grad);box-shadow:var(--glow)}
.dz-icon svg.lucide{width:30px;height:30px;color:#fff}
.dz-main{font-weight:700;font-size:17px}
.dz-sub{color:var(--mut);font-size:13px}
#dzPreview{width:100%;max-height:360px;object-fit:cover;border-radius:16px;display:block}
.compete{display:flex;gap:12px;align-items:flex-start;text-align:left;margin:18px 0 0;
  background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px 16px;cursor:pointer}
.compete input{width:22px;height:22px;accent-color:var(--v1);margin-top:1px;flex:none}
.compete small{color:var(--mut)}
.dn{width:100%;margin-top:12px;background:var(--card2);border:1px solid var(--line);border-radius:14px;
  padding:14px 16px;color:var(--txt);font:inherit;font-size:15px}
.dn:focus{outline:none;border-color:var(--v1)}
#acctSignedOut .dn{margin-bottom:14px}
.compete-fields{display:flex;gap:10px}
.compete-fields .dn{flex:1}
.dn-age{flex:0 0 88px!important;text-align:center}
#rateBtn{margin-top:18px}
.credit-line{text-align:center;color:var(--mut);font-size:13px;margin-top:10px;min-height:18px}
.credit-line b{color:var(--v1)}
.trust{color:var(--mut2);font-size:12px;text-align:center;margin-top:14px;display:flex;gap:5px;align-items:center;justify-content:center}
.trust svg.lucide{width:13px;height:13px}

/* ===== ANALYZING ===== */
.scan-wrap{position:relative;width:200px;height:200px;border-radius:50%;overflow:hidden;
  box-shadow:var(--glow);border:2px solid rgba(168,85,247,.4)}
.scan-wrap img{width:100%;height:100%;object-fit:cover}
.scan-line{position:absolute;left:0;right:0;height:40px;background:linear-gradient(180deg,transparent,rgba(168,85,247,.6),transparent);animation:scan 1.8s ease-in-out infinite}
@keyframes scan{0%{top:-40px}100%{top:200px}}
#analyzing h2{margin-top:26px;font-size:22px}
.scan-steps{margin-top:18px;color:var(--mut);font-size:14px;line-height:2;min-height:60px}
.scan-steps .done{color:var(--good)}

/* ===== RESULTS ===== */
.res-head{position:relative;text-align:center;background:linear-gradient(180deg,var(--card),rgba(21,17,42,0));
  border-radius:24px;padding:22px 16px 0;margin-top:14px;border:1px solid var(--line);overflow:hidden}
.res-avatar{width:84px;height:84px;border-radius:50%;overflow:hidden;margin:0 auto 8px;border:2px solid rgba(168,85,247,.5);box-shadow:var(--glow);background:var(--card2)}
.res-avatar img{width:100%;height:100%;object-fit:cover}
.res-label{letter-spacing:.25em;font-size:12px;color:var(--mut);font-weight:700}
.res-big{font-family:Sora;font-weight:800;font-size:84px;line-height:1;margin:2px 0;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.res-pct{color:var(--good);font-weight:700;font-size:14px}
.curve{width:100%;height:90px;margin-top:6px;display:block}
.curve-cap{color:var(--mut);font-size:12px;padding:0 0 16px}
.res-summary{text-align:center;font-size:17px;font-weight:600;line-height:1.4;margin:20px 4px 8px}
.cats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.cat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px}
.cat .ct{display:flex;justify-content:space-between;align-items:baseline}
.cat .cn{font-size:13px;color:var(--mut);font-weight:600}
.cat .cv{font-family:Sora;font-weight:800;font-size:22px}
.cat .bar{height:8px;border-radius:99px;background:rgba(255,255,255,.08);margin-top:9px;overflow:hidden}
.cat .bar i{display:block;height:100%;border-radius:99px;background:var(--grad);width:0;transition:width .9s cubic-bezier(.2,.8,.2,1)}
.tips{margin-top:22px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px}
.tips h3{font-size:16px;margin-bottom:12px}
.tips ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px}
.tips li{display:flex;gap:10px;font-size:14px;color:#e3def5;line-height:1.4;align-items:flex-start}
.tips li svg.lucide{width:18px;height:18px;color:var(--v1);margin-top:1px}
.rankcard{margin-top:18px;background:linear-gradient(135deg,rgba(168,85,247,.22),rgba(99,102,241,.12));
  border:1px solid rgba(168,85,247,.4);border-radius:18px;padding:18px;text-align:center;font-weight:600}
.rankcard .rk{font-family:Sora;font-weight:800;font-size:30px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.lockwrap{position:relative}
.lockwrap.locked .cats,.lockwrap.locked .tips,.lockwrap.locked .rankcard{filter:blur(9px);pointer-events:none;user-select:none;opacity:.75}
.reslock{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.4rem;padding:24px;z-index:3;border-radius:18px;background:radial-gradient(circle at 50% 38%,rgba(18,14,28,.5),rgba(18,14,28,.86))}
.reslock h3{margin:.3rem 0;font-size:20px}
.reslock p{color:rgba(255,255,255,.82);font-size:.9rem;max-width:330px;margin:0 0 .7rem;line-height:1.5}
.reslock [data-lucide]{width:36px;height:36px;color:#c084fc}
.reslock .cta{max-width:300px}
.res-actions{margin-top:22px}

/* ===== LEADERBOARD ===== */
.board-title{margin-top:14px}
.cat-tabs{display:flex;gap:8px;overflow-x:auto;padding:14px 0 34px;scrollbar-width:none}
.cat-tabs::-webkit-scrollbar{display:none}
.cat-tabs button{white-space:nowrap;background:var(--card);border:1px solid var(--line);color:var(--mut);
  border-radius:999px;padding:9px 16px;font:inherit;font-weight:600;font-size:13px}
.cat-tabs button.on{background:var(--grad);color:#fff;border-color:transparent;box-shadow:var(--glow)}

/* podium (top 3) */
.podium{display:flex;align-items:flex-end;justify-content:center;gap:12px;margin:6px 0 18px}
.pod{flex:1;max-width:130px;display:flex;flex-direction:column;align-items:center;gap:6px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),transparent);border:1px solid var(--line);
  border-radius:18px;padding:14px 8px 16px;position:relative}
.pod .crown{position:absolute;top:-14px;color:var(--gold)}
.pod .crown svg.lucide{width:26px;height:26px}
.pod .pav{border-radius:50%;overflow:hidden;border:3px solid;background:var(--card2)}
.pod .pav img{width:100%;height:100%;object-fit:cover;display:block}
.pod .pnm{font-weight:700;font-size:13px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pod .page{font-size:11px;color:var(--mut);font-weight:600;margin-top:-2px}
.row .nm .age{color:var(--mut2);font-weight:600}
.pod .psc{font-family:Sora;font-weight:800;font-size:24px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.pod .pos{font-size:11px;color:var(--mut);font-weight:700}
.pod.p1{order:2;transform:translateY(-10px)} .pod.p1 .pav{width:84px;height:84px;border-color:var(--gold);box-shadow:0 0 26px rgba(251,191,36,.4)}
.pod.p2{order:1} .pod.p2 .pav{width:64px;height:64px;border-color:#cbd5e1}
.pod.p3{order:3} .pod.p3 .pav{width:64px;height:64px;border-color:#d8a06a}
.pod.p1 .psc{font-size:30px}

.board-list{display:flex;flex-direction:column;gap:8px}
.row{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:9px 14px}
.row .pos{width:26px;text-align:center;font-family:Sora;font-weight:800;color:var(--mut)}
.row .av{width:40px;height:40px;border-radius:50%;overflow:hidden;flex:none;background:var(--card2);display:grid;place-items:center}
.row .av img{width:100%;height:100%;object-fit:cover}
.row .nm{flex:1;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .sc{font-family:Sora;font-weight:800;font-size:20px}
.row.me{border-color:var(--v1);background:linear-gradient(135deg,rgba(168,85,247,.18),var(--card))}
.row.me .nm::after{content:" (you)";color:var(--v1);font-weight:700}
.row-rm{background:none;border:none;color:var(--mut2);flex:none;display:grid;place-items:center;padding:4px;cursor:pointer}
.row-rm:hover{color:#f87171}
.row-rm svg.lucide{width:17px;height:17px}
.pod-rm{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.35);border:none;color:#fff;border-radius:50%;width:22px;height:22px;display:grid;place-items:center;cursor:pointer;opacity:.8}
.pod-rm:hover{opacity:1;color:#f87171}
.pod-rm svg.lucide{width:14px;height:14px}
.res-remove{display:block;margin:10px auto 0;font-size:13px}
#boardScan{margin-top:18px}

/* ===== MODALS / SHEETS ===== */
.modal{position:fixed;inset:0;z-index:60;display:flex;align-items:flex-end;justify-content:center;
  background:rgba(4,2,10,.7);backdrop-filter:blur(6px);animation:fade .2s}
.sheet{width:100%;max-width:var(--maxw);background:var(--bg2);border:1px solid var(--line);
  border-radius:26px 26px 0 0;padding:26px 20px calc(26px + env(safe-area-inset-bottom));
  position:relative;animation:up .3s cubic-bezier(.2,.8,.2,1);max-height:92dvh;overflow-y:auto}
@keyframes up{from{transform:translateY(100%)}}
@media(min-width:560px){.modal{align-items:center}.sheet{border-radius:26px}}
.sheet-x{position:absolute;top:14px;right:14px;background:var(--card);border:none;color:var(--mut);
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center}
.sheet-x svg.lucide{width:16px;height:16px}
.sheet h2{font-size:24px;margin-bottom:6px}
.pay-h{font-size:26px;text-align:center}
.pay-sub{color:var(--mut);text-align:center;font-size:14px;margin:6px 0 18px}
.seg{display:flex;background:var(--card);border-radius:14px;padding:4px;margin-bottom:16px}
.seg-b{flex:1;border:none;background:none;color:var(--mut);font-weight:700;padding:11px;border-radius:11px}
.seg-b.active{background:var(--grad);color:#fff;box-shadow:var(--glow)}
.plan-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.opt{display:flex;align-items:center;gap:14px;border:2px solid var(--line);border-radius:16px;padding:15px 16px;cursor:pointer;position:relative;background:var(--card)}
.opt.sel{border-color:var(--v1);background:var(--card2);box-shadow:var(--glow)}
.opt .radio{width:22px;height:22px;border-radius:50%;border:2px solid var(--mut);flex:none}
.opt.sel .radio{border-color:var(--v1);background:radial-gradient(circle,#fff 35%,var(--v1) 38%)}
.opt .oi{flex:1}
.opt .on1{font-weight:800;font-size:16px}
.opt .ob1{color:var(--mut);font-size:13px}
.opt .price{text-align:right;font-family:Sora;font-weight:800}
.opt .price small{display:block;color:var(--mut);font-weight:500;font-size:11px;font-family:Inter}
.badge{position:absolute;top:-9px;right:14px;background:var(--grad);color:#fff;font-size:11px;font-weight:800;padding:3px 10px;border-radius:99px}
.trial-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,rgba(168,85,247,.16),rgba(99,102,241,.08));border:1px solid rgba(168,85,247,.4);border-radius:14px;padding:13px 16px;margin-bottom:14px}
.trial-t{font-weight:800;font-size:15px}
.trial-s{color:var(--mut);font-size:12px}
.switch{width:52px;height:30px;border-radius:999px;border:none;background:rgba(255,255,255,.16);position:relative;flex:none;transition:background .2s;cursor:pointer}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.switch.on{background:var(--grad)}
.switch.on::after{left:25px}
.pay-fine{color:var(--mut2);font-size:12px;text-align:center;margin:12px 0 6px}
.pay-fine.free{color:var(--good);font-weight:700;font-size:13px}
.acct-stat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;margin:14px 0;text-align:center}
.acct-stat .big{font-family:Sora;font-weight:800;font-size:34px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.acct-stat .lbl{color:var(--mut);font-size:13px}

/* history */
.hist-head{margin:20px 0 10px;font-weight:700;font-size:15px;color:var(--mut)}
.hist-list{display:flex;flex-direction:column;gap:8px}
.hist{display:flex;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.hist:hover{border-color:rgba(255,255,255,.2)}
.hopen{flex:1;display:flex;align-items:center;gap:12px;background:none;border:none;padding:10px 6px 10px 14px;text-align:left}
.hrm{background:none;border:none;color:var(--mut2);padding:10px 14px;align-self:stretch;display:grid;place-items:center}
.hrm:hover{color:#f87171}
.hrm svg.lucide{width:18px;height:18px}
.hist .hav{width:40px;height:40px;border-radius:50%;overflow:hidden;flex:none;background:var(--card2);display:grid;place-items:center;color:var(--mut)}
.hist .hav img{width:100%;height:100%;object-fit:cover}
.hist .hav svg.lucide{width:18px;height:18px}
.hist .hi{flex:1}
.hist .ho{font-family:Sora;font-weight:800;font-size:18px}
.hist .hd{color:var(--mut);font-size:12px}
.hist .hgo{color:var(--mut)}

.share-sheet{text-align:center}
#shareCanvas{width:100%;max-width:340px;border-radius:18px;margin:6px auto 16px;display:block;box-shadow:0 20px 60px rgba(0,0,0,.5)}

.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);background:var(--card2);
  border:1px solid var(--line);color:var(--txt);padding:13px 20px;border-radius:14px;z-index:90;
  font-weight:600;font-size:14px;box-shadow:0 10px 40px rgba(0,0,0,.5);max-width:90vw;text-align:center}
