:root{
  --bg:#120e2e; --bg2:#1a1640; --panel:#221c52; --panel2:#2b2466; --line:#372e7a;
  --txt:#ede9ff; --mut:#a59fd6; --dim:#7d77b3;
  --accent:#7c5cff; --accent2:#b15cff; --grad:linear-gradient(135deg,#7c5cff,#b15cff);
  --gold:#ffce4d; --flame:#ff7a3d; --green:#34d399; --red:#ff5d73; --cyan:#3dd7ff;
  --common:#9aa3b2; --uncommon:#5fd06b; --rare:#3dd7ff; --epic:#b15cff; --legendary:#ffce4d;
  --r:16px; --sb:240px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:radial-gradient(1200px 800px at 80% -10%,#2a1f63 0%,var(--bg) 55%) fixed,var(--bg);
  color:var(--txt);overflow-x:hidden;
  padding-top:env(safe-area-inset-top);
}
button{font-family:inherit;cursor:pointer;border:none;color:inherit;background:none}
input,select,textarea{font-family:inherit;font-size:16px}
a{color:var(--accent2);cursor:pointer}
.hidden{display:none!important}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--panel2);border-radius:8px}

/* ---------- Boot / Auth ---------- */
#boot{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px;background:var(--bg);z-index:90}
.logo-orb{width:84px;height:84px;border-radius:24px;background:var(--grad);display:grid;place-items:center;font-size:44px;box-shadow:0 16px 50px rgba(124,92,255,.5);animation:float 2.6s ease-in-out infinite}
@keyframes float{50%{transform:translateY(-8px)}}
.spin{width:26px;height:26px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:sp .8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

#auth{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:24px;z-index:80}
.auth-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--line);border-radius:24px;padding:30px 26px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.brand .o{width:48px;height:48px;border-radius:14px;background:var(--grad);display:grid;place-items:center;font-size:26px}
.brand h1{font-size:22px;margin:0;letter-spacing:.3px}
.tag{color:var(--mut);font-size:13px;margin:0 0 22px}
.tabs{display:flex;background:var(--bg2);border-radius:12px;padding:4px;margin-bottom:18px}
.tabs button{flex:1;padding:10px;border-radius:9px;color:var(--mut);font-weight:600;font-size:14px}
.tabs button.on{background:var(--grad);color:#fff;box-shadow:0 6px 18px rgba(124,92,255,.4)}
.field{margin-bottom:13px}
.field label{display:block;font-size:12px;color:var(--mut);margin-bottom:6px;font-weight:600}
.inp{width:100%;padding:13px 14px;background:var(--bg2);border:1px solid var(--line);border-radius:12px;color:var(--txt);outline:none}
.inp:focus{border-color:var(--accent)}
textarea.inp{font:inherit;resize:vertical;line-height:1.4;min-height:48px}
.comp-terms{margin-top:5px;font-size:12px;font-weight:600;color:#ffd98a;background:rgba(255,206,77,.1);border:1px solid rgba(255,206,77,.28);border-radius:9px;padding:5px 9px;display:inline-block;max-width:100%}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border-radius:13px;font-weight:700;font-size:15px;background:var(--grad);color:#fff;width:100%;box-shadow:0 10px 26px rgba(124,92,255,.4)}
.btn.sec{background:var(--panel2);box-shadow:none;border:1px solid var(--line)}
.btn.ghost{background:transparent;border:1px solid var(--line);box-shadow:none}
.btn.sm{width:auto;padding:9px 14px;font-size:13px}
.btn.danger{background:linear-gradient(135deg,#ff5d73,#c4304c);box-shadow:none}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.5}
.err{color:var(--red);font-size:13px;margin-top:12px;min-height:16px;text-align:center}

/* ---------- App shell ---------- */
#app{display:none;min-height:100vh}
.shell{display:flex;min-height:100vh}

/* Sidebar (desktop) */
.sidebar{display:none;width:var(--sb);flex-shrink:0;border-right:1px solid var(--line);background:linear-gradient(180deg,var(--bg2),var(--bg));position:fixed;top:0;bottom:0;left:0;padding:18px 14px;flex-direction:column;gap:6px;z-index:30}
.sb-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 16px}
.sb-brand .o{width:40px;height:40px;border-radius:12px;background:var(--grad);display:grid;place-items:center;font-size:22px}
.sb-brand b{font-size:16px}
.sb-comp{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px 12px;margin-bottom:10px;cursor:pointer}
.sb-comp small{color:var(--dim);font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.sb-comp .nm{font-weight:700;display:flex;justify-content:space-between;align-items:center;gap:6px}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:12px;color:var(--mut);font-weight:600;font-size:14.5px;width:100%;text-align:left}
.nav-item .ic{font-size:19px;width:22px;text-align:center}
.nav-item.on{background:var(--panel2);color:#fff}
.nav-item.on .ic{filter:drop-shadow(0 0 6px var(--accent))}
.nav-item:hover{color:#fff}
.sb-spacer{flex:1}
.sb-user{display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;background:var(--panel);border:1px solid var(--line);cursor:pointer}
.sb-user .av{width:34px;height:34px;border-radius:10px;background:var(--bg2);display:grid;place-items:center;font-size:18px;overflow:hidden}

/* Main */
.main{flex:1;min-width:0;padding-bottom:96px}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;background:rgba(18,14,46,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.topbar .tt{display:flex;flex-direction:column;min-width:0}
.topbar .tt b{font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar .tt small{color:var(--dim);font-size:11.5px}
.tb-av{width:38px;height:38px;border-radius:12px;background:var(--panel2);display:grid;place-items:center;font-size:20px;flex-shrink:0;border:1px solid var(--line)}
.content{max-width:820px;margin:0 auto;padding:16px}
.view{display:none;animation:fade .25s ease}
.view.on{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}}

/* Bottom nav (mobile) */
.bottomnav{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;justify-content:space-around;align-items:stretch;background:rgba(26,22,64,.92);backdrop-filter:blur(16px);border-top:1px solid var(--line);padding:8px 4px calc(8px + env(safe-area-inset-bottom))}
.bn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--dim);font-size:10.5px;font-weight:600;padding:4px 2px;border-radius:12px;max-width:90px}
.bn .ic{font-size:21px;line-height:1}
.bn.on{color:#fff}
.bn.on .ic{transform:translateY(-1px);filter:drop-shadow(0 0 8px var(--accent))}

/* ---------- Cards / generic ---------- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:16px;margin-bottom:14px}
.card h3{margin:0 0 12px;font-size:15px;display:flex;align-items:center;gap:8px}
.sec-title{font-size:12px;text-transform:uppercase;letter-spacing:.7px;color:var(--dim);font-weight:700;margin:18px 4px 10px}
.row{display:flex;align-items:center;gap:12px}
.between{justify-content:space-between}
.pill{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:999px;background:var(--bg2);border:1px solid var(--line);font-size:12.5px;font-weight:600}
.muted{color:var(--mut)}.dim{color:var(--dim)}
.empty{text-align:center;color:var(--dim);padding:34px 16px}
.empty .big{font-size:42px;margin-bottom:8px}
.fab{position:fixed;right:18px;bottom:calc(84px + env(safe-area-inset-bottom));width:56px;height:56px;border-radius:18px;background:var(--grad);display:grid;place-items:center;font-size:28px;color:#fff;box-shadow:0 12px 30px rgba(124,92,255,.5);z-index:35}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* Today hero */
.hero{background:linear-gradient(135deg,#2a2070,#3a2585);border:1px solid var(--line);border-radius:22px;padding:18px;margin-bottom:16px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;background:radial-gradient(circle,rgba(177,92,255,.5),transparent 70%)}
.hero .top{display:flex;align-items:center;gap:16px;position:relative}
.ring{position:relative;width:96px;height:96px;flex-shrink:0}
.ring svg{transform:rotate(-90deg)}
.ring .lbl{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring .lbl b{font-size:24px;line-height:1}
.ring .lbl small{font-size:10px;color:var(--mut)}
.hero .stats{flex:1}
.hero h2{margin:0 0 2px;font-size:20px}
.streakflame{display:inline-flex;align-items:center;gap:6px;background:rgba(255,122,61,.16);border:1px solid rgba(255,122,61,.4);color:#ffb38a;padding:5px 11px;border-radius:999px;font-weight:700;font-size:13px}
.multi{display:inline-flex;align-items:center;gap:5px;background:rgba(255,206,77,.14);border:1px solid rgba(255,206,77,.35);color:var(--gold);padding:5px 11px;border-radius:999px;font-weight:700;font-size:13px}

/* Goal log rows */
.goal{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:12px 13px;margin-bottom:10px}
.goal .g-top{display:flex;align-items:center;gap:11px}
.goal .em{font-size:24px;width:34px;text-align:center}
.goal .g-name{flex:1;min-width:0}
.goal .g-name b{display:block;font-size:14.5px}
.goal .g-name small{color:var(--dim);font-size:12px}
.goal .g-pct{font-weight:800;font-size:15px;min-width:46px;text-align:right}
.gbar{height:7px;border-radius:6px;background:#15112f;overflow:hidden;margin-top:10px}
.gbar > i{display:block;height:100%;border-radius:6px;background:var(--grad);transition:width .4s}
.gbar.done > i{background:linear-gradient(90deg,#34d399,#10b981)}
.logrow{display:flex;align-items:center;gap:8px;margin-top:11px}
.stepper{display:flex;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:11px;overflow:hidden;flex:1}
.stepper button{width:42px;height:42px;font-size:22px;color:var(--accent2);font-weight:700}
.stepper input{flex:1;width:100%;text-align:center;background:transparent;border:none;color:var(--txt);font-weight:700;font-size:16px;outline:none;-moz-appearance:textfield}
.stepper input::-webkit-outer-spin-button,.stepper input::-webkit-inner-spin-button{-webkit-appearance:none}
.tick{width:42px;height:42px;border-radius:11px;background:var(--panel2);display:grid;place-items:center;font-size:18px;border:1px solid var(--line)}
.tick.done{background:linear-gradient(135deg,#34d399,#10b981)}
.bigcheck{width:48px;height:48px;border-radius:50%;border:2.5px solid var(--line);background:var(--bg2);display:grid;place-items:center;font-size:24px;color:#fff;flex-shrink:0;font-weight:800;transition:.15s}
.bigcheck.done{background:linear-gradient(135deg,#34d399,#10b981);border-color:#10b981}
.bigcheck:active{transform:scale(.92)}

/* Leaderboard */
.lb{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-bottom:10px;display:flex;align-items:center;gap:13px}
.lb.me{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 8px 24px rgba(124,92,255,.25);background:var(--panel2)}
.lb .rk{font-weight:800;font-size:17px;width:30px;text-align:center;color:var(--mut)}
.lb .av{width:46px;height:46px;border-radius:13px;background:var(--bg2);display:grid;place-items:center;font-size:24px;flex-shrink:0;border:1px solid var(--line);overflow:hidden}
.lb .info{flex:1;min-width:0}
.lb .info b{font-size:15px;display:block}
.lb .info .sub{color:var(--dim);font-size:12px;display:flex;gap:10px;flex-wrap:wrap;margin-top:2px}
.lb .score{text-align:right;flex-shrink:0}
.lb .score b{font-size:19px;color:var(--gold)}
.lb .score small{display:block;color:var(--dim);font-size:11px}
.lb .score .score-today{display:block;color:var(--green);font-size:10.5px;font-weight:700;margin-top:2px;white-space:nowrap}
/* points breakdown in the player sheet */
.brk{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:14px}
.brk-tot{display:flex;justify-content:space-between;align-items:flex-end;border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:9px}
.brk-tot b{font-size:24px;color:var(--gold);display:block;line-height:1.05}
.brk-tot span{font-size:11px;color:var(--dim)}
.brk-today{text-align:right}
.brk-today b{font-size:17px;color:var(--green)}
.brk-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:3px 0}
.brk-row b{font-weight:700}
.rk.r1{color:var(--gold)}.rk.r2{color:#d8d8e8}.rk.r3{color:#e0985a}
.podium-medal{font-size:19px}
.lb{cursor:pointer;transition:border-color .15s}
.lb:active{border-color:var(--accent)}
.lb-fight{width:36px;height:36px;border-radius:11px;background:var(--panel2);border:1px solid var(--line);font-size:17px;flex-shrink:0;display:grid;place-items:center;color:#fff}
.lb-fight:active{background:var(--accent)}

/* Daily + Competition countdown dials */
.dials{display:flex;gap:8px;flex-shrink:0}

/* "Your Lead" insight card */
.leadcard{background:linear-gradient(135deg,#241b5c,#322278);border:1px solid var(--line);border-radius:14px;padding:13px 16px;margin-bottom:12px}
.leadcard.ahead{border-color:rgba(255,206,77,.45)}
.leadcard.behind{border-color:rgba(124,92,255,.55)}
.leadcard .lead-head{font-size:11px;font-weight:800;color:var(--mut);text-transform:uppercase;letter-spacing:.05em}
.leadcard .lead-gap{font-size:22px;font-weight:800;color:#fff;margin:3px 0 6px;line-height:1.15}
.leadcard.solo .lead-gap{font-size:14px;font-weight:600;color:var(--dim)}
.leadcard .lead-sub{font-size:13px;color:var(--dim);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.leadcard .lead-sub .pd{color:#ffd98a;font-weight:700}
.leadcard .lead-sub .dot{color:var(--mut)}
.lead-mom{font-weight:700}
.lead-mom.up{color:var(--green)}.lead-mom.down{color:#ff7a6b}.lead-mom.flat{color:var(--dim)}

/* Player detail sheet */
.psheet-head{display:flex;align-items:center;gap:13px;margin-bottom:16px}
.psheet-head .av{width:54px;height:54px;border-radius:14px;background:var(--bg2);display:grid;place-items:center;font-size:28px;border:1px solid var(--line);flex-shrink:0;overflow:hidden}
.psheet-head .av img{width:100%;height:100%;object-fit:cover}
.pstat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.pstat{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:11px 13px}
.pstat-v{font-size:16px;font-weight:700}
.pstat-l{font-size:11.5px;color:var(--dim);margin-top:2px}

/* Badges */
.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(102px,1fr));gap:12px}
.badge{background:var(--bg2);border:1px solid var(--line);border-radius:16px;padding:14px 8px;text-align:center;position:relative;overflow:hidden;cursor:pointer}
.badge .be{font-size:34px;filter:grayscale(1) opacity(.34);transition:.3s;height:40px;display:flex;align-items:center;justify-content:center}
.badge .be img{width:40px;height:40px;object-fit:contain;display:block}
/* badge detail hero + admin upload zone */
.badge-hero{width:96px;height:96px;margin:0 auto;border-radius:18px;overflow:hidden;display:grid;place-items:center;background:var(--bg2);border:1px solid var(--line)}
.badge-hero img{width:100%;height:100%;object-fit:contain}
.badge-hero.locked{filter:grayscale(1) opacity(.45)}
.badgeupload{width:104px;height:104px;border-radius:18px;overflow:hidden;border:2px dashed var(--line);background:var(--bg2);margin:0 auto 12px;cursor:pointer;display:grid;place-items:center;font-size:38px;color:var(--mut);text-align:center}
.badgeupload img{width:100%;height:100%;object-fit:contain}
.badge .bn{font-size:12px;font-weight:700;margin-top:6px;line-height:1.2}
.badge .br{font-size:9.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--dim);margin-top:3px;font-weight:700}
.badge.earned .be{filter:none;animation:pop .5s ease}
.badge.earned{border-color:var(--rarc)}
.badge.earned::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0,var(--rarc) 0,transparent 62%);opacity:.16}
.badge.earned .bn{color:#fff}
@keyframes pop{0%{transform:scale(.5)}60%{transform:scale(1.15)}}
.rar-common{--rarc:var(--common)}.rar-uncommon{--rarc:var(--uncommon)}.rar-rare{--rarc:var(--rare)}.rar-epic{--rarc:var(--epic)}.rar-legendary{--rarc:var(--legendary)}

/* Collectible cards */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:12px}
.cardx{background:var(--bg2);border:2px solid var(--rarc,var(--line));border-radius:12px;overflow:hidden;cursor:pointer;position:relative}
.cardx-img{aspect-ratio:3/4;background:#15112f;display:grid;place-items:center;overflow:hidden}
.cardx-img img{width:100%;height:100%;object-fit:contain;display:block}
.cardx-lock{font-size:34px;opacity:.55}
.cardx-nm{font-size:11px;font-weight:700;text-align:center;padding:6px 4px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cardx.locked{opacity:.65}
.cardx.locked .cardx-img img{filter:grayscale(1) brightness(.35)}
.cardx-ct{position:absolute;top:5px;right:5px;background:rgba(0,0,0,.72);color:#fff;font-size:11px;font-weight:800;padding:2px 7px;border-radius:999px;border:1px solid var(--rarc,var(--line))}
.cardbig{max-width:min(360px,86vw);min-height:140px;margin:0 auto;border-radius:16px;overflow:hidden;border:3px solid var(--rarc,var(--line));background:#15112f;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 44px rgba(0,0,0,.55);cursor:zoom-in}
.cardbig img{display:block;width:100%;height:auto;max-height:70vh;object-fit:contain}
.cardbig.locked img{filter:grayscale(1) brightness(.35)}
.cardbig.reveal{animation:cardreveal .6s cubic-bezier(.2,.9,.3,1.35)}
.cardview-nav{display:flex;align-items:center;gap:8px;justify-content:center}
.cardview .cardbig{flex:1;max-width:300px;margin:0}
.cv-arrow{flex-shrink:0;width:42px;height:64px;border-radius:12px;background:var(--panel2);border:1px solid var(--line);color:#fff;font-size:30px;font-weight:700;display:grid;place-items:center;cursor:pointer}
.cv-arrow:disabled{opacity:.3}
.cv-arrow:active:not(:disabled){background:var(--accent)}
@keyframes cardreveal{0%{transform:scale(.3) rotate(-12deg);opacity:0}100%{transform:scale(1) rotate(0);opacity:1}}
.cardupload{max-width:200px;min-height:130px;margin:0 auto 16px;border:2px dashed var(--line);border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--bg2);overflow:hidden;cursor:pointer;text-align:center;font-size:40px;color:var(--mut)}
.cardupload img{display:block;width:100%;height:auto;max-height:55vh;object-fit:contain}
.cardupload.drag{border-color:var(--accent);background:var(--panel2)}
.cardupload>*{pointer-events:none}
/* Battle arena */
.statline{display:block;font-size:11px;color:var(--mut);margin-top:3px;letter-spacing:.3px}
.minicard{display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--bg2);border:2px solid var(--rarc,var(--line));border-radius:12px;padding:10px;text-align:center;margin-top:8px}
.minicard .mc-img{width:84px;height:112px;border-radius:8px;overflow:hidden;background:#15112f;display:grid;place-items:center;font-size:32px}
.minicard .mc-img img{width:100%;height:100%;object-fit:contain}
.minicard .mc-nm{font-weight:700;font-size:13px;line-height:1.2}
.pickrow{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px}
.pickcard{flex:0 0 auto;width:100px;background:var(--bg2);border:2px solid var(--line);border-radius:12px;padding:8px;text-align:center;cursor:pointer}
.pickcard.on{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.pickcard .mc-img{width:100%;aspect-ratio:3/4;border-radius:8px;overflow:hidden;background:#15112f;display:grid;place-items:center;font-size:28px;margin-bottom:4px}
.pickcard .mc-img img{width:100%;height:100%;object-fit:contain}
.pickcard .mc-nm{font-size:11px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pickcard .statline{font-size:9px;margin-top:2px}
.fight{display:flex;align-items:flex-start;gap:8px;justify-content:center;margin-bottom:12px}
.fight .fighter{flex:1;min-width:0}
.fight .vs{font-weight:800;color:var(--gold);font-size:14px;align-self:center}
.hpbar{height:8px;border-radius:5px;background:#15112f;overflow:hidden;margin-top:6px}
.hpbar > i{display:block;height:100%;background:linear-gradient(90deg,#34d399,#10b981);width:100%;transition:width .45s}
.fightfeed{max-height:180px;overflow-y:auto;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:10px;font-size:13px;display:flex;flex-direction:column;gap:5px;line-height:1.35}
.winnerbanner{background:var(--panel2);border:1px solid var(--gold);color:var(--gold);font-weight:800;padding:10px;border-radius:12px;font-size:15px;animation:pop .5s ease}
/* Workout Showdown */
.showdown{display:flex;align-items:flex-start;gap:10px;justify-content:center;margin-bottom:12px}
.showdown .sd-fighter{flex:1;min-width:0;text-align:center;transition:opacity .3s,filter .3s,transform .3s}
.showdown .fcard{max-width:128px;margin:0 auto}
.sd-fighter.dim{opacity:.42;filter:grayscale(.85)}
.sd-fighter.active{transform:translateY(-3px)}
.sd-fighter.active .fcard{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold),0 10px 26px rgba(255,206,77,.4)}
.sd-stat{display:block;font-size:10px;color:var(--gold);font-weight:700;margin-top:2px}
.statkey{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.statkey span{background:rgba(255,255,255,.08);border:1px solid var(--line);border-radius:999px;padding:3px 9px;font-size:11px;font-weight:600;color:#fff}
/* Level / XP + battle stats panel (deck builder) */
.lvl-badge{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,#7c5cff,#b15cff);color:#fff;border-radius:10px;padding:6px 11px;font-size:12px;font-weight:700;flex-shrink:0}
.lvl-badge b{font-size:16px}
.lvl-badge.sm{padding:2px 8px;font-size:11px;border-radius:8px;vertical-align:middle}
.lvl-badge.sm b{font-size:13px}
/* Card battle game dashboard */
.bdash-top{display:flex;align-items:center;gap:14px}
.lvl-badge.lg{flex-direction:column;gap:0;padding:9px 14px;border-radius:14px;font-size:10px;letter-spacing:1px;line-height:1.1}
.lvl-badge.lg b{font-size:26px}
.bdash-mult{font-size:23px;font-weight:800;color:var(--gold);line-height:1}
.bdash-mult span{font-size:12px;color:#fff;font-weight:600}
.bdash-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:13px}
.bdash-grid > div{background:rgba(0,0,0,.2);border:1px solid var(--line);border-radius:11px;padding:9px 6px;text-align:center}
.bdash-grid b{font-size:16px;display:block}
.bdash-grid span{font-size:10.5px;color:#cdb8ff}
.bdash-how{margin-top:12px;background:rgba(0,0,0,.2);border:1px solid var(--line);border-radius:11px;padding:11px 13px}
.bdash-how-t{font-size:12px;margin-bottom:8px;line-height:1.35}
.bdash-how-row{display:flex;justify-content:space-between;font-size:12.5px;padding:3px 0;color:#cdb8ff}
.bdash-how-row b{color:var(--gold);font-weight:700}
.bstats{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:13px;margin-bottom:14px}
.bstats-top{display:flex;align-items:center;gap:12px}
.xpbar{height:8px;border-radius:5px;background:#15112f;overflow:hidden}
.xpbar > i{display:block;height:100%;background:linear-gradient(90deg,#7c5cff,#ffce4d);border-radius:5px;transition:width .5s}
.bstats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.bstats-grid > div{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:9px 6px;text-align:center}
.bstats-grid b{font-size:16px;display:block}
.bstats-grid span{font-size:10.5px;color:var(--dim)}
.sd-name{font-weight:700;font-size:13px;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sd-vs{align-self:center;text-align:center;min-width:72px;flex-shrink:0}
.sd-score{font-weight:800;color:var(--gold);font-size:22px;letter-spacing:1px}
.sd-event{font-size:11px;color:var(--dim);margin-top:6px;min-height:30px;display:flex;align-items:center;justify-content:center;text-align:center;font-weight:700;line-height:1.2}
.sd-event.flash{animation:pop .4s ease}
.sd-pips{display:flex;gap:5px;justify-content:center;margin-top:8px;min-height:11px}
.sd-pip{width:10px;height:10px;border-radius:50%;background:var(--line);transition:background .3s}
.sd-pip.won{background:var(--gold);box-shadow:0 0 8px rgba(255,206,77,.6)}
.fightfeed .feed-event{color:var(--gold);font-weight:700;border-top:1px solid var(--line);margin-top:4px;padding-top:8px}
.fightfeed .feed-a{color:#cdb8ff}
.fightfeed .feed-b{color:#7fd0ff}
.fightfeed .feed-round{font-weight:700;color:#fff}

/* Treasure hunt */
.geo-banner{background:linear-gradient(135deg,#1d3a4d,#15324a);border:1px solid #2a5a7a;border-radius:14px;padding:14px;margin-bottom:14px;text-align:center}
.tre{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:14px;margin-bottom:12px}
.tre.found{opacity:.72;border-color:var(--green)}
.tre .t-top{display:flex;align-items:center;gap:12px}
.tre .te{font-size:30px;width:44px;height:44px;display:grid;place-items:center;background:var(--bg2);border-radius:12px}
.tre .ti{flex:1;min-width:0}
.tre .ti b{font-size:15px}
.tre .ti .hint{color:var(--mut);font-size:13px;margin-top:1px}
.tre .tp{color:var(--gold);font-weight:800;white-space:nowrap}
.distbar{height:8px;border-radius:6px;background:#15112f;margin-top:12px;overflow:hidden;position:relative}
.distbar > i{display:block;height:100%;border-radius:6px;transition:width .5s,background .5s}
.dist-lbl{display:flex;justify-content:space-between;font-size:11.5px;color:var(--dim);margin-top:6px}
/* cartoon hunt map */
.huntmap-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:10px;margin-bottom:14px}
.huntmap{width:100%;height:calc(100vh - 200px);height:calc(100dvh - 200px);min-height:360px;display:block;border-radius:16px;overflow:hidden;background:#a8d8a0}
.hunt-status{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.hunt-stats{display:flex;gap:8px;margin-bottom:10px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.hstat{flex:1;min-width:0;white-space:nowrap;text-align:center;background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:7px 6px;font-size:12px;color:var(--mut)}
.hstat b{color:#fff;font-size:14px}
.hstat.car{background:rgba(255,90,90,.16);border-color:var(--red);color:#ffb3b3}
.hstat.car b{color:#ff6b6b}
.carbanner{background:rgba(255,90,90,.14);border:1px solid var(--red);color:#ffb3b3;border-radius:12px;padding:10px 12px;font-size:12.5px;margin-bottom:10px;text-align:center}
.huntmap-wrap.carmode .huntmap{filter:grayscale(1) brightness(.7);pointer-events:none}
.carlock{position:absolute;left:50%;top:14px;transform:translateX(-50%);z-index:1000;background:rgba(20,16,46,.92);color:#fff;border:1px solid var(--red);border-radius:20px;padding:7px 14px;font-size:13px;font-weight:700;pointer-events:none;box-shadow:0 4px 14px rgba(0,0,0,.4)}
.huntmap-hint{text-align:center;color:var(--dim);font-size:12px;margin-top:8px}
/* isolate Leaflet's internal z-index stack (panes ~400, controls ~1000) so the card-reveal
   sheet/scrim and app chrome render ABOVE the map instead of being buried under it */
.huntmap-wrap{position:relative;isolation:isolate}
.map-recenter{position:absolute;right:14px;bottom:14px;z-index:1000;width:46px;height:46px;border-radius:50%;background:#fff;color:#2e7d4f;border:2px solid #2e7d4f;font-size:20px;box-shadow:0 3px 10px rgba(0,0,0,.4);display:grid;place-items:center;cursor:pointer}
.map-recenter:active{transform:scale(.92)}
.pm .avimg{width:30px;height:30px;border-radius:50%;border:2px solid #fff;object-fit:cover;z-index:2}
.avimg{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.avupload{width:120px;height:120px;border-radius:50%;overflow:hidden;border:2px dashed var(--line);background:var(--bg2);margin:0 auto 10px;cursor:pointer;display:grid;place-items:center;font-size:34px;color:var(--mut)}
.avupload>*{pointer-events:none}
.avupload img,#avPreview{width:100%;height:100%;object-fit:cover}
.heroupload{display:grid;place-items:center;width:120px;height:120px;border-radius:50%;overflow:hidden;border:2px dashed var(--line);background:var(--bg2);margin:0 auto 8px;cursor:pointer;font-size:34px;color:var(--mut);text-align:center}
.heroupload>*{pointer-events:none}
.heroupload img{width:100%;height:100%;object-fit:cover}
.prof-av{width:112px;height:112px;border-radius:50%;overflow:hidden;border:3px solid var(--accent);margin:4px auto 0;display:grid;place-items:center;background:var(--panel2);font-size:54px;line-height:1}
.prof-av img{width:100%;height:100%;object-fit:cover}
.profgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:10px;text-align:center}
.profgrid>div{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:10px 4px}
.profgrid b{display:block;font-size:16px}
.profgrid span{font-size:11px;color:var(--mut)}
.revealgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.revealcard{opacity:0;transform:translateY(12px) scale(.85);animation:revealpop .55s cubic-bezier(.2,.9,.3,1.4) forwards;background:var(--bg2);border:2px solid var(--rarc,var(--line));border-radius:12px;padding:8px;overflow:hidden}
@keyframes revealpop{to{opacity:1;transform:none}}
.rc-img{aspect-ratio:1;display:grid;place-items:center;font-size:26px;overflow:hidden;border-radius:8px;background:var(--panel)}
.rc-img img{width:100%;height:100%;object-fit:cover}
.rc-nm{font-size:11px;font-weight:700;margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mailbtn{position:relative;width:38px;height:38px;border-radius:12px;background:var(--panel2);border:1px solid var(--line);display:grid;place-items:center;font-size:18px;flex-shrink:0;cursor:pointer}
.mailbadge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--red);color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center}
.inbox{display:flex;flex-direction:column;gap:10px}
.msg{display:flex;gap:10px;align-items:flex-start;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:12px;position:relative}
.msg.unread{border-color:var(--accent);background:var(--panel)}
.msg-ic{font-size:22px;flex-shrink:0;line-height:1.2}
.msg-bd{flex:1;min-width:0}
.msg-x{background:none;border:none;color:var(--mut);font-size:20px;line-height:1;cursor:pointer;padding:0 2px;flex-shrink:0}
.hiddencard{text-align:center;background:var(--bg2);border:2px dashed var(--line);border-radius:12px;padding:16px;color:var(--mut);font-size:13px;margin-bottom:14px;letter-spacing:.3px}
.decktile{position:relative;background:var(--bg2);border:2px solid var(--rarc,var(--line));border-radius:12px;overflow:hidden;cursor:pointer;opacity:.5;transition:opacity .15s}
.decktile.on{opacity:1;box-shadow:0 0 0 2px var(--accent) inset}
.decktile .dt-check{position:absolute;top:5px;right:5px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:none;place-items:center;font-size:13px;font-weight:800}
.decktile.on .dt-check{display:grid}
.decktile .cardx-img{position:relative}
.dt-zoom{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.55);color:#fff;font-size:14px;display:grid;place-items:center;cursor:zoom-in;z-index:3}
.dt-stats{font-size:10.5px;color:var(--mut);text-align:center;padding:0 4px 7px;white-space:nowrap;letter-spacing:-.3px}
.deckgrid{grid-template-columns:repeat(auto-fill,minmax(108px,1fr))}
.chart{display:flex;align-items:flex-end;gap:3px;height:130px;padding:6px 2px 0;background:var(--bg2);border:1px solid var(--line);border-radius:12px;margin-bottom:6px}
.cbar{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;height:100%;gap:3px}
.cbar i{width:100%;max-width:24px;min-height:3px;background:linear-gradient(#7c5cff,#b15cff);border-radius:4px 4px 0 0;transition:height .4s}
.cbar small{font-size:9px;color:var(--mut);white-space:nowrap;line-height:1}
.cbar .cbv{font-size:8.5px;color:#cdb8ff;line-height:1;height:9px}
.fcard{width:100%;aspect-ratio:5/9;border:2px solid var(--rarc,var(--line));border-radius:12px;overflow:hidden;background:#15112f;cursor:zoom-in;display:grid;place-items:center}
.fcard img{width:100%;height:100%;object-fit:contain;display:block}
.fcard-ph{font-size:42px}
.cardfull{position:fixed;inset:0;z-index:130;background:rgba(0,0,0,.88);display:none;align-items:center;justify-content:center;padding:16px;cursor:zoom-out}
.cardfull.open{display:flex}
.cardfull img{max-width:100%;max-height:92vh;border-radius:14px;box-shadow:0 16px 50px rgba(0,0,0,.7)}
.cardfull-x{position:absolute;top:14px;right:18px;color:#fff;font-size:28px;font-weight:700}
/* Card gallery carousel */
.cgal{position:fixed;inset:0;z-index:135;background:rgba(8,6,22,.96);display:none;flex-direction:column;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.cgal.open{display:flex;animation:fadein .25s ease}
.cgal-top{display:flex;align-items:center;justify-content:space-between;padding:calc(env(safe-area-inset-top,0px) + 12px) 18px 8px}
.cgal-count{color:#cfd2e6;font-weight:800;font-size:14px;letter-spacing:.5px}
.cgal-x{background:rgba(255,255,255,.12);color:#fff;border-radius:999px;width:38px;height:38px;font-size:19px;font-weight:700;display:grid;place-items:center}
.cgal-viewport{flex:1;overflow:hidden;position:relative;touch-action:pan-y}
.cgal-track{display:flex;height:100%;will-change:transform}
.cgal-slide{min-width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:8px 20px 28px;box-sizing:border-box}
.cgal-card{max-width:min(440px,86vw);border-radius:18px;overflow:hidden;border:3px solid var(--rarc,var(--line));background:#15112f;display:grid;place-items:center;box-shadow:0 18px 60px rgba(0,0,0,.6),0 0 34px -8px var(--rarc,transparent)}
.cgal-card img{display:block;width:100%;height:auto;max-height:62vh;object-fit:contain}
.cgal-card .cardx-lock{opacity:.6;padding:40px}
.cgal-meta{text-align:center;color:#fff}
.cgal-meta b{font-size:18px}
.cgal-nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:999px;background:rgba(255,255,255,.1);color:#fff;font-size:30px;line-height:0;display:grid;place-items:center;z-index:2}
.cgal-nav.prev{left:10px}
.cgal-nav.next{right:10px}
@media(min-width:760px){.cgal-nav{width:54px;height:54px;font-size:34px}}
.pull-overlay{position:fixed;inset:0;z-index:140;background:rgba(8,6,24,.93);display:none;align-items:center;justify-content:center;padding:20px}
.pull-overlay.open{display:flex;animation:fadein .3s ease}
@keyframes fadein{from{opacity:0}}
.pull-wrap{text-align:center;max-width:320px}
.pull-cap{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);font-weight:800;margin-bottom:18px;animation:fadein .6s ease}
.pull-card{width:210px;height:294px;margin:0 auto;perspective:1100px;animation:pullbob 1.1s ease-in-out infinite}
.pull-card.flip{animation:none}
.pull-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .75s cubic-bezier(.2,.8,.25,1.2)}
.pull-card.flip .pull-inner{transform:rotateY(180deg)}
.pull-back,.pull-front{position:absolute;inset:0;border-radius:16px;overflow:hidden;backface-visibility:hidden;-webkit-backface-visibility:hidden;border:3px solid var(--rarc,var(--line));display:grid;place-items:center;background:#15112f}
.pull-back{background:linear-gradient(135deg,#2a2070,#3a2585);font-size:64px;box-shadow:0 0 36px var(--rarc,#7c5cff),inset 0 0 30px rgba(0,0,0,.4)}
.pull-front{transform:rotateY(180deg)}
.pull-front img{width:100%;height:100%;object-fit:cover}
.pull-info{margin-top:18px;opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s}
.pull-info.show{opacity:1;transform:none}
@keyframes pullbob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.resetdial{position:relative;width:66px;height:66px;flex-shrink:0}
.resetdial .rd-lbl{position:absolute;inset:0;display:grid;place-content:center;text-align:center;line-height:1.05}
.resetdial .rd-lbl b{font-size:12px;color:#fff;display:block}
.resetdial .rd-lbl small{font-size:8px;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.5px}
@media(min-width:900px){ .huntmap{height:calc(100vh - 150px);height:calc(100dvh - 150px)} }
/* Leaflet / Pokémon-Go style map */
.leaflet-container{background:#a8d8a0;font:inherit}
.huntmap .leaflet-tile-pane{filter:saturate(1.18) brightness(1.02)}
.leaflet-control-attribution{font-size:9px;background:rgba(255,255,255,.65)}
.leaflet-bar a{background:var(--panel2);color:#fff;border-color:var(--line)}
.leaflet-bar a:hover{background:var(--accent)}
.pm{position:relative;width:40px;height:40px;display:grid;place-items:center}
.pm-av{font-size:24px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.55));z-index:2}
.pm-pulse{position:absolute;width:36px;height:36px;border-radius:50%;background:rgba(124,92,255,.35);border:2px solid #7c5cff;animation:pmp 2s ease-out infinite}
@keyframes pmp{0%{transform:scale(.5);opacity:.9}100%{transform:scale(1.6);opacity:0}}
/* treasure = a mystery "?" card on the map (rarity hints quality via the border) */
.tm{width:32px;height:42px;border-radius:7px;display:grid;place-items:center;font-size:21px;font-weight:800;color:#fff;background:linear-gradient(160deg,#4a3ca6,#241c54);border:2.5px solid var(--rarc,#9aa3b2);box-shadow:0 3px 8px rgba(0,0,0,.5);text-shadow:0 1px 3px rgba(0,0,0,.6)}
.tm.rar-legendary{animation:tmleg 1.2s ease-in-out infinite}
@keyframes tmleg{50%{box-shadow:0 0 14px 3px #ffce4d}}
.tm.found{width:34px;height:34px;border-radius:50%;background:#bfe6cf;border:2.5px solid #2e7d4f;color:#13351f;font-size:18px}
#huntPins g{transition:transform .6s cubic-bezier(.2,.8,.2,1);cursor:pointer}
#huntPins .pin-bg{fill:#fff5d6;stroke:#b8860b;stroke-width:1.5}
#huntPins .pin-lb{fill:#fff;paint-order:stroke;stroke:#16432b;stroke-width:2px;font-weight:700}
#huntPins .within .pin-bg{fill:#fff;stroke:#ffce4d;stroke-width:2.5;animation:pinpulse 1.1s ease-in-out infinite}
@keyframes pinpulse{0%,100%{stroke-width:2.5px}50%{stroke-width:5.5px}}
#huntPins .found{opacity:.5}
#huntPins .found .pin-bg{fill:#bfe6cf;stroke:#2e7d4f}
.tre.flash{animation:cardflash 1.2s ease}
@keyframes cardflash{0%,100%{box-shadow:none}30%{box-shadow:0 0 0 2px var(--gold)}}
#huntPins .rar-common .pin-bg{fill:#fff5d6;stroke:#b8860b}
#huntPins .rar-rare .pin-bg{fill:#dff4ff;stroke:#1f8fbf}
#huntPins .rar-epic .pin-bg{fill:#f2e0ff;stroke:#8a3fd1}
#huntPins .rar-legendary .pin-bg{fill:#fff3c4;stroke:#e0a400;stroke-width:2.5}
#huntPins .within .pin-bg{fill:#fff;stroke:#ffce4d;stroke-width:2.5;animation:pinpulse 1.1s ease-in-out infinite}
#huntPins .found{opacity:.5}
#huntPins .found .pin-bg{fill:#bfe6cf;stroke:#2e7d4f}
.rchip{font-size:9px;text-transform:uppercase;letter-spacing:.4px;font-weight:800;padding:2px 6px;border-radius:6px;vertical-align:middle}
.rchip.rar-common{background:rgba(154,163,178,.2);color:#c7cdd6}
.rchip.rar-uncommon{background:rgba(95,208,107,.16);color:var(--uncommon)}
.rchip.rar-rare{background:rgba(61,215,255,.16);color:var(--rare)}
.rchip.rar-epic{background:rgba(177,92,255,.18);color:var(--epic)}
.rchip.rar-legendary{background:rgba(255,206,77,.18);color:var(--legendary)}

/* Sheets / modals */
.scrim{position:fixed;inset:0;background:rgba(8,6,22,.66);backdrop-filter:blur(3px);z-index:60;opacity:0;pointer-events:none;transition:.2s}
.scrim.open{opacity:1;pointer-events:auto}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:71;background:var(--panel);border-radius:24px 24px 0 0;border-top:1px solid var(--line);padding:20px 18px calc(20px + env(safe-area-inset-bottom));transform:translateY(110%);transition:transform .28s cubic-bezier(.2,.8,.2,1);max-height:90vh;overflow-y:auto;pointer-events:none}
.sheet.open{transform:translateY(0);pointer-events:auto}
.sheet .grab{width:42px;height:4px;border-radius:3px;background:var(--line);margin:0 auto 16px}
.sheet h3{margin:0 0 16px;font-size:18px}
.emoji-pick{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.emoji-pick button{width:42px;height:42px;border-radius:11px;background:var(--bg2);border:1px solid var(--line);font-size:22px}
.emoji-pick button.on{border-color:var(--accent);background:var(--panel2)}
.seg{display:flex;background:var(--bg2);border-radius:11px;padding:4px;border:1px solid var(--line)}
.seg button{flex:1;padding:9px;border-radius:8px;color:var(--mut);font-weight:600;font-size:13px}
.seg button.on{background:var(--grad);color:#fff}
.toast{position:fixed;left:50%;bottom:calc(100px + env(safe-area-inset-bottom));transform:translateX(-50%) translateY(20px);background:#2d2766;border:1px solid var(--line);color:#fff;padding:12px 18px;border-radius:14px;font-size:14px;font-weight:600;z-index:95;opacity:0;transition:.3s;box-shadow:0 14px 36px rgba(0,0,0,.5);max-width:90vw;text-align:center;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#fx{position:fixed;inset:0;pointer-events:none;z-index:88}

/* Admin */
.admin-tabs{display:flex;gap:8px;margin-bottom:16px}
.admin-tabs button{flex:1;padding:9px 4px;border-radius:11px;background:var(--bg2);border:1px solid var(--line);color:var(--mut);font-weight:700;font-size:12.5px;cursor:pointer;white-space:nowrap}
.admin-tabs button.on{background:var(--grad);color:#fff}
.adm-row{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:11px 13px;margin-bottom:9px;display:flex;align-items:center;gap:11px}
.adm-row .em{font-size:24px}
.adm-row .ai{flex:1;min-width:0}
.adm-row .ai b{font-size:14px}
.adm-row .ai small{color:var(--dim);font-size:11.5px;display:block}
.reorder{display:flex;flex-direction:column;gap:3px;flex-shrink:0}
.reorder button{width:30px;height:21px;border-radius:6px;background:var(--panel2);border:1px solid var(--line);color:var(--mut);font-size:10px;line-height:1;display:grid;place-items:center}
.reorder button:disabled{opacity:.3}
.reorder button:active:not(:disabled){background:var(--accent);color:#fff}
.linkbox{display:flex;gap:8px;align-items:center;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:6px 6px 6px 14px;margin-top:8px}
.linkbox code{flex:1;font-size:15px;letter-spacing:2px;font-weight:800;color:var(--gold);overflow:hidden}

/* Desktop */
@media(min-width:900px){
  .sidebar{display:flex}
  .bottomnav{display:none}
  .topbar .tb-av{display:none}
  .main{margin-left:var(--sb);padding-bottom:24px}
  .fab{right:auto;left:calc(var(--sb) + 36px);bottom:32px}
  .content{padding:24px 28px}
  .sheet{left:50%;right:auto;bottom:auto;top:50%;transform:translate(-50%,-46%) scale(.96);width:460px;max-width:92vw;border-radius:22px;border:1px solid var(--line);opacity:0}
  .sheet.open{transform:translate(-50%,-50%) scale(1);opacity:1}
  .sheet .grab{display:none}
  .badge-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}
}
@media(min-width:1200px){ .content{max-width:920px} }
