/* ════════════════════════════════════════════════════════════════════
   arcade.css — Gold economy, home hub, dungeon, shop, leaderboard, card
   skins. Loaded LAST (after profile.css) so skin/frame rules win the
   cascade. Neon Helo skin; reuses existing CSS vars.
   ════════════════════════════════════════════════════════════════════ */
:root { --ag: #ffd23f; --cy: #28e0ff; }

/* ── two-currency top bar ── */
.nav-wallet .sa-bal { font-family: var(--f-mono); font-size: 13px; color: var(--text2); white-space: nowrap; }
.nav-wallet .sa-bal.ag b { color: var(--ag); }
.nav-wallet .sa-bal.sol b { color: var(--cy); }

/* ── HOME HUB ── */
.sa-home { max-width: 940px; margin: 0 auto; padding: 22px 16px 60px; }
.sa-hero {
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
  background: linear-gradient(120deg, rgba(40,224,255,.08), rgba(17,17,32,.5) 60%);
  border: 1px solid rgba(255,255,255,.08); border-radius: 18px; padding: 24px 26px; margin-bottom: 18px;
}
.sa-hero .sa-welcome { font: 800 30px var(--f-display); letter-spacing: .04em; margin: 0; }
.sa-hero .sa-welcome-sub { color: var(--text2); font-size: 13px; margin-top: 6px; }
.sa-streak { text-align: center; min-width: 92px; }
.sa-streak-num { font: 800 40px var(--f-display); color: var(--ag); line-height: 1; text-shadow: 0 0 18px rgba(255,210,63,.35); }
.sa-streak-lbl { font: 600 10px var(--f-body); letter-spacing: .12em; text-transform: uppercase; color: var(--text3); margin-top: 6px; }

.sa-quicknav { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; }
.sa-qbtn {
  background: var(--card); border: 1px solid var(--border2); color: var(--text2);
  border-radius: 12px; padding: 9px 18px; cursor: pointer;
  font: 600 13px var(--f-body); transition: all .15s; display: inline-flex; gap: 7px; align-items: center;
}
.sa-qbtn:hover { border-color: var(--cy); color: #fff; }

.sa-statcards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 18px; }
.sa-statcard { background: rgba(17,17,32,.6); border: 1px solid rgba(255,255,255,.08); border-radius: 14px; padding: 18px 14px; text-align: center; }
.sa-statcard .v { font: 800 26px var(--f-display); line-height: 1; }
.sa-statcard .l { font: 500 10px var(--f-body); letter-spacing: .1em; text-transform: uppercase; color: var(--text3); margin-top: 8px; }
.sa-statcard.ag .v { color: var(--ag); }
.sa-statcard.wins .v { color: var(--cy); }
.sa-statcard.rank .v { color: var(--gold); font-size: 22px; }
.sa-statcard.cards .v { color: #fff; }

.sa-hub { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: start; }
.sa-actions { display: flex; flex-direction: column; gap: 16px; }
.sa-action {
  background: rgba(17,17,32,.62); border: 1px solid rgba(255,255,255,.08); border-radius: 16px;
  padding: 26px 22px; text-align: center; transition: border-color .15s, transform .15s;
}
.sa-action:hover { transform: translateY(-2px); }
.sa-action.pvp:hover { border-color: var(--cy); }
.sa-action.pve:hover { border-color: var(--green); }
.sa-action-ico { margin-bottom: 10px; display: flex; justify-content: center; }
.sa-action-ico svg { width: 46px; height: 46px; }
.sa-action.pvp .sa-action-ico { color: #cfd6f5; }
.sa-action.pve .sa-action-ico { color: var(--green); }
.sa-action h3 { font: 700 17px var(--f-display); letter-spacing: .06em; margin-bottom: 8px; }
.sa-action p { font-size: 12.5px; color: var(--text2); line-height: 1.5; margin-bottom: 16px; }
.sa-action .pvp-btn { width: auto; }

/* daily bounties panel */
.bounty-panel { background: rgba(17,17,32,.62); border: 1px solid rgba(255,255,255,.08); border-radius: 16px; padding: 18px 18px 20px; }
.bounty-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; font: 700 13px var(--f-display); letter-spacing: .12em; text-transform: uppercase; }
.bounty-badge { font: 600 10px var(--f-mono); color: var(--text3); border: 1px solid var(--border2); border-radius: 8px; padding: 3px 9px; letter-spacing: .06em; }
.bounty-badge.all { color: var(--green); border-color: rgba(20,241,149,.4); background: rgba(20,241,149,.08); }
.bounty-locked { color: var(--text3); font-size: 13px; padding: 14px 0; }
.bounty { display: flex; align-items: center; gap: 12px; padding: 11px 0; border-top: 1px solid rgba(255,255,255,.06); }
.bounty:first-of-type { border-top: none; }
.bounty.is-done { opacity: .6; }
.bounty-svg.i-atk { color: #ff6b6b; } .bounty-svg.i-def { color: #4da6ff; } .bounty-svg.i-heal { color: var(--green); }
.bounty-mid { flex: 1; min-width: 0; }
.bounty-name { font: 600 13px var(--f-body); color: #fff; }
.bounty-desc { font-size: 11px; color: var(--text3); margin: 2px 0 5px; }
.bounty-bar { height: 4px; background: rgba(255,255,255,.08); border-radius: 3px; overflow: hidden; }
.bounty-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--cy), var(--green)); border-radius: 3px; }
.bounty-amt { font: 700 11px var(--f-mono); color: var(--text3); white-space: nowrap; }
.bounty-ok { color: var(--green); font-weight: 800; font-size: 16px; }
.bounty-claim {
  background: linear-gradient(135deg, var(--ag), #ffae00); border: none; color: #2a1c00; cursor: pointer;
  font: 700 11px var(--f-body); border-radius: 9px; padding: 7px 12px; white-space: nowrap;
  box-shadow: 0 3px 14px rgba(255,210,63,.3); animation: bountyPulse 1.6s ease-in-out infinite;
}
@keyframes bountyPulse { 0%,100% { box-shadow: 0 3px 14px rgba(255,210,63,.25); } 50% { box-shadow: 0 3px 20px rgba(255,210,63,.5); } }
.bounty-claim:hover { filter: brightness(1.08); }

.sa-recent-title { font: 700 12px var(--f-display); letter-spacing: .12em; text-transform: uppercase; color: var(--text3); margin: 26px 0 12px; }

/* ── PvE DUNGEON ── */
.dg { max-width: 760px; margin: 0 auto; padding: 16px 16px 50px; }
.dg-card { background: rgba(17,17,32,.62); border: 1px solid rgba(255,255,255,.08); border-radius: 18px; padding: 30px 26px; text-align: center; }
.dg-leaf { font-size: 40px; margin-bottom: 10px; }
.dg-card h2 { font: 800 24px var(--f-display); letter-spacing: .06em; }
.dg-sub { color: var(--text2); font-size: 13px; margin: 8px 0 22px; }
.dg-diffs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; max-width: 460px; margin: 0 auto 24px; }
.dg-diff { background: #0b0e18; border: 1px solid var(--border2); border-radius: 12px; padding: 14px 8px; cursor: pointer; display: flex; flex-direction: column; gap: 5px; transition: all .15s; }
.dg-diff b { font: 700 13px var(--f-display); letter-spacing: .06em; color: var(--text); }
.dg-diff span { font: 600 11px var(--f-mono); color: var(--ag); }
.dg-diff:hover { border-color: var(--green); }
.dg-diff.on { border-color: var(--green); background: rgba(20,241,149,.08); box-shadow: 0 0 14px rgba(20,241,149,.2); }
.dg-handlabel { font: 600 10px var(--f-body); letter-spacing: .14em; text-transform: uppercase; color: var(--text3); margin-bottom: 10px; }
.dg-hand { margin-bottom: 22px; }
.dg-cta .pvp-btn { width: auto; min-width: 200px; }
.dg-note { font-size: 11px; color: var(--text3); margin-top: 16px; }

/* ── SHOP ── */
.shop { max-width: 920px; margin: 0 auto; padding: 18px 16px 60px; }
.shop-head { display: flex; align-items: center; gap: 16px; margin-bottom: 22px; flex-wrap: wrap; }
.shop-head h2 { font: 800 24px var(--f-display); letter-spacing: .06em; }
.shop-sub { color: var(--text2); font-size: 13px; margin-top: 4px; }
.shop-bal { margin-left: auto; font: 700 16px var(--f-mono); color: var(--text2); }
.shop-bal b { color: var(--ag); }
.shop-empty { text-align: center; color: var(--text2); padding: 60px 0; }
.shop-sec-h { font: 700 13px var(--f-display); letter-spacing: .14em; text-transform: uppercase; color: #fff; margin: 18px 0 14px; padding-left: 12px; position: relative; }
.shop-sec-h::before { content: ''; position: absolute; left: 0; top: 1px; bottom: 1px; width: 3px; border-radius: 2px; background: var(--cy); box-shadow: 0 0 8px var(--cy); }
.shop-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; margin-bottom: 14px; }
.shop-item { background: rgba(17,17,32,.6); border: 1px solid rgba(255,255,255,.08); border-radius: 14px; padding: 16px 14px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 8px; }
.shop-item.owned { border-color: rgba(40,224,255,.3); }
.shop-item.eq { border-color: var(--cy); box-shadow: 0 0 14px rgba(40,224,255,.2); }
.shop-item-title { font: 700 13px var(--f-body); color: #fff; }
.shop-item-tag { font: 500 9px var(--f-body); letter-spacing: .1em; text-transform: uppercase; color: var(--text3); }
.shop-btn { background: linear-gradient(135deg, var(--ag), #ffae00); border: none; color: #2a1c00; cursor: pointer; font: 700 12px var(--f-body); border-radius: 10px; padding: 8px 16px; margin-top: 2px; }
.shop-btn:hover { filter: brightness(1.08); }
.shop-btn.ghost { background: transparent; border: 1px solid var(--cy); color: var(--cy); }
.shop-eq { font: 700 11px var(--f-body); color: var(--cy); letter-spacing: .04em; padding: 8px 0 2px; }
.shop-skin-prev { display: flex; gap: 8px; align-items: center; justify-content: center; height: 64px; }
.shop-skin-prev .gb-card { width: 44px; min-height: 56px; flex: 0 0 44px; padding: 6px 2px; }
.shop-skin-prev .ssk-face { display: block; width: 18px; height: 18px; margin: 8px auto; border-radius: 4px; background: rgba(255,255,255,.25); }
.shop-skin-prev .bt-back { width: 40px; height: 56px; }
.shop-disclaimer { font-size: 11px; color: var(--text3); margin-top: 18px; line-height: 1.5; border-top: 1px solid var(--border); padding-top: 14px; }

/* ── LEADERBOARD (multi-sort) ── */
.lb2 { max-width: 920px; margin: 0 auto; padding: 18px 16px 60px; }
.lb2-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 18px; }
.lb2-head h2 { font: 800 24px var(--f-display); letter-spacing: .06em; }
.lb2-sub { color: var(--text2); font-size: 13px; margin-top: 4px; }
.lb2-tabsrow { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 16px 0; flex-wrap: wrap; }
.lb2-tabs { display: inline-flex; gap: 4px; background: var(--dark2); padding: 4px; border-radius: 12px; }
.lb2-note { font: 600 10px var(--f-body); letter-spacing: .04em; color: var(--text3); border: 1px solid var(--border2); border-radius: 8px; padding: 4px 10px; }
/* clickable Live ⇄ Demo source toggle */
.lb2-source { display: inline-flex; align-items: center; gap: 7px; cursor: pointer; font: 700 10px var(--f-body); letter-spacing: .05em; text-transform: uppercase; color: var(--text3); background: var(--dark2); border: 1px solid var(--border2); border-radius: 8px; padding: 5px 11px; transition: border-color .15s, color .15s; }
.lb2-source:hover { color: var(--text); border-color: var(--cy); }
.lb2-source.on { color: #6ff7c8; border-color: rgba(80,240,180,.4); }
.lb2-source .lb2-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--text3); flex-shrink: 0; }
.lb2-source.on .lb2-dot { background: #45f7b0; box-shadow: 0 0 7px #45f7b0; animation: lbpulse 1.8s ease-in-out infinite; }
@keyframes lbpulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
.lb2-swap { font-style: normal; font-weight: 600; opacity: .7; letter-spacing: .02em; text-transform: none; }
.lb2-empty { text-align: center; font-size: 12px; color: var(--text3); background: rgba(40,224,255,.06); border: 1px dashed rgba(40,224,255,.28); border-radius: 12px; padding: 12px 16px; margin: 0 0 12px; }
.lb-av.me { box-shadow: 0 0 0 2px rgba(40,224,255,.5); }
.lb2-table { display: flex; flex-direction: column; gap: 8px; }
.lb-row2 { display: flex; align-items: center; gap: 12px; background: rgba(17,17,32,.5); border: 1px solid rgba(255,255,255,.06); border-radius: 12px; padding: 12px 16px; }
.lb-row2.me { background: rgba(40,224,255,.08); border-color: rgba(40,224,255,.4); }
.lb-pos { font: 700 14px var(--f-mono); color: var(--text3); min-width: 36px; }
.lb-av { position: relative; width: 34px; height: 34px; border-radius: 50%; background: var(--card2); display: flex; align-items: center; justify-content: center; font: 800 14px var(--f-display); color: var(--text2); flex-shrink: 0; }
.lb-av.sim { opacity: .85; }
/* presence dot (persistent board: green = online now, grey = offline) */
.lb-pres { position: absolute; right: -1px; bottom: -1px; width: 10px; height: 10px; border-radius: 50%; border: 2px solid var(--dark, #08080f); box-sizing: border-box; }
.lb-pres.on { background: #45f7b0; box-shadow: 0 0 6px #45f7b0; }
.lb-pres.off { background: #5a5a70; }
.lb-row2.offline { opacity: .58; }
.lb-row2.offline.me { opacity: 1; }
.lb-who { flex: 1; min-width: 0; }
.lb-nm { font: 700 14px var(--f-body); color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lb-youtag { font-style: normal; font-size: 10px; color: var(--cy); font-weight: 600; }
.lb-tier { font: 700 10px var(--f-mono); letter-spacing: .08em; border: 1px solid; border-radius: 7px; padding: 3px 8px; }
.lb-metric { font: 700 13px var(--f-mono); color: var(--text); min-width: 92px; text-align: right; }
.lb-metric.big { font-size: 18px; }
.lb2-foot { text-align: center; font-size: 11px; color: var(--text3); margin-top: 16px; }

/* ── CARD SKINS (cosmetic only) ──
   Frame skins restyle YOUR cards' border/background/glow. Back skins restyle
   the face-down card the opponent sees. No combat code reads these classes. */
.gb-card.sk-aurora { border-color: #6ad7ff; box-shadow: 0 0 14px rgba(106,215,255,.35); background: linear-gradient(160deg, rgba(106,215,255,.14), rgba(140,90,255,.12)); }
.gb-card.sk-ember  { border-color: #ff8a3d; box-shadow: 0 0 14px rgba(255,138,61,.35); background: linear-gradient(160deg, rgba(255,90,40,.16), rgba(120,20,10,.18)); }
.gb-card.sk-holo   { border-color: #c8a2ff; box-shadow: 0 0 16px rgba(200,162,255,.4); background: linear-gradient(160deg, rgba(40,224,255,.14), rgba(255,107,214,.14) 60%, rgba(255,210,63,.12)); }
.gb-card.sk-void   { border-color: #8b5cf6; box-shadow: 0 0 16px rgba(139,92,246,.4); background: linear-gradient(160deg, rgba(20,10,40,.7), rgba(80,40,160,.25)); }

.bt-back.sk-back-aurora, .fxcard-back.sk-back-aurora { background-image: linear-gradient(135deg, #0a2740, #1b6a9a), repeating-linear-gradient(45deg, rgba(106,215,255,.18) 0 6px, transparent 6px 12px); background-blend-mode: screen; border-color: #6ad7ff66; }
.bt-back.sk-back-ember,  .fxcard-back.sk-back-ember  { background-image: linear-gradient(135deg, #2a0c06, #7c2d12), repeating-linear-gradient(-45deg, rgba(255,138,61,.2) 0 5px, transparent 5px 11px); background-blend-mode: screen; border-color: #ff8a3d66; }
.bt-back.sk-back-holo,   .fxcard-back.sk-back-holo   { background-image: linear-gradient(135deg, #2a0b3a, #0a4a63), conic-gradient(from 0deg, rgba(40,224,255,.25), rgba(255,107,214,.25), rgba(255,210,63,.25), rgba(40,224,255,.25)); background-blend-mode: screen; border-color: #c8a2ff66; }
.bt-back.sk-back-void,   .fxcard-back.sk-back-void   { background-image: radial-gradient(circle at 50% 40%, rgba(139,92,246,.4), transparent 60%), linear-gradient(135deg, #0a0618, #1a0b3a); border-color: #8b5cf666; }

@media (max-width: 720px) {
  .sa-statcards { grid-template-columns: repeat(2, 1fr); }
  .sa-hub { grid-template-columns: 1fr; }
  .sa-hero { flex-direction: column; align-items: flex-start; }
  .dg-diffs { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) { .bounty-claim { animation: none; } }

/* ════════ v3 patch — emoji icons, home polish, new cosmetics, history ════════ */
.ccoin { font-size: 13px; }

/* emoji card icons (replaced the old SVGs everywhere) */
.gb-card-icon { font-size: 30px; line-height: 1; }
.lc-icon { font-size: 18px; line-height: 1; }
.bt-slot-emoji { font-size: 20px; }
.bt-logemoji { font-size: 14px; }
.fxcard-emoji { display: block; font-size: 46px; line-height: 1; filter: drop-shadow(0 2px 6px rgba(0,0,0,.5)); }
.bounty-emoji { flex: 0 0 26px; width: 26px; text-align: center; font-size: 20px; line-height: 1; }

/* home — centered + more visible quick-nav */
.sa-quicknav { justify-content: center; }
.sa-qbtn { background: rgba(40,224,255,.07); border-color: rgba(40,224,255,.35); color: #dfe7ff; font-weight: 600; }
.sa-qbtn:hover { background: rgba(40,224,255,.15); border-color: var(--cy); color: #fff; box-shadow: 0 0 14px rgba(40,224,255,.22); }

/* home — emoji action icon + harmonized card/panel heights */
.sa-action-ico { font-size: 44px; line-height: 1; filter: drop-shadow(0 3px 8px rgba(0,0,0,.5)); }
.sa-hub { align-items: stretch; }
.sa-actions { height: 100%; }
.bounty-panel { height: 100%; }
.sa-action { flex: 1; display: flex; flex-direction: column; justify-content: center; }

/* recent header row + see-all link */
.sa-recent-title-row { display: flex; align-items: center; justify-content: space-between; margin: 26px 0 12px; }
.sa-recent-title-row .sa-recent-title { margin: 0; }
.sa-seeall { background: none; border: none; color: var(--cy); font: 600 12px var(--f-body); cursor: pointer; }
.sa-seeall:hover { text-decoration: underline; }

/* new card skins */
.gb-card.sk-toxic { border-color: #7CFC00; box-shadow: 0 0 14px rgba(124,252,0,.35); background: linear-gradient(160deg, rgba(124,252,0,.14), rgba(20,60,10,.3)); }
.gb-card.sk-frost { border-color: #9fe8ff; box-shadow: 0 0 14px rgba(159,232,255,.4); background: linear-gradient(160deg, rgba(159,232,255,.16), rgba(20,60,90,.25)); }
.gb-card.sk-solar { border-color: #ffd23f; box-shadow: 0 0 16px rgba(255,210,63,.45); background: linear-gradient(160deg, rgba(255,210,63,.18), rgba(120,60,0,.22)); }
.bt-back.sk-back-toxic, .fxcard-back.sk-back-toxic { background-image: linear-gradient(135deg,#0c2a06,#2f7c12), repeating-linear-gradient(45deg, rgba(124,252,0,.18) 0 5px, transparent 5px 11px); background-blend-mode: screen; border-color: #7CFC0066; }
.bt-back.sk-back-frost, .fxcard-back.sk-back-frost { background-image: radial-gradient(circle at 50% 35%, rgba(159,232,255,.4), transparent 60%), linear-gradient(135deg,#06283a,#0a4a63); border-color: #9fe8ff66; }
.bt-back.sk-back-solar, .fxcard-back.sk-back-solar { background-image: radial-gradient(circle at 50% 40%, rgba(255,210,63,.5), transparent 60%), linear-gradient(135deg,#3a2406,#7c5212); border-color: #ffd23f66; }

/* name effects (cosmetic, applied to .bt-name) */
.nf-cyan { color: #28e0ff !important; text-shadow: 0 0 8px rgba(40,224,255,.7); }
.nf-gold { color: #ffd23f !important; text-shadow: 0 0 8px rgba(255,210,63,.7); }
.nf-crimson { color: #ff5577 !important; text-shadow: 0 0 8px rgba(255,85,119,.7); }
.nf-frost { color: #cfefff !important; text-shadow: 0 0 8px rgba(159,232,255,.85); }
.nf-rainbow { background: linear-gradient(90deg,#ff5577,#ffd23f,#22e3a6,#28e0ff,#8b5cf6); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* shop — item previews + price + name fx swatch */
.shop-item-prev { display: flex; gap: 8px; align-items: center; justify-content: center; height: 58px; margin-bottom: 2px; }
.shop-item-prev .gb-card { width: 42px; min-height: 54px; flex: 0 0 42px; padding: 6px 2px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; }
.shop-item-prev .ssk-face { font-size: 18px; }
.shop-item-prev .bt-back { width: 38px; height: 54px; }
.shop-item-prev.tt, .shop-item-prev.nf { height: 44px; }
.shop-item-prev.tt .bt-name { font: 700 12px var(--f-display); background: rgba(0,0,0,.4); border: 1px solid rgba(255,255,255,.16); padding: 3px 10px; border-radius: 8px; color: #e3e9ff; }
.shop-item-prev.nf .bt-name { font: 700 15px var(--f-display); }
.shop-price { display: inline-flex; align-items: center; gap: 4px; }

/* history page */
.hist { max-width: 920px; margin: 0 auto; padding: 18px 16px 60px; }
.hist-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 18px; }
.hist-head h2 { font: 800 24px var(--f-display); letter-spacing: .06em; }
.hist-sub { color: var(--text2); font-size: 13px; margin-top: 4px; }
.hist-summary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 16px; }
.hist-sm { background: rgba(17,17,32,.6); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 14px 10px; text-align: center; }
.hist-sm b { font: 800 20px var(--f-display); }
.hist-sm span { display: block; font: 500 10px var(--f-body); letter-spacing: .08em; text-transform: uppercase; color: var(--text3); margin-top: 6px; }
.hist-tabs { margin-bottom: 14px; }
.hist-table-wrap { background: rgba(17,17,32,.5); border: 1px solid rgba(255,255,255,.07); border-radius: 14px; overflow: hidden; }
.hist-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.hist-table th { text-align: left; font: 600 10px var(--f-body); letter-spacing: .08em; text-transform: uppercase; color: var(--text3); padding: 12px 14px; border-bottom: 1px solid var(--border); }
.hist-table td { padding: 11px 14px; border-bottom: 1px solid rgba(255,255,255,.05); color: var(--text); }
.hist-table tr:last-child td { border-bottom: none; }
.hist-table .right { text-align: right; }
.hist-when { color: var(--text3); font-family: var(--f-mono); font-size: 12px; white-space: nowrap; }
.hist-opp { color: var(--text2); }
.hist-tag { font: 700 10px var(--f-body); padding: 2px 8px; border-radius: 6px; letter-spacing: .04em; }
.hist-tag.win { color: var(--green); background: rgba(20,241,149,.1); border: 1px solid rgba(20,241,149,.35); }
.hist-tag.lose { color: var(--red); background: rgba(255,68,85,.08); border: 1px solid rgba(255,68,85,.3); }
.hist-tag.push { color: var(--text2); border: 1px solid var(--border2); }
.hist-mode { font: 700 10px var(--f-mono); padding: 2px 7px; border-radius: 6px; }
.hist-mode.pvp { color: var(--cy); border: 1px solid rgba(40,224,255,.4); }
.hist-mode.pve { color: var(--green); border: 1px solid rgba(20,241,149,.4); }
.hist-free, .hist-dim { color: var(--text3); font-size: 11px; }
.hist-empty { text-align: center; color: var(--text3); padding: 30px 0; }
@media (max-width: 720px) { .hist-summary { grid-template-columns: repeat(2, 1fr); } .hist-when, .hist-table th:first-child, .hist-table td:first-child { display: none; } }

/* ════════ v4 patch — grouped home stats, wider leaderboard, nav animations ════════ */

/* home — grouped stats (Global / PvP / PvE) */
.sa-statcards { display: grid; grid-template-columns: 1fr 1.45fr 1.3fr; gap: 14px; align-items: stretch; }
.sa-sgroup { background: rgba(17,17,32,.6); border: 1px solid rgba(255,255,255,.08); border-radius: 14px; padding: 14px 14px 16px; }
.sa-sgroup.global { border-color: rgba(255,210,63,.2); }
.sa-sgroup.pvp { border-color: rgba(40,224,255,.2); }
.sa-sgroup.pve { border-color: rgba(20,241,149,.2); }
.sa-sg-title { font: 700 11px var(--f-display); letter-spacing: .14em; text-transform: uppercase; color: var(--text2); margin-bottom: 12px; display: flex; align-items: center; gap: 6px; }
.sa-sg-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.sa-sgroup.pve .sa-sg-cards { grid-template-columns: repeat(3, 1fr); }
.sa-mini { background: #0b0e18; border: 1px solid rgba(255,255,255,.06); border-radius: 10px; padding: 13px 8px; text-align: center; }
.sa-mini-v { font: 800 20px var(--f-display); line-height: 1; color: #fff; white-space: nowrap; }
.sa-mini-l { font: 500 9px var(--f-body); letter-spacing: .08em; text-transform: uppercase; color: var(--text3); margin-top: 8px; }
.sa-mini-tot { color: var(--text3); font-size: 13px; font-weight: 600; }
@media (max-width: 860px) { .sa-statcards { grid-template-columns: 1fr; } }

/* leaderboard — wider + multi-column grid */
.lb2 { max-width: 1080px; }
.lb-row2 { display: grid; grid-template-columns: 48px 32px minmax(76px,1fr) 96px 60px 50px 92px 72px 48px 60px; align-items: center; gap: 10px; }
.lb-headrow { background: transparent !important; border: none !important; padding: 4px 16px 2px; }
.lb-headrow .lb-who, .lb-headrow .lb-tier-h, .lb-headrow .lb-c { font: 600 10px var(--f-body); letter-spacing: .08em; text-transform: uppercase; color: var(--text3); }
.lb-c { text-align: right; font: 700 13px var(--f-mono); color: var(--text2); white-space: nowrap; }
.lb-c.on { color: #fff; }
.lb-row2.me .lb-c.on { color: var(--cy); }
.lb-headrow .lb-c.on { color: var(--cy); }
.lb-tier { justify-self: start; }
.lb-tier-h { text-align: left; }
.lb-medal { font-size: 19px; text-align: center; }
.yr-stats { display: flex; gap: 20px; margin-left: auto; }
.yr-stats span { display: flex; flex-direction: column; align-items: flex-end; font: 600 9px var(--f-body); letter-spacing: .06em; text-transform: uppercase; color: var(--text3); }
.yr-stats b { font: 800 16px var(--f-mono); color: #fff; margin-bottom: 2px; }
@media (max-width: 760px) {
  .lb-row2 { grid-template-columns: 38px 28px minmax(60px,1fr) 78px 56px 46px; gap: 8px; }
  .lb-ag, .lb-played, .lb-bounties, .lb-winrate { display: none; }   /* keep ELO + LVL on narrow screens */
  .yr-stats { display: none; }
}

/* ── navigation / motion polish ── */
@keyframes pageIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.page.active { animation: pageIn .26s cubic-bezier(.22,.7,.3,1) both; }
@keyframes riseIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.sa-sgroup, .sa-action, .bounty-panel, .lb-row2:not(.lb-headrow), .shop-item, .hist-sm { animation: riseIn .3s ease both; }
.sa-sgroup:nth-child(2) { animation-delay: .04s; } .sa-sgroup:nth-child(3) { animation-delay: .08s; }
.sa-action, .sa-statcards, .sa-mini, .lb-row2:not(.lb-headrow), .shop-item, .sa-sgroup, .sa-qbtn, .bounty, .dg-diff, .lb-tab, .deck-back { transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease; }
.lb-row2:not(.lb-headrow):not(.me):hover { border-color: rgba(255,255,255,.16); transform: translateX(3px); }
.shop-item:hover { transform: translateY(-3px); border-color: rgba(40,224,255,.3); }
.sa-mini:hover { border-color: rgba(255,255,255,.16); }
nav .icon-btn, nav .wallet-badge, nav .connect-btn, .bottom-nav button { transition: transform .15s ease, color .15s ease, border-color .15s ease, background .15s ease; }
.bottom-nav button:active { transform: scale(.92); }

/* ════════ v5 patch — victory effects, wider leaderboard, PvP lobby ════════ */

/* victory effects overlay (cosmetic, plays on win) */
#victory-fx { position: fixed; inset: 0; z-index: 450; pointer-events: none; overflow: hidden; }
#victory-fx:not(.show) { display: none; }
.vfx-shockwave .sw { position: absolute; left: 50%; top: 46%; width: 40px; height: 40px; margin: -20px; border-radius: 50%; border: 4px solid var(--cy); transform: scale(0); animation: swExpand 1.1s ease-out forwards; box-shadow: 0 0 30px var(--cy); }
@keyframes swExpand { to { transform: scale(26); opacity: 0; border-width: 1px; } }
.vfx-goldrain .vc { position: absolute; top: -40px; font-size: 26px; animation: vcFall 1.6s linear forwards; }
@keyframes vcFall { to { transform: translateY(112vh) rotate(360deg); opacity: .2; } }
.vfx-fireworks .fw { position: absolute; width: 8px; height: 8px; border-radius: 50%; background: #fff; animation: fwBurst 1s ease-out forwards; }
@keyframes fwBurst { 0% { transform: scale(.4); box-shadow: 0 0 8px 3px #ffd23f; } 100% { transform: scale(1); box-shadow: 34px 0 0 #ff5577, -34px 0 0 #28e0ff, 0 34px 0 #22e3a6, 0 -34px 0 #ffd23f, 24px 24px 0 #8b5cf6, -24px -24px 0 #ff6bd6, 24px -24px 0 #28e0ff, -24px 24px 0 #ffd23f; opacity: 0; } }
.vfx-aurora { background: linear-gradient(120deg, rgba(40,224,255,.18), rgba(139,92,246,.18) 50%, rgba(34,227,166,.18)); animation: auroraSweep 1.6s ease forwards; }
@keyframes auroraSweep { 0% { opacity: 0; } 25% { opacity: 1; } 100% { opacity: 0; } }
.shop-item.fx .shop-item-prev.vfx { font-size: 30px; }
.vfx-emoji { cursor: pointer; transition: transform .15s; }
.vfx-emoji:hover { transform: scale(1.25); }

/* leaderboard — fill the width, breathe between columns */
.lb2 { max-width: 1320px; }
.lb-row2 { grid-template-columns: 58px 40px minmax(120px,1fr) 124px 100px 132px 118px 86px; gap: 28px; padding: 15px 26px; }
.lb-headrow { padding: 4px 26px 2px; }
.lb-medal { font-size: 20px; }
@media (max-width: 900px) {
  .lb-row2 { grid-template-columns: 44px 32px minmax(70px,1fr) 96px 70px; gap: 14px; padding: 12px 14px; }
  .lb-row2 .lb-c:nth-of-type(2), .lb-row2 .lb-c:nth-of-type(3), .lb-headrow .lb-c:nth-of-type(2), .lb-headrow .lb-c:nth-of-type(3) { display: none; }
  .yr-stats { display: none; }
}

/* PvP lobby / room browser */
.lobby { max-width: 1080px; margin: 0 auto; padding: 18px 16px 60px; }
.lobby-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 18px; }
.lobby-head h2 { font: 800 24px var(--f-display); letter-spacing: .06em; }
.lobby-sub { color: var(--text2); font-size: 13px; margin-top: 4px; }
.lobby-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 22px; }
.lobby-cta .pvp-btn { width: auto; min-width: 180px; }
.lobby-sec { display: flex; align-items: center; justify-content: space-between; font: 700 13px var(--f-display); letter-spacing: .12em; text-transform: uppercase; color: #fff; margin: 20px 0 12px; padding-left: 12px; position: relative; }
.lobby-sec::before { content: ''; position: absolute; left: 0; top: 1px; bottom: 1px; width: 3px; border-radius: 2px; background: var(--cy); box-shadow: 0 0 8px var(--cy); }
.lobby-sec.live::before { background: var(--green); box-shadow: 0 0 8px var(--green); }
.lobby-count { font: 600 10px var(--f-mono); color: var(--text3); border: 1px solid var(--border2); border-radius: 8px; padding: 3px 9px; letter-spacing: .04em; }
.lobby-list { display: grid; gap: 10px; }
.lobby-row { display: flex; align-items: center; gap: 14px; background: rgba(17,17,32,.55); border: 1px solid rgba(255,255,255,.07); border-radius: 12px; padding: 13px 16px; transition: border-color .15s, transform .15s; }
.lobby-row:hover { border-color: rgba(40,224,255,.3); transform: translateX(2px); }
.lobby-row.live:hover { border-color: rgba(20,241,149,.3); }
.lobby-ava { width: 36px; height: 36px; border-radius: 50%; background: var(--card2); display: flex; align-items: center; justify-content: center; font: 800 15px var(--f-display); color: var(--text2); flex-shrink: 0; }
.lobby-who { flex: 1; min-width: 0; }
.lobby-nm { font: 700 14px var(--f-body); color: #fff; }
.lobby-meta { font-size: 11px; color: var(--text3); margin-top: 2px; }
.lobby-stake { font: 700 13px var(--f-mono); color: var(--text2); white-space: nowrap; }
.lobby-stake b { color: var(--cy); }
.lobby-vs { font: 700 12px var(--f-mono); color: var(--text3); }
.lobby-live-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px var(--green); animation: livePulse 1.4s ease-in-out infinite; flex-shrink: 0; }
@keyframes livePulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
.lobby-empty { color: var(--text3); font-size: 13px; padding: 18px; text-align: center; background: rgba(17,17,32,.4); border: 1px dashed var(--border2); border-radius: 12px; }
.lobby-spectate-tag { font: 700 9px var(--f-body); letter-spacing: .08em; text-transform: uppercase; color: var(--green); }
.bt-spectator { position: absolute; top: 10px; left: 50%; transform: translateX(-50%); font: 700 10px var(--f-body); letter-spacing: .12em; text-transform: uppercase; color: var(--green); background: rgba(20,241,149,.1); border: 1px solid rgba(20,241,149,.35); border-radius: 8px; padding: 3px 12px; z-index: 3; }

/* ════════ v8 patch — leaderboard: FLUID columns that can never overflow ════════
   Every column is minmax(0, …fr): the grid always sums to exactly the row width,
   so it fills the full width AND can never spill past the card (no min-width, no
   scroll). Cell content is nowrap + ellipsis. This is the single source of truth —
   `!important` + being the last .lb-row2 rule overrides all earlier patches/media. */
.lb2 { max-width: 1360px; margin: 0 auto; }
.lb2-table { width: 100%; overflow: hidden; }
.lb-row2 {
  width: 100%; min-width: 0 !important;
  grid-template-columns: 32px 28px minmax(0,2fr) minmax(0,1.35fr) minmax(0,0.85fr) minmax(0,1.05fr) minmax(0,0.85fr) minmax(0,0.7fr) minmax(0,0.6fr) !important;
  gap: 12px !important; padding: 14px 16px !important; box-sizing: border-box; overflow: hidden;
}
.lb-headrow { padding: 6px 18px 2px !important; }
.lb-row2 .lb-c, .lb-headrow .lb-c { display: block !important; text-align: right; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lb-tier { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
.lb-who { overflow: hidden; }
.yr-stats span { white-space: nowrap; }
@media (max-width: 560px) { .yr-stats { display: none; } }

/* season-rewards annotation on the leaderboard */
.lb-rewards { display: flex; gap: 10px; align-items: flex-start; background: linear-gradient(120deg, rgba(255,210,63,.12), rgba(255,255,255,.03)); border: 1px solid rgba(255,210,63,.3); border-radius: 12px; padding: 11px 16px; margin: 2px 0 14px; font-size: 12.5px; color: #e7ddc0; line-height: 1.5; }
.lb-rewards-ico { font-size: 18px; line-height: 1.4; flex-shrink: 0; }
.lb-rewards b { color: var(--ag, #ffd23f); }
.lb-rewards i { color: var(--text3); font-style: italic; }
.lb-row2.in-rewards { border-color: rgba(255,210,63,.35); box-shadow: inset 3px 0 0 var(--ag, #ffd23f); }

/* ════════ PvP setup wizard + simultaneous reveal ════════ */
.bt-stage .fxpair { display: flex; gap: 26px; align-items: center; justify-content: center; }
.wiz-step { display: flex; flex-direction: column; gap: 14px; align-items: stretch; max-width: 460px; margin: 0 auto; text-align: center; }
.wiz-h { font: 700 16px var(--f-display); letter-spacing: .04em; color: #fff; }
.wiz-hint { font-size: 12px; color: var(--text3); margin-top: -6px; }
.wiz-choice { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.wiz-pick { background: #0b0e18; border: 1px solid var(--border2); border-radius: 14px; padding: 18px 12px; cursor: pointer; display: flex; flex-direction: column; gap: 6px; transition: all .15s; }
.wiz-pick b { font: 700 14px var(--f-display); color: var(--text); }
.wiz-pick span { font-size: 11px; color: var(--text3); line-height: 1.35; }
.wiz-pick:hover { border-color: var(--cy); transform: translateY(-2px); }
.wager-quick.big { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.wager-quick.big button { background: #0b0e18; border: 1px solid var(--border2); color: var(--text2); border-radius: 10px; padding: 9px 16px; cursor: pointer; font: 700 13px var(--f-mono); }
.wager-quick.big button.on { border-color: var(--cy); color: #fff; background: rgba(40,224,255,.12); }
.wiz-locked { font: 700 14px var(--f-mono); color: var(--cy); background: rgba(40,224,255,.08); border: 1px solid rgba(40,224,255,.3); border-radius: 10px; padding: 10px; }
.wiz-lines { display: flex; flex-direction: column; gap: 6px; background: rgba(17,17,32,.5); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 12px 14px; }
.wiz-lines > div { display: flex; justify-content: space-between; font-size: 12.5px; color: var(--text2); }
.wiz-lines b { font-family: var(--f-mono); color: #fff; }
.wiz-actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.wiz-tx { gap: 16px; }
.wiz-tx-body { font-size: 13.5px; color: var(--text); line-height: 1.55; background: rgba(17,17,32,.5); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 14px; }
.wiz-tx-sim { font-size: 11px; color: var(--text3); }
.wiz-insuff { font-size: 12px; color: var(--red); display: flex; gap: 8px; align-items: center; justify-content: center; flex-wrap: wrap; }
.wiz-hands { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.wiz-hand { background: #0b0e18; border: 2px solid var(--border2); border-radius: 14px; padding: 10px; cursor: pointer; transition: all .15s; text-align: center; }
.wiz-hand.on { border-color: var(--cy); box-shadow: 0 0 14px rgba(40,224,255,.25); }
.wiz-hand-h { font: 700 12px var(--f-display); color: var(--text2); margin-bottom: 8px; }
/* small cards for the choose-hand grids (PvP wizard + PvE dungeon) — scale the WHOLE
   card, not just its width, so the icon/name/value never overflow and overlap. */
.gb-hand-grid.sm { gap: 7px; }
.gb-hand-grid.sm .gb-card { width: 62px; flex: 0 0 62px; aspect-ratio: auto; min-height: 76px; padding: 15px 3px 6px; gap: 1px; }
.gb-hand-grid.sm .gb-card-rar { top: 3px; right: 3px; font-size: 6px; padding: 1px 3px; letter-spacing: 0; }
.gb-hand-grid.sm .gb-card-icon { height: 22px; font-size: 19px; }
.gb-hand-grid.sm .gb-card-emoji { font-size: 19px; }
.gb-hand-grid.sm .gb-card-name { font-size: 6.5px; min-height: 0; margin-top: 2px; line-height: 1.15; }
.gb-hand-grid.sm .gb-card-val { font-size: 13px; margin-top: 1px; }
.wiz-guest { font-size: 12px; color: var(--green); min-height: 16px; }
.mm-timer { font: 700 14px var(--f-mono); color: var(--text2); background: rgba(255,255,255,.06); border-radius: 8px; padding: 3px 10px; }
.mm-timer.urgent { color: #fff; background: rgba(255,68,85,.18); border: 1px solid rgba(255,68,85,.5); animation: mmPulse 1s ease-in-out infinite; }
@keyframes mmPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(255,68,85,.4); } 50% { box-shadow: 0 0 10px 2px rgba(255,68,85,.5); } }
@media (max-width: 560px) { .wiz-choice, .wiz-hands { grid-template-columns: 1fr; } }
@media (prefers-reduced-motion: reduce) { .mm-timer.urgent { animation: none; } }

/* ════════ batch7 — mini-profile card, avatar picker, docs sidebar ════════ */
/* home mini-profile card (replaces the old Global group; click → profile) */
.sa-pcard { display: flex; align-items: center; gap: 14px; text-align: left; cursor: pointer; border: 1px solid rgba(40,224,255,.22); }
.sa-pcard:hover { border-color: var(--cy); transform: translateY(-2px); box-shadow: 0 0 16px rgba(40,224,255,.18); }
.sa-pc-av .av-photo { box-shadow: 0 0 0 2px rgba(255,255,255,.14); }
.sa-pc-info { min-width: 0; }
.sa-pc-name { font: 800 17px var(--f-display); color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sa-pc-sub { font: 700 12px var(--f-mono); margin-top: 4px; }
.sa-pc-sub2 { font: 500 11px var(--f-mono); color: var(--text3); margin-top: 3px; }
.sa-pc-edit { font: 600 11px var(--f-body); color: var(--cy); margin-top: 8px; }

/* profile avatar picker */
.pf-avatars { display: flex; flex-wrap: wrap; gap: 10px; }
.pf-avpick { width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--border2); background: #0b0e18; cursor: pointer; font-size: 24px; line-height: 1; transition: all .12s; display: inline-flex; align-items: center; justify-content: center; }
.pf-avpick:hover { border-color: var(--cy); transform: scale(1.08); }
.pf-avpick.on { border-color: var(--cy); box-shadow: 0 0 0 2px rgba(40,224,255,.3), 0 0 12px rgba(40,224,255,.3); background: rgba(40,224,255,.1); }
.pf-avrow { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.pf-welcome { background: linear-gradient(120deg, rgba(40,224,255,.14), rgba(139,92,246,.12)); border: 1px solid rgba(40,224,255,.35); border-radius: 12px; padding: 12px 16px; margin-bottom: 14px; font-size: 13px; color: #dfe7ff; }

/* docs as a real doc: left nav tree + content */
.docs-wrap.docs-layout { display: grid; grid-template-columns: 210px 1fr; gap: 26px; max-width: 1040px; margin: 0 auto; align-items: start; }
.docs-nav { position: sticky; top: 74px; align-self: start; background: rgba(17,17,32,.5); border: 1px solid rgba(255,255,255,.07); border-radius: 14px; padding: 12px 10px; max-height: calc(100vh - 96px); overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.docs-nav-h { font: 700 11px var(--f-display); letter-spacing: .1em; text-transform: uppercase; color: var(--text3); padding: 4px 10px 8px; }
.docs-navlink { display: block; padding: 7px 10px; border-radius: 8px; font: 500 12.5px var(--f-body); color: var(--text2); text-decoration: none; cursor: pointer; border-left: 2px solid transparent; transition: all .12s; }
.docs-navlink:hover { background: rgba(255,255,255,.05); color: #fff; }
.docs-navlink.on { color: var(--cy); border-left-color: var(--cy); background: rgba(40,224,255,.08); }
.docs-content { min-width: 0; }
.docs-content h2 { scroll-margin-top: 74px; }
@media (max-width: 820px) {
  .docs-wrap.docs-layout { grid-template-columns: 1fr; gap: 12px; }
  .docs-nav { position: static; flex-direction: row; flex-wrap: nowrap; overflow-x: auto; max-height: none; }
  .docs-nav-h { display: none; }
  .docs-navlink { white-space: nowrap; border-left: none; border-bottom: 2px solid transparent; }
  .docs-navlink.on { border-left: none; border-bottom-color: var(--cy); }
}

/* ═══════════ PvE level / XP (home card, profile, result) ═══════════ */
.sa-lvl { font: 800 10px var(--f-mono); letter-spacing: .04em; color: #22e3a6; background: rgba(34,227,166,.12); border: 1px solid rgba(34,227,166,.35); border-radius: 7px; padding: 2px 7px; vertical-align: middle; }
.sa-xp { margin-top: 10px; }
.sa-xp-top { display: flex; justify-content: space-between; font: 600 10px var(--f-body); letter-spacing: .03em; color: var(--text3); margin-bottom: 5px; }
.sa-xp-bar, .pf-xp-bar, .dr-xp-bar { height: 8px; border-radius: 6px; background: rgba(255,255,255,.07); overflow: hidden; border: 1px solid rgba(255,255,255,.06); }
.sa-xp-fill, .pf-xp-fill, .dr-xp-fill { height: 100%; border-radius: 6px; background: linear-gradient(90deg,#22e3a6,#28e0ff); box-shadow: 0 0 10px rgba(34,227,166,.5); transition: width .5s cubic-bezier(.2,.7,.2,1); }
.pf-xp { margin-top: 14px; }
.pf-xp-top { display: flex; justify-content: space-between; font: 600 11px var(--f-body); color: var(--text3); margin-bottom: 6px; }
.duel-result-xp { margin: 10px auto 4px; max-width: 320px; }
.dr-xp-gain { font: 800 15px var(--f-display); color: #22e3a6; }
.dr-xp-lvl { font: 700 12px var(--f-mono); color: #28e0ff; margin-left: 10px; }
.dr-xp-lvl.dim { color: var(--text3); }
.dr-xp-bar { margin-top: 8px; }

/* ═══════════ chat hover profile preview ═══════════ */
#chat-pc { position: fixed; z-index: 4000; width: 224px; background: linear-gradient(160deg,#0d1424,#0a0f1c); border: 1px solid var(--border2); border-radius: 14px; padding: 13px; box-shadow: 0 18px 48px rgba(0,0,0,.6); opacity: 0; transform: translateY(6px) scale(.97); pointer-events: none; transition: opacity .14s, transform .14s; }
#chat-pc.open { opacity: 1; transform: none; pointer-events: auto; }
.cpc-head { display: flex; align-items: center; gap: 10px; }
.cpc-av { width: 42px; height: 42px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; font-weight: 800; color: #06121f; }
.cpc-id { min-width: 0; }
.cpc-name { font: 700 14px var(--f-body); color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cpc-rank { font: 700 10px var(--f-mono); letter-spacing: .07em; }
.cpc-title { font-size: 11px; color: var(--text3); margin-top: 8px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cpc-stats { display: flex; gap: 8px; margin: 11px 0 0; }
.cpc-stats > div { flex: 1; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.06); border-radius: 9px; padding: 7px 4px; text-align: center; }
.cpc-stats b { display: block; font: 800 15px var(--f-display); color: var(--text); }
.cpc-stats span { font-size: 9px; letter-spacing: .06em; text-transform: uppercase; color: var(--text3); }
.cpc-defy { width: 100%; margin-top: 11px; padding: 9px; border: none; border-radius: 10px; cursor: pointer; font: 800 12px var(--f-body); letter-spacing: .04em; color: #06121f; background: linear-gradient(90deg,#ff5577,#ff8a3d); box-shadow: 0 6px 16px rgba(255,85,119,.32); transition: transform .12s, box-shadow .12s; }
.cpc-defy:hover { transform: translateY(-1px); box-shadow: 0 9px 22px rgba(255,85,119,.45); }
.cpc-off { margin-top: 11px; text-align: center; font-size: 11px; color: var(--text3); }

/* ═══════════ incoming challenge modal ═══════════ */
#challenge-modal { position: fixed; inset: 0; z-index: 4200; display: none; align-items: center; justify-content: center; background: rgba(4,7,14,.72); backdrop-filter: blur(4px); padding: 20px; }
#challenge-modal.open { display: flex; animation: chmIn .18s ease; }
@keyframes chmIn { from { opacity: 0; } to { opacity: 1; } }
.chm-card { width: 100%; max-width: 360px; text-align: center; background: linear-gradient(160deg,#141021,#0c0a16); border: 1px solid rgba(255,85,119,.35); border-radius: 20px; padding: 26px 24px; box-shadow: 0 24px 60px rgba(0,0,0,.6); }
.chm-ico { font-size: 46px; animation: chmPulse 1.4s ease-in-out infinite; }
@keyframes chmPulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.12); } }
.chm-title { font: 800 19px var(--f-display); color: #fff; margin: 10px 0 4px; }
.chm-stake { font: 700 13px var(--f-mono); color: var(--gold); margin-bottom: 20px; }
.chm-actions { display: flex; gap: 10px; }
.chm-actions .pvp-btn { flex: 1; }
.waiting-challenge { font: 700 12px var(--f-body); color: #ff8a3d; background: rgba(255,138,61,.1); border: 1px solid rgba(255,138,61,.3); border-radius: 10px; padding: 8px 12px; margin: 4px 0 2px; }

/* respect reduced-motion for the new challenge/preview/xp animations (matches the codebase pattern) */
@media (prefers-reduced-motion: reduce) {
  .chm-ico { animation: none; }
  .qm-found-ico { animation: none; }
  #challenge-modal.open { animation: none; }
  #chat-pc { transition: none; }
  .sa-xp-fill, .pf-xp-fill, .dr-xp-fill { transition: none; }
  .lb2-source.on .lb2-dot { animation: none; }
}

/* ═══════════ Quick Match ═══════════ */
.lobby-quick-note { text-align: center; font-size: 11.5px; color: var(--text3); margin: 10px auto 0; max-width: 560px; }
.qm-row { display: flex; align-items: center; gap: 12px; margin: 12px 0; flex-wrap: wrap; }
.qm-lbl { font: 700 11px var(--f-body); letter-spacing: .08em; text-transform: uppercase; color: var(--text3); min-width: 42px; }
.qm-hint { font-size: 12px; color: var(--text3); margin: 4px 0 6px; line-height: 1.5; }
.qm-summary { text-align: center; font: 700 12px var(--f-mono); color: var(--cy); background: rgba(40,224,255,.07); border: 1px solid rgba(40,224,255,.25); border-radius: 10px; padding: 9px 12px; margin: 14px 0; }
.qm-found { text-align: center; }
.qm-found-ico { font-size: 44px; animation: chmPulse 1.4s ease-in-out infinite; margin-bottom: 4px; }
.qm-vs { font: 800 18px var(--f-display); color: #fff; margin: 4px 0; }
.qm-stake { font: 700 13px var(--f-mono); color: var(--gold); margin-bottom: 16px; }

/* ═══════════ PvE dungeon: explicit draw → reroll → choose ═══════════ */
.dg-draw { display: flex; flex-direction: column; align-items: center; gap: 10px; margin: 26px 0 8px; }
.dg-draw .pvp-btn { width: auto; min-width: 220px; }
.dg-drawhint { font-size: 12px; color: var(--text3); max-width: 420px; text-align: center; line-height: 1.5; }
.dg-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 20px; }
.dg-actions .pvp-btn { width: auto; min-width: 180px; }
