/* ── Reset ─────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;background:#050505}
body{font-family:'Jost',sans-serif;color:#EAE6DE;-webkit-font-smoothing:antialiased;display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:12px}
#app{position:relative;width:100%;max-width:430px;height:100%;max-height:min(932px,calc(100dvh - 24px));overflow:hidden;background:#000000;flex-shrink:0;border-radius:28px;isolation:isolate;box-shadow:0 0 0 1px rgba(184,134,11,.14),0 24px 64px rgba(0,0,0,.75),inset 0 1px 0 rgba(255,255,255,.04);contain:layout paint style}
#intro,#shell,#ob{position:absolute;inset:0;width:100%;height:100%;border-radius:inherit;overflow:hidden}
html.levelup-app-ready #intro{display:none!important;visibility:hidden!important;pointer-events:none!important}
@media(min-width:500px){body{padding:20px}#app{max-height:min(932px,calc(100dvh - 40px))}}
@media(display-mode:standalone){body{padding:0;background:#000}#app{border-radius:0;max-height:100dvh;height:100dvh;box-shadow:none;max-width:none}}

/* ── Tokens ─────────────────────────────────────── */
:root{
  --bg:#050c05;--bg2:#080f08;--card:#0d1a0e;--card2:#0d1a0e;
  --g1:#B8860B;--g2:#D4AF37;--g3:#9A7B2F;
  --gd:linear-gradient(135deg,#9A7B2F,#B8860B,#D4AF37);
  --t1:#EAE6DE;--t2:#A89880;--t3:#5A5040;
  --br:rgba(184,134,11,.22);--br2:rgba(184,134,11,.38);
  /* stat colors — rich, dark, readable */
  --c-ac:#4E8EC4;--c-fi:#28A06C;--c-he:#C24848;
  --c-mo:#B8860B;--c-di:#7560C8;--c-so:#B44E8A;
  --c-kn:#6068B4;--c-ha:#C06418;
  --st:env(safe-area-inset-top,0px);--sb:env(safe-area-inset-bottom,0px);
  --nav:72px;
  --pg-ease:cubic-bezier(.22,1,.36,1);
  --pg-ease-out:cubic-bezier(.33,1,.32,1);
  --pg-enter-dur:.38s;
  --pg-exit-dur:.28s;
}

/* ── Shell ──────────────────────────────────────── */
#shell{display:flex;flex-direction:column;height:100%;width:100%;position:relative}
#topbar{flex-shrink:0;position:relative;padding:0 18px 12px;background:rgba(7,14,11,.96);backdrop-filter:blur(28px);border-bottom:1px solid var(--br);z-index:20}
.tb-inner{display:flex;align-items:center;justify-content:space-between;padding-top:calc(var(--st) + 12px)}
/* top gold accent bar removed */
#i-prog{display:none!important}
html.levelup-native-ios .tb-inner{padding-top:max(env(safe-area-inset-top,0px),12px)}
.tb-pills{display:flex;gap:7px}
#main{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--nav)+var(--sb)+40px);scroll-behavior:smooth;position:relative;overscroll-behavior:none}
#main::-webkit-scrollbar{display:none}

/* ── Nav ────────────────────────────────────────── */
#nav{position:absolute;bottom:0;left:0;right:0;width:100%;height:calc(var(--nav)+var(--sb));padding-bottom:var(--sb);background:rgba(7,14,11,.97);backdrop-filter:blur(28px);border-top:1px solid var(--br);display:flex;z-index:30;border-bottom-left-radius:inherit;border-bottom-right-radius:inherit;touch-action:manipulation}
.nb{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;border:none;background:none;color:var(--t3);transition:color .32s cubic-bezier(.22,1,.36,1),transform .32s cubic-bezier(.22,1,.36,1);padding:8px 4px;position:relative;user-select:none!important;-webkit-user-select:none!important;-webkit-touch-callout:none!important;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.nb *,.nb *::before,.nb *::after{user-select:none!important;-webkit-user-select:none!important}
.nb svg{pointer-events:none;width:26px;height:26px;transition:transform .32s cubic-bezier(.22,1,.36,1),filter .32s cubic-bezier(.22,1,.36,1),color .32s cubic-bezier(.22,1,.36,1)}
.nb.on{color:var(--g1)}
.nb.on::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:22px;height:2px;background:var(--g1);border-radius:0 0 2px 2px;opacity:.8;transition:opacity .32s cubic-bezier(.22,1,.36,1),width .32s cubic-bezier(.22,1,.36,1),transform .32s cubic-bezier(.22,1,.36,1)}
.nb.on svg{transform:scale(1.08) translateY(-1px)}
.nb-lbl{font-family:'Cormorant SC',sans-serif;font-size:11px;font-weight:500;letter-spacing:.03em;text-transform:uppercase}

/* ── Brand ──────────────────────────────────────── */
.brand{font-family:'Cormorant SC',sans-serif;font-size:17px;font-weight:500;letter-spacing:-.02em;background:var(--gd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:8px}
.tpill{display:flex;align-items:center;gap:5px;background:rgba(184,134,11,.08);border:1px solid var(--br);border-radius:14px;padding:6px 13px;font-family:'Cormorant SC',sans-serif;font-size:13px;font-weight:500;color:var(--g1)}
.tpill svg{width:13px;height:13px;flex-shrink:0}
#tb-streak-icon{display:flex;align-items:center;justify-content:center;line-height:1;flex-shrink:0;width:13px;height:13px}
#tb-streak-icon.is-risk-flame{color:#f87171;animation:streakRiskPulse 2.4s ease-in-out infinite}
@keyframes streakRiskPulse{0%,100%{opacity:1}50%{opacity:.7}}
.tpill.streak-at-risk{border-color:rgba(248,113,113,.35);background:rgba(248,113,113,.1);color:#f87171}
.tpill.streak-at-risk #tb-streak{color:#fca5a5}

/* ── Pages ──────────────────────────────────────── */
.page{display:none;background:var(--bg);will-change:opacity,transform;width:100%}
.page.on{display:block;position:relative;z-index:1;animation:pgLuxIn var(--pg-enter-dur) var(--pg-ease) both}
.page.leaving{display:block;position:absolute;top:0;left:0;right:0;z-index:3;animation:pgLuxOut var(--pg-exit-dur) var(--pg-ease-out) both;pointer-events:none}
@keyframes pgLuxIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes pgLuxOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}

/* ── Home section stagger reveal ─────────────────── */
@keyframes secReveal{from{transform:translateY(14px)}to{transform:translateY(0)}}
.page.on #home-content>*{animation:secReveal .42s var(--pg-ease) forwards;opacity:1}
.page.on #home-content>.hero{animation-delay:.02s}
.page.on #home-content>#dr-banner{animation-delay:.06s}
.page.on #home-content>div:nth-child(3){animation-delay:.10s}
.page.on #home-content>.sec{animation-delay:.14s}
.page.on #home-content>.sec-stats{animation-delay:.18s}
.page.on #home-content>div:last-child{animation-delay:.22s}

/* Page transition skeleton loader — disabled; tabs pre-render on switch */
#pg-skeleton{display:none!important}

/* ── Text helpers ───────────────────────────────── */
.gt{background:var(--gd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.syne{font-family:'Cormorant SC',sans-serif}

/* ── Cards ──────────────────────────────────────── */
.card{background:var(--card);border:1px solid rgba(184,134,11,0.18);border-radius:18px}
.card2{background:var(--card2);border:1px solid rgba(184,134,11,0.18);border-radius:12px}
.cp{padding:20px}

/* ── XP bar ─────────────────────────────────────── */
.xbt,.xbtrack{height:2px;background:rgba(255,255,255,.07);border-radius:2px;overflow:hidden}
.xbf,.xbfill{height:100%;background:#B8860B;border-radius:2px;transition:width .7s cubic-bezier(.4,0,.2,1)}

/* ── Hero card ──────────────────────────────────── */
.hero{margin:16px 16px 0;border-radius:22px;padding:24px;position:relative;overflow:hidden;background:linear-gradient(145deg,#0d1a0e 0%,#151208 45%,#0d1a0e 100%);border:1px solid rgba(184,134,11,0.28);box-shadow:0 4px 32px rgba(0,0,0,.45),0 0 0 1px rgba(184,134,11,.06) inset,0 0 40px rgba(184,134,11,.04)}
.hero::before{content:'';position:absolute;top:-50px;right:-30px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(184,134,11,.28),transparent 70%);pointer-events:none;animation:heroGlow 5s ease-in-out infinite}
.hero::after{content:'';position:absolute;bottom:-60px;left:-30px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(184,134,11,.14),transparent 70%);pointer-events:none}
@keyframes heroGlow{0%,100%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}

/* ── Stat pills ─────────────────────────────────── */
.spill{background:rgba(0,0,0,.35);border-radius:13px;padding:11px 8px;text-align:center;border:1px solid rgba(184,134,11,.08);transition:border-color .2s,transform .15s}
.spill:active{transform:scale(.96);border-color:rgba(184,134,11,.22)}
.spill-val{font-family:'Cormorant SC',sans-serif;font-size:24px;font-weight:500;color:var(--g1);line-height:1}
.spill-lbl{display:flex;align-items:center;justify-content:center;gap:4px;font-size:11px;color:var(--t2);margin-top:5px;text-transform:uppercase;letter-spacing:.05em}
.spill-lbl svg{width:11px;height:11px}

/* ── Rank badge ─────────────────────────────────── */
.rank-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:14px;font-family:'Cormorant SC',sans-serif;font-size:12px;font-weight:500;border:1px solid;letter-spacing:.04em}
.rank-badge svg{width:12px;height:12px}

/* ── Sections ───────────────────────────────────── */
.sec{padding:0 16px;margin-bottom:28px}
#wc-container,#focus-mission-wrap{padding:0 16px;width:100%;box-sizing:border-box}
#wc-container{margin-top:16px}
#focus-mission-wrap{margin-top:12px;margin-bottom:4px}
.sh{display:flex;align-items:center;gap:7px;font-family:'Cormorant SC',sans-serif;font-size:13px;font-weight:500;color:var(--t2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px}
.sh svg{width:16px;height:16px;flex-shrink:0}

/* ── Buttons ────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;cursor:pointer;font-family:'Jost',sans-serif;font-weight:400;border-radius:11px;transition:all .18s;white-space:nowrap}
.btn:active{transform:scale(.95)}
.btn svg{width:14px;height:14px;flex-shrink:0}
.bgold{background:linear-gradient(135deg,var(--g3),var(--g1),var(--g2));color:#070E0B;padding:15px 24px;font-size:15px;font-family:'Cormorant SC',sans-serif;font-weight:500;letter-spacing:-.01em;box-shadow:0 4px 18px rgba(184,134,11,.22)}
.boutline{background:rgba(184,134,11,.1);border:1px solid var(--br2);color:var(--g1);padding:12px 18px;font-size:14px}
.bghost{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);color:var(--t2);padding:11px 16px;font-size:13px}
.bsm{padding:8px 14px!important;font-size:12px!important;border-radius:9px!important;font-weight:500!important}
.bbl{width:100%}
.bdanger{background:rgba(194,72,72,.08);border:1px solid rgba(194,72,72,.25);color:#C24848;padding:13px 18px;font-size:13px}

/* ── Mission card ───────────────────────────────── */
.mcard{background:var(--card);border:1px solid rgba(184,134,11,0.15);border-radius:16px;padding:18px 18px 18px 22px;display:flex;align-items:center;gap:12px;position:relative;overflow:hidden;transition:border-color .2s}
.mcard::before{display:none}
.mcard.done{opacity:.4}
.mcard-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mcard-icon svg{width:22px;height:22px;color:#4a7a3a}
.mcard-body{flex:1;min-width:0}
.mcard-title{font-size:15px;font-weight:400;margin-bottom:7px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--t1)}
.mcard-title.done-t{text-decoration:line-through;color:var(--t3)}
.mcard-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.mxp{font-family:'Cormorant SC',sans-serif;font-size:13px;font-weight:500;color:var(--g1)}
.mstat{font-size:12px;color:var(--t3);text-transform:capitalize}
.diff{display:inline-flex;align-items:center;padding:3px 9px;border-radius:6px;font-family:'Cormorant SC',sans-serif;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.06em}
.de{background:rgba(40,160,108,.12);color:#28A06C;border:1px solid rgba(40,160,108,.25)}
.dm{background:rgba(184,134,11,.12);color:#B8860B;border:1px solid rgba(184,134,11,.28)}
.dh{background:rgba(194,72,72,.12);color:#C24848;border:1px solid rgba(194,72,72,.25)}
.mcheck{width:32px;height:32px;border-radius:50%;background:rgba(40,160,108,.12);border:1.5px solid rgba(40,160,108,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mcheck svg{width:16px;height:16px;color:#28A06C}
.mdone-btn{background:rgba(184,134,11,.1);border:1.5px solid var(--br2);color:var(--g1);padding:10px 16px;font-size:13px;font-weight:500;border-radius:10px;cursor:pointer;font-family:'Cormorant SC',sans-serif;transition:all .18s;flex-shrink:0}
.mdone-btn:active{transform:scale(.93);background:rgba(184,134,11,.2)}

/* ── Stats grid ─────────────────────────────────── */
.sgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.scard{background:var(--card);border:1px solid rgba(184,134,11,0.18);border-radius:16px;padding:18px 12px 16px;text-align:center;position:relative;overflow:hidden;transition:border-color .25s,transform .2s,box-shadow .25s}
.scard:active{transform:scale(.97)}
.scard::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.03),transparent 60%);pointer-events:none}
.scard-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.scard-icon svg{width:22px;height:22px;color:#4a7a3a}
.scard-val{font-family:'Cormorant SC',sans-serif;font-size:54px;font-weight:500;line-height:1;margin-bottom:6px}
.scard-name{font-family:'Cormorant SC',sans-serif;font-size:13px;font-weight:500;color:var(--t2);text-transform:capitalize;letter-spacing:.05em}
.sbar{height:5px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden}
.sbar-fill{height:100%;border-radius:2px;transition:width .8s cubic-bezier(.4,0,.2,1)}
/* ── Stat ring ───────────────────────────────────── */
.sring-wrap{position:relative;width:88px;height:88px;margin:0 auto 12px}
.sring-svg{width:88px;height:88px;transform:rotate(-90deg)}
.sring-track{fill:none;stroke:rgba(255,255,255,.07);stroke-width:6}
.sring-fill{fill:none;stroke-width:6;stroke-linecap:round;stroke-dasharray:226.2;transition:stroke-dashoffset .85s cubic-bezier(.4,0,.2,1)}
.sring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}
.sring-val{font-family:'Cormorant SC',sans-serif;font-size:24px;font-weight:500;line-height:1}

/* ── Compact home stats grid ─────────────────────── */
.sec-stats{margin-bottom:16px}
.sec-stats .sh{margin-bottom:10px}
.sgrid-compact{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.sgrid-compact .scard{padding:8px 4px 6px;border-radius:11px}
.sgrid-compact .sring-wrap{width:44px;height:44px;margin:0 auto 4px}
.sgrid-compact .sring-svg{width:44px;height:44px}
.sgrid-compact .sring-track,.sgrid-compact .sring-fill{stroke-width:5}
.sgrid-compact .sring-val{font-size:12px}
.sgrid-compact .sring-center{gap:1px}
.sgrid-compact .sring-center svg{width:8px;height:8px}
.sgrid-compact .scard-name{font-size:8px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;line-height:1.15;margin-top:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Filter tabs ────────────────────────────────── */
.tabs-wrap{overflow-x:auto;padding:14px 16px 12px;display:flex;gap:8px;scrollbar-width:none}
.tabs-wrap::-webkit-scrollbar{display:none}
.ftab{flex-shrink:0;display:flex;align-items:center;gap:6px;padding:10px 16px;border-radius:20px;font-family:'Cormorant SC',sans-serif;font-size:13px;font-weight:500;background:var(--card);border:1px solid var(--br);color:var(--t2);cursor:pointer;transition:background .28s cubic-bezier(.22,1,.36,1),border-color .28s cubic-bezier(.22,1,.36,1),color .28s cubic-bezier(.22,1,.36,1),transform .28s cubic-bezier(.22,1,.36,1),box-shadow .28s cubic-bezier(.22,1,.36,1);white-space:nowrap;text-transform:capitalize}
.ftab:active{transform:scale(.97)}
.ftab svg{width:13px;height:13px;flex-shrink:0}
.ftab.on{background:rgba(184,134,11,.12);border-color:var(--br2);color:var(--g1)}

/* ── Bottom-sheet overlays ──────────────────────── */
.ov{position:absolute;inset:0;background:rgba(7,14,11,.88);backdrop-filter:blur(22px);z-index:100;display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity var(--pg-enter-dur) var(--pg-ease)}
.ov.on{opacity:1;pointer-events:all}
.ovs{background:var(--bg2);border:1px solid var(--br);border-top-left-radius:26px;border-top-right-radius:26px;padding:30px 24px calc(28px + var(--sb));width:100%;transform:translateY(100%);transition:transform var(--pg-enter-dur) var(--pg-ease);max-height:92vh;overflow-y:auto;text-align:center}
.ov.on .ovs{transform:translateY(0)}
.ov-handle{display:none}

/* ── Mission complete ───────────────────────────── */
.mc-circle{width:82px;height:82px;border-radius:50%;background:linear-gradient(135deg,#28A06C,#1A6644);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 8px 32px rgba(40,160,108,.25)}
.mc-circle svg{width:36px;height:36px;color:#fff}
.mc-bigxp{font-family:'Cormorant SC',sans-serif;font-size:72px;font-weight:500;letter-spacing:-.04em;line-height:1}
.reward-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:16px 0}
.reward-box{background:rgba(255,255,255,.04);border:1px solid var(--br);border-radius:14px;padding:18px;text-align:center}
.reward-box svg{width:22px;height:22px;margin:0 auto 4px;display:block}
.reward-box-val{font-family:'Cormorant SC',sans-serif;font-size:24px;font-weight:500}
#ov-mc.mc-celebrate-pop .mc-circle{animation:mcCheckPop .6s cubic-bezier(.34,1.56,.64,1) forwards}
#ov-mc.mc-celebrate-pop .mc-bigxp{animation:mcXpPop .7s .15s cubic-bezier(.34,1.4,.64,1) both}
#ov-mc.mc-celebrate-pop .reward-grid{animation:mcRewardsPop .55s .35s cubic-bezier(.34,1.4,.64,1) both}
@keyframes mcCheckPop{0%{transform:scale(0);opacity:0}70%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}
@keyframes mcXpPop{0%{transform:scale(.5);opacity:0}100%{transform:scale(1);opacity:1}}
@keyframes mcRewardsPop{0%{transform:translateY(10px);opacity:0}100%{transform:translateY(0);opacity:1}}
.mc-diff-badge{display:inline-block;font-family:'Cormorant SC',sans-serif;font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;padding:3px 9px;border-radius:999px;margin-bottom:10px;border:1px solid var(--br);color:var(--g1);background:rgba(184,134,11,.08)}

/* ── Level up ───────────────────────────────────── */
@keyframes crownPop{0%{transform:scale(.3) rotate(-20deg);opacity:0}65%{transform:scale(1.12) rotate(4deg)}100%{transform:scale(1) rotate(0);opacity:1}}
@keyframes goldShine{0%,100%{opacity:1}50%{opacity:.78}}
.lu-crown svg{width:80px;height:80px;color:var(--g1);animation:crownPop .6s cubic-bezier(.34,1.56,.64,1) forwards,goldShine 2.5s 1s infinite}
.lu-bignum{font-family:'Cormorant SC',sans-serif;font-size:76px;font-weight:500;letter-spacing:-.04em;line-height:1}

/* ── Profile bars ───────────────────────────────── */
.pbar{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.pbar-icon{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pbar-icon svg{width:14px;height:14px}
.pbar-name{font-family:'Cormorant SC',sans-serif;font-size:13px;font-weight:500;color:var(--t2);text-transform:capitalize;width:88px;flex-shrink:0}
.pbar-track{flex:1;height:8px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}
.pbar-fill{height:100%;border-radius:4px;transition:width .7s}
.pbar-val{font-family:'Cormorant SC',sans-serif;font-size:15px;font-weight:500;width:32px;text-align:right;flex-shrink:0}

/* ── Achievement cards ──────────────────────────── */
.achcard{background:var(--card);border:1px solid rgba(184,134,11,0.15);border-radius:14px;padding:14px;display:flex;gap:12px;align-items:flex-start}
.achcard.locked{opacity:.28}
.achcard-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.achcard-icon svg{width:20px;height:20px}

/* ── Boss ───────────────────────────────────────── */
.boss-hp-track{height:12px;background:rgba(194,72,72,.1);border-radius:6px;overflow:hidden;border:1px solid rgba(194,72,72,.18)}
.boss-hp-fill{height:100%;background:linear-gradient(90deg,#7A1A1A,#C24848,#9A5A28);border-radius:6px;transition:width .5s}
.atk{flex:1;padding:14px 6px;border-radius:12px;border:1px solid;font-family:'Cormorant SC',sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .18s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}
.atk svg{width:18px;height:18px}
.atk:active{transform:scale(.93)}

/* ── Toggle ─────────────────────────────────────── */
.tog{width:48px;height:26px;border-radius:13px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}
.tog.on{background:rgba(184,134,11,.28);border-color:rgba(184,134,11,.4)}
.tog-dot{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:var(--t3);transition:all .2s}
.tog.on .tog-dot{transform:translateX(22px);background:var(--g1)}

/* ── Daily reward ───────────────────────────────── */
.dr-cal{display:flex;gap:6px}
.dr-day{flex:1;padding:12px 4px;border-radius:12px;text-align:center;border:1px solid var(--br);background:var(--card2);min-width:0;cursor:pointer;transition:all .2s}
.dr-day svg{width:16px;height:16px;margin:0 auto 3px;display:block}
.dr-day.claimed{background:rgba(40,160,108,.1);border-color:rgba(40,160,108,.25)}
.dr-day.today{background:rgba(184,134,11,.1);border-color:var(--br2);box-shadow:0 0 0 2px rgba(184,134,11,.15)}
.dr-day.locked{opacity:.28;cursor:default}

/* ── Shop items ─────────────────────────────────── */
.shopitem{background:var(--card);border:1px solid var(--br);border-radius:16px;padding:16px;display:flex;gap:14px;align-items:center;transition:border-color .2s}
.shopitem.owned{border-color:rgba(40,160,108,.25)}
.shopitem.equipped{border-color:var(--g1);background:rgba(184,134,11,.05)}
.shopitem-icon{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.shopitem-icon svg{width:24px;height:24px}

/* ── More hub cards ─────────────────────────────── */
.morecard{background:var(--card);border:1px solid var(--br);border-radius:16px;padding:16px;display:flex;align-items:center;gap:14px;margin-bottom:10px;cursor:pointer;transition:border-color .2s,background .2s}
.morecard:active{background:var(--card2);border-color:var(--br2)}
.morecard-icon{width:50px;height:50px;border-radius:13px;border:1px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.morecard-body{flex:1;min-width:0}
.morecard-title{font-family:'Cormorant SC',sans-serif;font-size:16px;font-weight:500;margin-bottom:5px}
.morecard-desc{font-size:13px;color:var(--t2);line-height:1.4}
.morecard-arrow{color:var(--t3);flex-shrink:0}

/* ── Mini-games ─────────────────────────────────── */
.rt-target{width:130px;height:130px;border-radius:50%;background:rgba(96,104,180,.1);border:2px solid rgba(96,104,180,.28);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;margin:0 auto;user-select:none}
.rt-target.go{background:rgba(40,160,108,.18);border-color:rgba(40,160,108,.5);transform:scale(1.06);box-shadow:0 0 32px rgba(40,160,108,.2)}
.mem-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;max-width:300px;margin:0 auto}
.mem-c{aspect-ratio:1;border-radius:11px;background:var(--card2);border:1px solid var(--br);display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;transition:all .22s;user-select:none}
.mem-c.flip{background:rgba(117,96,200,.12);border-color:rgba(117,96,200,.3)}
.mem-c.match{background:rgba(40,160,108,.1);border-color:rgba(40,160,108,.3);opacity:.5}

/* ── Skill nodes ────────────────────────────────── */
.skill-node{background:var(--card);border:1px solid var(--br);border-radius:14px;padding:14px;display:flex;gap:12px;align-items:flex-start;margin-bottom:10px;transition:all .2s}
.skill-node.unlocked{border-color:rgba(184,134,11,.35);background:rgba(184,134,11,.04)}
.skill-node.locked{opacity:.38}
.skill-node-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ── Focus timer ────────────────────────────────── */
.timer-ring{width:190px;height:190px;border-radius:50%;border:4px solid var(--br);display:flex;align-items:center;justify-content:center;margin:0 auto 22px;position:relative;background:var(--card)}
.timer-num{font-family:'Cormorant SC',sans-serif;font-size:44px;font-weight:500;letter-spacing:-.04em}

/* ── Toast ──────────────────────────────────────── */
#toast{position:absolute;top:calc(var(--st)+76px);left:50%;transform:translateX(-50%) translateY(-10px);background:rgba(11,25,18,.97);border:1px solid var(--br2);border-radius:14px;padding:13px 22px;font-family:'Cormorant SC',sans-serif;font-size:14px;font-weight:500;backdrop-filter:blur(22px);z-index:400;opacity:0;transition:all .28s;pointer-events:none;white-space:nowrap;box-shadow:0 10px 32px rgba(0,0,0,.65);max-width:88%;color:var(--t1)}
#toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── Confetti ───────────────────────────────────── */
.cf{position:absolute;border-radius:2px;pointer-events:none;z-index:300;animation:cffall linear forwards}
@keyframes cffall{0%{opacity:1;transform:translateY(-10px) rotate(0) scale(1)}100%{opacity:0;transform:translateY(900px) rotate(900deg) scale(.4)}}

/* ── Assessment ─────────────────────────────────── */
#ob{background:#000000;z-index:500;display:none;flex-direction:column;align-items:center;justify-content:center;padding:24px;overflow-y:auto}
.ob-card{background:var(--card);border:1px solid var(--br2);border-radius:22px;padding:26px;width:100%;max-width:380px}
.ob-prog-track{height:4px;background:rgba(255,255,255,.06);border-radius:2px;margin-bottom:24px;overflow:hidden}
.ob-prog-fill{height:100%;background:linear-gradient(90deg,var(--g3),var(--g2));border-radius:2px;transition:width .4s}
.ob-q{font-family:'Cormorant SC',sans-serif;font-size:18px;font-weight:500;text-align:center;margin-bottom:22px;line-height:1.4;color:var(--g2)}
.ob-opt{background:rgba(255,255,255,.03);border:1px solid var(--br);border-radius:12px;padding:15px 16px;margin-bottom:10px;cursor:pointer;display:flex;align-items:center;gap:11px;transition:all .18s}
.ob-opt:active{transform:scale(.98)}
.ob-opt.sel{background:rgba(184,134,11,.1);border-color:var(--br2)}
.ob-ltr{width:34px;height:34px;border-radius:8px;background:rgba(184,134,11,.1);border:1px solid var(--br);display:flex;align-items:center;justify-content:center;font-family:'Cormorant SC',sans-serif;font-size:13px;font-weight:500;color:var(--g1);flex-shrink:0;transition:all .18s}
.ob-opt.sel .ob-ltr{background:var(--g1);color:#070E0B;border-color:var(--g1)}
.ob-text{font-size:15px;color:var(--t1)}
.ob-input{width:100%;background:rgba(0,0,0,.38);border:1px solid var(--br);border-radius:12px;padding:14px;color:var(--t1);font-size:16px;font-family:'Jost',sans-serif;outline:none;transition:border .2s;margin-bottom:13px}
.ob-input:focus{border-color:var(--g1)}

/* ═══════════════════════════════════════════════════
   INTRO SLIDES — redesigned
═══════════════════════════════════════════════════ */
#intro{background:#000000;z-index:600;overflow:hidden}

/* Ambient background */
.i-orb-a{position:absolute;width:380px;height:380px;top:-120px;right:-80px;border-radius:50%;filter:blur(90px);background:rgba(184,134,11,.15);pointer-events:none}
.i-orb-b{position:absolute;width:300px;height:300px;bottom:-80px;left:-60px;border-radius:50%;filter:blur(90px);background:rgba(184,134,11,.18);pointer-events:none}
.i-grid{position:absolute;inset:0;opacity:.02;background-image:linear-gradient(var(--g1) 1px,transparent 1px),linear-gradient(90deg,var(--g1) 1px,transparent 1px);background-size:52px 52px;pointer-events:none}

/* Progress bar */

/* Back button */
#i-back{position:absolute;top:calc(var(--st) + 10px);left:16px;z-index:10;background:transparent;border:none;border-radius:8px;color:var(--t3);opacity:.4;font-family:'Cormorant SC',sans-serif;font-size:0;font-weight:500;cursor:pointer;display:none;align-items:center;gap:0;padding:6px 8px;backdrop-filter:none;transition:opacity .2s}
#i-back:hover,#i-back:active{opacity:.7}
#i-back svg{width:16px;height:16px}

/* Dot indicators */
#i-dots{position:absolute;bottom:92px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:10}
.idot{width:6px;height:6px;border-radius:3px;background:rgba(184,134,11,.2);transition:all .3s cubic-bezier(.4,0,.2,1)}
.idot.on{width:22px;background:var(--g1)}

/* Bottom nav */
#i-bnav{position:absolute;bottom:0;left:0;right:0;padding:14px 22px calc(14px + var(--sb));z-index:10;background:linear-gradient(transparent,rgba(7,14,11,.97) 38%);display:flex;flex-direction:column;align-items:center;gap:9px}
#i-next{width:100%;max-width:360px;padding:16px;font-size:16px}
#i-skip{background:none;border:none;color:var(--t3);font-family:'Cormorant SC',sans-serif;font-size:12px;font-weight:500;letter-spacing:.06em;cursor:pointer;padding:5px 12px;text-transform:uppercase}

/* Slides */
.islide{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;padding:3.5rem 1.7rem 9rem;text-align:center;overflow:hidden;overscroll-behavior:none}
.islide.i-scroll{overflow-y:auto;-webkit-overflow-scrolling:touch;justify-content:flex-start;padding-top:3rem}
.islide.on{display:flex;animation:slideIn .42s cubic-bezier(.22,1,.36,1)}
@keyframes slideIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* Typography */
.i-eyebrow{font-family:'Cormorant SC',sans-serif;font-size:12px;font-weight:500;letter-spacing:.22em;color:var(--g1);text-transform:uppercase;margin-bottom:16px;opacity:.85}
.i-h1{font-family:'Cormorant SC',sans-serif;font-size:clamp(2rem,8vw,2.9rem);font-weight:500;line-height:1.05;letter-spacing:-.03em;margin-bottom:14px;background:linear-gradient(155deg,#d4c8a8 0%,var(--g2) 52%,var(--g1) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.i-h2{font-family:'Cormorant SC',sans-serif;font-size:clamp(1.45rem,6vw,1.95rem);font-weight:500;line-height:1.08;letter-spacing:-.03em;margin-bottom:18px;background:linear-gradient(135deg,#fff 30%,var(--g2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.i-body{font-size:1rem;color:var(--t2);line-height:1.72;max-width:320px;margin:0 auto 18px}
.i-hl{color:var(--g2);font-weight:400}

/* Logo mark */
.i-logo{width:90px;height:90px;border-radius:24px;background:linear-gradient(145deg,#9A7B2F,#B8860B);display:flex;align-items:center;justify-content:center;margin:0 auto 26px;box-shadow:0 0 0 1px rgba(184,134,11,.28),0 12px 44px rgba(184,134,11,.22);animation:logoPulse 3.5s ease-in-out infinite}
.i-logo svg{width:46px;height:46px;color:#070E0B}
@keyframes logoPulse{0%,100%{box-shadow:0 0 0 1px rgba(184,134,11,.28),0 10px 36px rgba(184,134,11,.2)}50%{box-shadow:0 0 0 1px rgba(184,134,11,.52),0 10px 50px rgba(184,134,11,.38)}}
.i-tagline{font-family:'Cormorant SC',sans-serif;font-size:.92rem;letter-spacing:.22em;color:var(--g1);opacity:.6;text-transform:uppercase;font-style:italic}

/* Stat grid (S2) */
.i-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;width:100%;max-width:340px;margin:0 auto 18px}
.i-stat-pill{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:12px;background:var(--card);border:1px solid var(--br);animation:popIn .4s both;text-align:left}
.i-stat-pill svg{width:20px;height:20px;flex-shrink:0}
.i-stat-name{font-family:'Cormorant SC',sans-serif;font-size:.88rem;font-weight:500}
.i-stat-hint{font-size:.72rem;color:var(--t3);margin-top:1px}
@keyframes popIn{from{opacity:0;transform:scale(.78)}to{opacity:1;transform:scale(1)}}

/* Mission rows (S3) */
.i-mrow{display:flex;align-items:flex-start;gap:14px;padding:13px 15px;border-radius:13px;margin-bottom:9px;text-align:left}
.i-mrow-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px}
.i-mrow-title{font-family:'Cormorant SC',sans-serif;font-size:.95rem;font-weight:500;margin-bottom:4px}
.i-mrow-desc{font-size:.82rem;color:var(--t2);line-height:1.48}

/* Feature chips (S4) */
.i-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:340px;margin:0 auto 18px}
.i-chip{display:flex;align-items:center;gap:5px;padding:8px 14px;border-radius:20px;background:var(--card);border:1px solid var(--br);font-family:'Cormorant SC',sans-serif;font-size:13px;font-weight:500;white-space:nowrap;color:var(--t1)}
.i-chip svg{width:12px;height:12px;flex-shrink:0;color:var(--g1)}
#is4{overflow:hidden;justify-content:flex-start;padding-top:2.8rem}
#is4 .i-h2{margin-bottom:10px}
.i-chips-float-arena{position:relative;flex:0 0 auto;width:100%;max-width:360px;height:clamp(280px,48vh,400px);margin:4px auto 0;overflow:hidden;border-radius:18px;background:radial-gradient(ellipse at 50% 40%,rgba(184,134,11,.06) 0%,transparent 68%)}
.i-chips-float-arena::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(184,134,11,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(184,134,11,.04) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 78%);pointer-events:none}
.i-chip-float{position:absolute;left:0;top:0;will-change:transform;pointer-events:none;box-shadow:0 4px 14px rgba(0,0,0,.28);backdrop-filter:blur(4px);transition:opacity .5s cubic-bezier(.4,0,.2,1),filter .5s ease;opacity:0;filter:blur(4px)}
.i-chips-float-arena .i-chip-float{padding:5px 9px;font-size:10px;border-radius:12px;gap:3px;letter-spacing:.01em}
.i-chips-float-arena .i-chip-float svg{width:9px!important;height:9px!important}
.i-chips-float-arena .i-chip-pro{font-size:7px;color:var(--g1);opacity:.85}
.i-chip-float.i-chip-in{opacity:1;filter:blur(0)}
.i-chip-float.i-chip-out{opacity:0!important;filter:blur(6px)!important}

/* Comparison table (S5) */
.i-vs{width:100%;max-width:340px;border-radius:14px;overflow:hidden;border:1px solid var(--br);margin:0 auto 18px}
.i-vs-h{display:grid;grid-template-columns:1fr 54px 54px 62px;background:var(--card2);padding:10px 13px;gap:4px}
.i-vs-h span{font-family:'Cormorant SC',sans-serif;font-size:.58rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--t3)}
.i-vs-h .ours{color:var(--g1);text-align:center}
.i-vs-h .other{text-align:center}
.i-vs-row{display:grid;grid-template-columns:1fr 54px 54px 62px;padding:9px 13px;gap:4px;align-items:center;border-top:1px solid rgba(184,134,11,.05)}
.i-vs-row:nth-child(odd){background:rgba(7,14,11,.5)}
.i-vs-f{font-size:.77rem;color:var(--t1)}
.i-vs-n{font-size:.76rem;color:#C24848;text-align:center}
.i-vs-y{font-family:'Cormorant SC',sans-serif;font-size:.76rem;color:#28A06C;font-weight:500;text-align:center}
.i-vs-inf{font-size:1.2rem;color:var(--g1);font-weight:600;line-height:1;letter-spacing:0}
.i-vs-m{font-size:.76rem;color:#B8860B;text-align:center}

/* Price card (S6) */
.i-price{background:var(--card);border:1px solid var(--br);border-radius:18px;padding:22px;width:100%;max-width:300px;margin:0 auto 16px;position:relative;overflow:hidden;text-align:left}
.i-price-top{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--g3),var(--g1),var(--g2))}
.i-feat{display:flex;align-items:center;gap:9px;font-size:.92rem;padding:.45rem 0;border-bottom:1px solid rgba(184,134,11,.07);color:var(--t1)}
.i-feat svg{width:13px;height:13px;flex-shrink:0;color:#28A06C}

/* Notification preview (S7) */
.i-notif{max-width:300px;width:100%;margin:0 auto 20px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:17px;padding:15px 16px;display:flex;gap:12px;align-items:center;text-align:left}
.i-notif-av{width:40px;height:40px;border-radius:11px;flex-shrink:0;background:linear-gradient(135deg,var(--g3),var(--g1));display:flex;align-items:center;justify-content:center}
.i-notif-av svg{width:20px;height:20px;color:#070E0B}

/* Assessment option (S8) */
.i-ao{background:var(--card);border:1px solid var(--br);border-radius:14px;padding:16px 18px;text-align:left;cursor:pointer;transition:all .18s;position:relative;overflow:hidden;width:100%;max-width:320px;display:block}
.i-ao::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:linear-gradient(var(--g3),var(--g1))}
.i-ao:active{transform:scale(.98);border-color:var(--br2)}
.i-ao-title{font-family:'Cormorant SC',sans-serif;font-size:1rem;font-weight:500;margin-bottom:5px;display:flex;align-items:center;gap:8px}
.i-ao-badge{font-size:.6rem;padding:2px 7px;border-radius:5px;background:rgba(184,134,11,.14);color:var(--g1);font-weight:500}
.i-ao-desc{font-size:.86rem;color:var(--t2);line-height:1.48}

/* ══════════════════════════════════════════════════
   ✦  VISUAL POLISH — FANCY UPGRADE
══════════════════════════════════════════════════ */

/* ── App ambient background glow ─────────────── */
#app{background:
  radial-gradient(ellipse 65% 42% at 18% 6%, rgba(184,134,11,.22) 0%,transparent 58%),
  radial-gradient(ellipse 55% 38% at 82% 94%, rgba(184,134,11,.25) 0%,transparent 52%),
  radial-gradient(ellipse 42% 30% at 55% 48%, rgba(184,134,11,.14) 0%,transparent 60%),
  #000000;background-clip:padding-box}

/* ── Card depth ──────────────────────────────── */
.card{box-shadow:0 1px 0 rgba(255,255,255,.045) inset,0 4px 24px rgba(0,0,0,.42);}

/* ── Gold CTA button shimmer ─────────────────── */
.bgold{
  background:linear-gradient(110deg,#9A7B2F 0%,#B8860B 35%,#D4AF37 52%,#B8860B 72%,#9A7B2F 100%) !important;
  background-size:220% 100% !important;
  animation:btnGlow 3.8s ease-in-out infinite;
  box-shadow:0 5px 26px rgba(184,134,11,.38),0 1px 0 rgba(255,255,255,.22) inset !important;
}
.bgold:active{
  transform:scale(.95);
  box-shadow:0 2px 10px rgba(184,134,11,.25) !important;
  animation:none !important;
}
@keyframes btnGlow{0%,100%{background-position:0% 0}50%{background-position:100% 0}}

/* ── Outline button lift ─────────────────────── */
.boutline{
  box-shadow:0 0 0 1px rgba(184,134,11,.18) inset,0 2px 12px rgba(184,134,11,.1);
  transition:all .18s;
}
.boutline:active{background:rgba(184,134,11,.22) !important;}

/* ── Done / mission button ───────────────────── */
.mdone-btn{box-shadow:0 0 0 1.5px rgba(184,134,11,.22) inset,0 2px 12px rgba(184,134,11,.14);}

/* ── Topbar premium border ───────────────────── */
#topbar{
  border-bottom-color:rgba(184,134,11,.2);
  box-shadow:0 4px 30px rgba(0,0,0,.58);
}

/* ── Nav bar glow ────────────────────────────── */
#nav{box-shadow:0 -1px 0 rgba(184,134,11,.14),0 -6px 32px rgba(0,0,0,.65);}
.nb.on{text-shadow:0 0 18px rgba(184,134,11,.55);}
.nb.on svg{filter:drop-shadow(0 0 7px rgba(184,134,11,.55));}
.nb.on::after{
  background:linear-gradient(90deg,transparent,var(--g1),transparent);
  opacity:1;
  width:34px;
}

/* ── XP bar shimmer ──────────────────────────── */
#h-xpb,#p-xpb{
  background:linear-gradient(90deg,var(--g3) 0%,var(--g1) 40%,var(--g2) 58%,var(--g3) 100%) !important;
  background-size:300% 100% !important;
  animation:xpFlow 3.2s linear infinite;
  box-shadow:0 0 10px rgba(184,134,11,.45),0 0 18px rgba(184,134,11,.18);
}
@keyframes xpFlow{0%{background-position:100% 0}100%{background-position:-200% 0}}

/* ── Mission cards ───────────────────────────── */
.mcard{transition:border-color .22s,box-shadow .2s,transform .15s;}
.mcard:not(.done):active{transform:scale(.984);box-shadow:0 8px 28px rgba(0,0,0,.55);}
.mcard.done{opacity:.3;filter:saturate(.3);}
.btn-clock{flex-shrink:0;width:36px;height:36px;border-radius:10px;background:rgba(117,96,200,.1);border:1px solid rgba(117,96,200,.25);color:#7560C8;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .18s,transform .15s}
.btn-clock:active{transform:scale(.9);background:rgba(117,96,200,.2)}
.sched-badge{font-family:'Cormorant SC',sans-serif;font-size:11px;font-weight:500;color:#7560C8;background:rgba(117,96,200,.1);padding:2px 8px;border-radius:5px;border:1px solid rgba(117,96,200,.2)}
.mcard.scheduled{border-color:rgba(117,96,200,.42)!important;box-shadow:0 0 0 1px rgba(117,96,200,.18),0 0 22px rgba(117,96,200,.14)!important}
.mcard.scheduled .sched-badge--glow{color:#c4b5fd;background:rgba(117,96,200,.2);border-color:rgba(117,96,200,.45);box-shadow:0 0 14px rgba(117,96,200,.35);animation:schedGlow 2.4s ease-in-out infinite}
@keyframes schedGlow{0%,100%{box-shadow:0 0 8px rgba(117,96,200,.22)}50%{box-shadow:0 0 18px rgba(117,96,200,.48)}}

/* ── Section headers gold accent ─────────────── */
.sh{padding-left:10px;border-left:2.5px solid var(--g1);}

/* ── Overlay sheet glass ─────────────────────── */
.ovs{
  background:linear-gradient(180deg,#0C2014 0%,#060D08 100%) !important;
  box-shadow:0 -4px 60px rgba(0,0,0,.85),0 0 0 1px rgba(184,134,11,.1);
}

/* ── Mission-complete circle pulse ───────────── */
@keyframes mcGlow{0%,100%{box-shadow:0 8px 32px rgba(40,160,108,.22)}55%{box-shadow:0 10px 52px rgba(40,160,108,.55),0 0 0 12px rgba(40,160,108,.07)}}
.mc-circle{animation:mcGlow 2.4s ease-in-out infinite;}

/* ── Profile stat bars ───────────────────────── */
.pbar-fill{filter:brightness(1.12) saturate(1.15);}

/* ── Achievement card unlocked glow ─────────── */
.achcard:not(.locked){
  border-color:rgba(184,134,11,.22);
  box-shadow:0 2px 18px rgba(0,0,0,.42),0 0 0 1px rgba(184,134,11,.07) inset;
}

/* ── Rank badge shadow ───────────────────────── */
.rank-badge{box-shadow:0 2px 14px rgba(0,0,0,.38),0 0 0 1px rgba(255,255,255,.04) inset;}

/* ── Toast premium ───────────────────────────── */
#toast{
  background:linear-gradient(135deg,rgba(10,22,14,.99),rgba(4,7,5,.99)) !important;
  border-color:rgba(184,134,11,.38) !important;
  box-shadow:0 14px 52px rgba(0,0,0,.82),0 0 28px rgba(184,134,11,.1) !important;
  color:var(--g2) !important;
  letter-spacing:.015em;
}

/* ── Daily reward today pulse ────────────────── */
@keyframes drPulse{0%,100%{box-shadow:0 0 0 2px rgba(184,134,11,.12)}55%{box-shadow:0 0 0 5px rgba(184,134,11,.28),0 4px 18px rgba(184,134,11,.14)}}
.dr-day.today{animation:drPulse 2.6s ease-in-out infinite;}

/* ── Boss HP bar animated glow ───────────────── */
.boss-hp-fill{
  background:linear-gradient(90deg,#721515,#C24848,#F05050,#C24848,#721515) !important;
  background-size:200% 100% !important;
  animation:bossHpGlow 1.8s ease-in-out infinite;
  box-shadow:0 0 12px rgba(194,72,72,.5);
}
@keyframes bossHpGlow{0%,100%{background-position:0% 0}100%{background-position:200% 0}}

/* ── More hub cards ──────────────────────────── */
.morecard{box-shadow:0 2px 16px rgba(0,0,0,.38);transition:all .2s;}
.morecard:active{transform:scale(.97);}

/* ── Shop equipped glow ──────────────────────── */
.shopitem.equipped{box-shadow:0 0 0 1.5px rgba(184,134,11,.32),0 4px 22px rgba(184,134,11,.14);}

/* ── Skill node unlocked glow ────────────────── */
.skill-node.unlocked{box-shadow:0 0 0 1px rgba(184,134,11,.24),0 4px 20px rgba(184,134,11,.1);}

/* ── Stat rings ──────────────────────────────── */
.sring-fill{filter:brightness(1.1);}

/* ── Stat card hover polish ─────────────────── */
.scard:hover{border-color:rgba(184,134,11,.32);box-shadow:0 6px 24px rgba(0,0,0,.35),0 0 20px rgba(184,134,11,.06)}

/* Mission card left accent is rendered inline in mCard() */

/* ── Home page stat pills row ───────────────── */
#h-stats .spill{border-color:rgba(184,134,11,.1)}

/* ── Input fields focus glow ─────────────────── */
.ob-input:focus{
  border-color:var(--g1) !important;
  box-shadow:0 0 0 3px rgba(184,134,11,.12),0 2px 14px rgba(184,134,11,.1);
  outline:none;
}

/* ── Page enter ──────────────────────────────── */
@keyframes pgIn{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}

/* ── Confetti variety ────────────────────────── */
.cf:nth-child(3n){border-radius:50%;}
.cf:nth-child(5n){width:3px !important;border-radius:1px;}

/* ── Onboarding card ─────────────────────────── */
.ob-card{box-shadow:0 8px 48px rgba(0,0,0,.65),0 0 0 1px rgba(184,134,11,.12) inset;}

/* ── Gold gradient text glow ─────────────────── */
.mc-bigxp,.lu-bignum{filter:drop-shadow(0 0 18px rgba(184,134,11,.4));}

/* ── Rank-up celebration ────────────────────── */
@keyframes rankPulse{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.15)}100%{transform:scale(1);opacity:1}}
@keyframes rankGlow{0%,100%{box-shadow:0 0 40px rgba(184,134,11,.3)}50%{box-shadow:0 0 80px rgba(184,134,11,.6),0 0 120px rgba(184,134,11,.2)}}
#ru-rank-icon{animation:rankPulse .7s cubic-bezier(.34,1.56,.64,1) forwards,rankGlow 2s .7s ease-in-out infinite;}
#ru-rank-label{filter:drop-shadow(0 0 24px rgba(184,134,11,.5));}

/* ── Boss HP bar ───────────────────────────── */
.boss-hp-track{width:100%;height:8px;background:rgba(168,56,56,.15);border-radius:4px;overflow:hidden}
.boss-hp-fill{height:100%;background:linear-gradient(90deg,#C04848,#F87171);border-radius:4px;transition:width .4s ease}

/* ══════════════════════════════════════════════════
   ✦  LUXURY v2 — Premium visual layer
══════════════════════════════════════════════════ */

/* Ambient backdrop behind phone */
body{
  background:
    radial-gradient(ellipse 70% 45% at 15% 20%, rgba(184,134,11,.08) 0%, transparent 55%),
    radial-gradient(ellipse 55% 40% at 85% 80%, rgba(184,134,11,.08) 0%, transparent 50%),
    radial-gradient(ellipse 40% 30% at 50% 50%, rgba(20,60,40,.12) 0%, transparent 60%),
    #030303 !important;
}

/* Gold bezel + inner rim light */
#app{
  box-shadow:
    0 0 0 1px rgba(184,134,11,.22),
    0 0 0 4px rgba(0,0,0,.4),
    0 28px 72px rgba(0,0,0,.82),
    0 0 80px rgba(184,134,11,.06),
    inset 0 1px 0 rgba(255,255,255,.06) !important;
}
#app::before{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:9000;
  box-shadow:inset 0 0 60px rgba(184,134,11,.04),inset 0 1px 0 rgba(255,255,255,.05);
}
#app::after{
  content:'';position:absolute;top:10px;left:50%;transform:translateX(-50%);width:88px;height:4px;
  border-radius:99px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  pointer-events:none;z-index:9001;opacity:.55;
}
@media(display-mode:standalone){#app::after{display:none}}

/* Main scroll — depth mesh */
#main{
  background:
    radial-gradient(ellipse 90% 40% at 50% 0%, rgba(184,134,11,.07) 0%, transparent 55%),
    radial-gradient(ellipse 60% 35% at 100% 100%, rgba(184,134,11,.05) 0%, transparent 50%),
    var(--bg);
}

/* Hero — cinematic glass card */
.hero{
  margin:14px 14px 0 !important;
  padding:22px 20px 20px !important;
  background:
    linear-gradient(155deg, rgba(13,26,14,.98) 0%, rgba(22,48,26,.92) 38%, rgba(14,32,18,.96) 68%, rgba(8,18,10,.98) 100%) !important;
  border:1px solid rgba(184,134,11,.28) !important;
  box-shadow:
    0 16px 48px rgba(0,0,0,.55),
    0 0 0 1px rgba(184,134,11,.08) inset,
    0 1px 0 rgba(255,255,255,.07) inset,
    0 0 40px rgba(184,134,11,.08) !important;
  backdrop-filter:blur(12px);
}
.hero::before{
  width:240px;height:240px;top:-80px;right:-60px;
  background:radial-gradient(circle,rgba(184,134,11,.22),transparent 68%) !important;
  animation:heroOrbA 8s ease-in-out infinite;
}
.hero::after{
  width:200px;height:200px;bottom:-70px;left:-50px;
  background:radial-gradient(circle,rgba(184,134,11,.22),transparent 68%) !important;
  animation:heroOrbB 10s ease-in-out infinite;
}
@keyframes heroOrbA{0%,100%{transform:translate(0,0) scale(1);opacity:.9}50%{transform:translate(-12px,8px) scale(1.08);opacity:1}}
@keyframes heroOrbB{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(10px,-6px) scale(1.06)}}

#h-lv{
  filter:drop-shadow(0 0 28px rgba(184,134,11,.45)) drop-shadow(0 4px 16px rgba(0,0,0,.4));
  line-height:.85 !important;
}
#h-name{letter-spacing:-.03em;text-shadow:0 2px 20px rgba(184,134,11,.15)}
#h-greeting{font-size:12px !important;letter-spacing:.12em;text-transform:uppercase;font-family:'Cormorant SC',sans-serif !important}

/* Stat pills — frosted glass */
.spill{
  background:rgba(255,255,255,.04) !important;
  border:1px solid rgba(184,134,11,.12) !important;
  backdrop-filter:blur(10px);
  box-shadow:0 4px 16px rgba(0,0,0,.28),inset 0 1px 0 rgba(255,255,255,.05);
  transition:transform .18s,border-color .18s,box-shadow .18s;
}
.spill:active{transform:scale(.96)}
.spill-val{text-shadow:0 0 16px rgba(184,134,11,.35)}

/* XP track — premium bar */
.xbtrack{height:5px !important;background:rgba(0,0,0,.45) !important;border:1px solid rgba(184,134,11,.12);box-shadow:inset 0 1px 3px rgba(0,0,0,.4)}

/* Cards — glass depth */
.card,.card2,.mcard{
  backdrop-filter:blur(8px);
  box-shadow:
    0 1px 0 rgba(255,255,255,.05) inset,
    0 8px 32px rgba(0,0,0,.45),
    0 0 0 1px rgba(184,134,11,.06) !important;
}
.mcard:not(.done){
  border-color:rgba(184,134,11,.18) !important;
}
.mcard:not(.done):hover{
  border-color:rgba(184,134,11,.38) !important;
  box-shadow:0 12px 36px rgba(0,0,0,.55),0 0 24px rgba(184,134,11,.08),0 1px 0 rgba(255,255,255,.05) inset !important;
}

/* Stat rings — jewel glow */
.scard{
  background:linear-gradient(160deg,rgba(13,26,14,.95),rgba(8,15,10,.98)) !important;
  border-color:rgba(184,134,11,.16) !important;
  box-shadow:0 6px 24px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.04) !important;
  transition:transform .2s,box-shadow .2s,border-color .2s !important;
}
.scard:active{transform:scale(.97) !important}

/* Topbar — luxe header */
#topbar{
  background:linear-gradient(180deg,rgba(10,20,12,.98) 0%,rgba(7,14,11,.94) 100%) !important;
  border-bottom:1px solid rgba(184,134,11,.18) !important;
}
.brand svg{filter:drop-shadow(0 0 8px rgba(184,134,11,.45))}
.tpill{
  background:linear-gradient(135deg,rgba(184,134,11,.12),rgba(184,134,11,.05)) !important;
  border-color:rgba(184,134,11,.22) !important;
  box-shadow:0 2px 12px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.06);
}

/* Nav — active tab glow pill */
#nav{
  background:linear-gradient(0deg,rgba(6,12,8,.99) 0%,rgba(7,14,11,.92) 100%) !important;
  border-top:1px solid rgba(184,134,11,.16) !important;
}
.nb.on{
  background:radial-gradient(ellipse 90% 120% at 50% 110%,rgba(184,134,11,.2),transparent 70%);
  border-radius:14px 14px 0 0;
}

/* Section headers — refined */
.sh{
  color:var(--g2) !important;
  letter-spacing:.1em !important;
  border-left-width:3px !important;
  border-image:linear-gradient(180deg,var(--g1),var(--g3)) 1 !important;
  padding-left:12px !important;
}

/* Buttons — richer depth */
.bgold{
  text-shadow:0 1px 0 rgba(255,255,255,.25);
  letter-spacing:.02em !important;
}
.bghost{
  backdrop-filter:blur(6px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}

@media(prefers-reduced-motion:reduce){
  .page.on,.page.leaving{animation:none}
  .nb,.nb svg,.ftab{transition:none}
}

/* Difficulty badges — jewel tones */
.diff.de{background:linear-gradient(135deg,rgba(40,160,108,.22),rgba(40,160,108,.08)) !important;border:1px solid rgba(40,160,108,.35) !important}
.diff.dm{background:linear-gradient(135deg,rgba(184,134,11,.22),rgba(184,134,11,.08)) !important;border:1px solid rgba(184,134,11,.35) !important}
.diff.dh{background:linear-gradient(135deg,rgba(194,72,72,.22),rgba(194,72,72,.08)) !important;border:1px solid rgba(194,72,72,.35) !important}

/* Intro slides — richer atmosphere */
.i-orb-a,.i-orb-b{opacity:.85}
.i-h1{text-shadow:0 4px 40px rgba(184,134,11,.15)}
.i-logo{box-shadow:0 0 0 1px rgba(184,134,11,.35),0 12px 40px rgba(184,134,11,.25),inset 0 1px 0 rgba(255,255,255,.12) !important}

/* Proof capture (hard missions) — bottom sheet */
.proof-capture-ov{z-index:9997}
.proof-sheet{
  background:linear-gradient(180deg,#101a10 0%,var(--bg2) 28%,#060d08 100%) !important;
  border-color:var(--br2) !important;
  text-align:center;
  padding-top:18px !important;
}
.proof-hero-icon{
  width:72px;height:72px;border-radius:20px;margin:0 auto 14px;
  background:linear-gradient(145deg,rgba(194,72,72,.22),rgba(139,48,48,.08));
  border:1px solid rgba(194,72,72,.35);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 32px rgba(194,72,72,.18),inset 0 1px 0 rgba(255,255,255,.06);
}
.proof-hero-icon svg{width:34px;height:34px;color:#E87878}
.proof-eyebrow{
  font-family:'Cormorant SC',sans-serif;font-size:10px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:#C24848;margin-bottom:6px;
}
.proof-sheet-title{
  margin:0 0 8px;font-family:'Cormorant SC',sans-serif;font-size:26px;font-weight:500;letter-spacing:-.02em;
}
.proof-mission-name{margin:0 0 8px;font-size:15px;color:var(--g2);font-weight:500}
.proof-sheet-hint{margin:0 0 20px;font-size:13px;color:var(--t2);line-height:1.55;max-width:300px;margin-left:auto;margin-right:auto}
.proof-options{display:flex;flex-direction:column;gap:10px;margin-bottom:18px;text-align:left}
.proof-tile{
  width:100%;display:flex;align-items:center;gap:12px;padding:14px 14px;
  background:rgba(255,255,255,.03);border:1px solid var(--br);border-radius:14px;
  cursor:pointer;color:inherit;transition:border-color .2s,background .2s,transform .15s;
}
.proof-tile:active{transform:scale(.985)}
.proof-tile:hover,.proof-tile:focus-visible{border-color:var(--br2);background:rgba(184,134,11,.06);outline:none}
.proof-tile-icon{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.proof-tile-icon svg{width:22px;height:22px}
.proof-tile-icon--photo{background:rgba(184,134,11,.12);border:1px solid rgba(184,134,11,.22);color:var(--g2)}
.proof-tile-icon--note{background:rgba(117,96,200,.12);border:1px solid rgba(117,96,200,.22);color:#A898E0}
.proof-tile-body{flex:1;min-width:0}
.proof-tile-title{display:block;font-family:'Cormorant SC',sans-serif;font-size:15px;font-weight:500;color:var(--t1);margin-bottom:2px}
.proof-tile-desc{display:block;font-size:12px;color:var(--t2);line-height:1.35}
.proof-tile-chevron{color:var(--t3);flex-shrink:0;display:flex;align-items:center}
#photo-input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;overflow:hidden}
.proof-field-label{
  display:block;text-align:left;font-family:'Cormorant SC',sans-serif;font-size:10px;font-weight:500;
  color:var(--t3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;
}
.proof-note-area{margin-bottom:16px;text-align:left}
.proof-note-area .ob-input{margin-bottom:0;resize:vertical;min-height:96px}
.proof-note-actions,.proof-photo-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
.proof-photo-preview{margin-bottom:16px;text-align:center}
.proof-photo-preview img{max-width:100%;max-height:240px;border-radius:14px;border:1px solid var(--br);box-shadow:0 8px 24px rgba(0,0,0,.35)}
.proof-summary{background:rgba(255,255,255,.03);border-radius:14px;padding:16px;margin-bottom:16px;border:1px solid var(--br);text-align:center}
.proof-summary-label{font-family:'Cormorant SC',sans-serif;font-size:10px;color:var(--g1);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.proof-summary-img{max-width:100%;max-height:200px;border-radius:12px;border:1px solid var(--br2)}
.proof-summary-note{background:var(--bg2);padding:12px 14px;border-radius:10px;color:var(--t1);font-size:14px;line-height:1.55;font-style:italic;border-left:3px solid var(--g1);text-align:left}
.proof-footer{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.proof-footer .btn{width:100%}
.proof-skip-btn{color:var(--t2) !important}
.proof-sheet [hidden]{display:none !important}

/* ── Proof Feed page ───────────────────────────── */
.pf-page{padding:0 0 8px}
.pf-header{
  padding:20px 16px 16px;text-align:center;
  border-bottom:1px solid var(--br);margin-bottom:4px;
  background:linear-gradient(180deg,rgba(184,134,11,.06) 0%,transparent 100%);
}
.pf-title{
  font-family:'Cormorant SC',sans-serif;font-size:26px;font-weight:500;letter-spacing:-.02em;
  background:var(--gd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:6px;
}
.pf-subtitle{font-size:13px;color:var(--t2);line-height:1.5;max-width:300px;margin:0 auto}
.pf-feed{padding:12px 16px 24px;display:flex;flex-direction:column;gap:12px}
.pf-card{
  background:var(--card);border:1px solid var(--br);border-radius:16px;padding:16px 16px 14px;
  position:relative;overflow:hidden;transition:border-color .2s,box-shadow .2s;
}
.pf-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--g2),var(--g1));border-radius:3px 0 0 3px;opacity:.85;
}
.pf-card:hover{border-color:var(--br2);box-shadow:0 8px 28px rgba(0,0,0,.35)}
.pf-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.pf-user-avatar{
  width:42px;height:42px;border-radius:12px;flex-shrink:0;
  background:rgba(184,134,11,.1);border:1px solid rgba(184,134,11,.22);
  display:flex;align-items:center;justify-content:center;font-size:20px;
}
.pf-user-info{flex:1;min-width:0}
.pf-user-name{
  font-family:'Cormorant SC',sans-serif;font-size:15px;font-weight:500;color:var(--t1);
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:2px;
}
.pf-you-badge{
  font-family:'Jost',sans-serif;font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
  padding:2px 7px;border-radius:6px;background:rgba(184,134,11,.15);color:var(--g2);border:1px solid rgba(184,134,11,.25);
}
.pf-time{font-size:11px;color:var(--t3);display:block}
.pf-mission-row{margin-bottom:12px}
.pf-stat-badge{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:500;letter-spacing:.02em;text-transform:uppercase;
  padding:4px 10px;border-radius:8px;margin-bottom:8px;
  background:color-mix(in srgb,var(--pf-stat,#B8860B) 14%,transparent);
  color:var(--pf-stat,#B8860B);border:1px solid color-mix(in srgb,var(--pf-stat,#B8860B) 28%,transparent);
}
.pf-stat-emoji{font-size:12px;line-height:1}
.pf-mission-title{
  font-size:15px;font-weight:400;color:var(--t1);line-height:1.45;margin:0;
  display:flex;align-items:flex-start;gap:8px;
}
.pf-check-icon{
  color:var(--c-fi);font-weight:700;font-size:14px;flex-shrink:0;margin-top:2px;
}
.pf-card-body{margin-bottom:12px}
.pf-proof-photo{border-radius:12px;overflow:hidden;background:rgba(0,0,0,.35);border:1px solid var(--br)}
.pf-proof-photo img{width:100%;max-height:280px;object-fit:cover;display:block}
.pf-proof-note{
  background:rgba(255,255,255,.03);border:1px solid var(--br);border-radius:12px;
  padding:12px 14px;border-left:3px solid var(--g1);
}
.pf-proof-note p{font-size:14px;color:var(--t2);line-height:1.6;margin:0;font-style:italic}
.pf-card-actions{
  display:flex;align-items:center;padding-top:12px;border-top:1px solid rgba(184,134,11,.1);
}
.pf-fire-btn{
  display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:20px;
  background:rgba(184,134,11,.08);border:1px solid rgba(184,134,11,.22);
  color:var(--t2);font-size:13px;font-weight:500;cursor:pointer;
  transition:background .2s,border-color .2s,color .2s,transform .15s;
  font-family:'Jost',sans-serif;
}
.pf-fire-btn:hover{background:rgba(184,134,11,.14);border-color:var(--br2);color:var(--t1)}
.pf-fire-btn:active{transform:scale(.97)}
.pf-fire-btn.fired{
  background:rgba(192,100,24,.16);border-color:rgba(255,100,50,.35);color:#FF8C5A;
}
.pf-fire-icon{font-size:15px;line-height:1;transition:transform .2s}
.pf-fire-btn.fired .pf-fire-icon{transform:scale(1.12)}
.pf-fire-count{font-family:'Cormorant SC',sans-serif;font-size:14px;font-weight:500;min-width:16px;text-align:center;color:inherit}
.pf-fire-label{font-size:12px;letter-spacing:.02em}
@keyframes pfFirePulse{0%{transform:scale(1)}50%{transform:scale(1.06)}100%{transform:scale(1)}}
.pf-fire-pulse{animation:pfFirePulse .4s ease}
.pf-empty{text-align:center;padding:56px 24px 40px}
.pf-empty-icon{font-size:44px;margin-bottom:14px;opacity:.9}
.pf-empty-title{font-family:'Cormorant SC',sans-serif;font-size:20px;font-weight:500;color:var(--t1);margin-bottom:8px}
.pf-empty-desc{font-size:14px;color:var(--t2);line-height:1.6;max-width:280px;margin:0 auto}

