/* =========================================================================
   $COAL — "Strike!"  dig-and-uncover mini-game
   Reuses brand tokens + fonts from coal.css (:root).
   ========================================================================= */

.game-body{
  height:auto; min-height:100%; overflow-x:clip; overflow-y:visible;
  background:
    radial-gradient(1200px 700px at 50% -10%, rgba(245,166,35,.10), transparent 60%),
    radial-gradient(900px 600px at 50% 120%, rgba(43,214,214,.07), transparent 60%),
    var(--void);
  color:var(--bone);
}

.gwrap{ max-width:1040px; margin:0 auto; padding:18px 16px 64px; }

/* ---------- top bar ---------- */
.gnav{ display:flex; align-items:center; justify-content:space-between; gap:14px; margin-bottom:18px; }
.gnav-logo{ height:34px; cursor:pointer; image-rendering:auto; }
.gnav-links{ display:flex; align-items:center; gap:18px; }
.gnav-links a{ font-family:var(--f-ui); font-weight:600; font-size:14px; color:var(--bone-dim); text-decoration:none; transition:color .15s; }
.gnav-links a:hover{ color:var(--gold-bright); }

/* ---------- title ---------- */
.ghead{ text-align:center; margin:8px 0 22px; }
.gkicker{ display:inline-flex; align-items:center; gap:7px; padding:5px 13px; border:2px solid var(--frame-edge);
  border-radius:20px; background:rgba(8,6,4,.6); font-family:var(--f-pixel); font-size:9px; letter-spacing:.06em;
  color:var(--gold-bright); text-transform:uppercase; }
.gkicker .dot{ width:7px; height:7px; border-radius:50%; background:var(--diamond-deep); box-shadow:0 0 8px var(--diamond); }
.gtitle{ font-family:var(--f-display); font-weight:400; line-height:.95; margin:12px 0 4px;
  font-size:clamp(40px,7vw,76px); color:var(--bone); text-shadow:0 4px 0 #2a2018, 0 6px 8px rgba(0,0,0,.6); }
.gtitle .gem{ color:var(--diamond-glow); text-shadow:0 4px 0 #1c6b6b, 0 6px 8px rgba(0,0,0,.6); }
.gsub{ font-family:var(--f-ui); font-size:clamp(14px,1.6vw,17px); color:var(--bone-dim); max-width:560px; margin:0 auto; }

/* ---------- stage layout ---------- */
.stage{ display:grid; grid-template-columns:minmax(0,1fr) 188px; gap:20px; align-items:start; }
@media (max-width:760px){ .stage{ grid-template-columns:1fr; } }

/* shared pixel-card frame */
.pcard{ position:relative; background:linear-gradient(180deg,var(--frame-face),var(--frame-face-2));
  border:3px solid var(--frame-edge); border-radius:var(--r-lg);
  box-shadow:inset 0 0 0 2px var(--frame-bevel), inset 0 3px 0 rgba(255,255,255,.05), 0 5px 0 var(--frame-edge), var(--pit); }

/* ---------- HUD ---------- */
.hud{ padding:13px 15px; margin-bottom:14px; display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.hud-stat{ display:flex; flex-direction:column; gap:3px; }
.hud-stat .lbl{ font-family:var(--f-pixel); font-size:8px; letter-spacing:.06em; color:var(--muted); text-transform:uppercase; }
.hud-stat .val{ font-family:var(--f-ui); font-weight:700; font-size:22px; line-height:1; color:var(--gold-bright); }
.hud-stat .val.gem{ color:var(--diamond-glow); }
.hud-spacer{ flex:1; }

/* durability bar */
.dura{ flex:1 1 180px; min-width:160px; }
.dura .lbl{ display:flex; justify-content:space-between; font-family:var(--f-pixel); font-size:8px; letter-spacing:.06em;
  color:var(--muted); text-transform:uppercase; margin-bottom:5px; }
.dura .lbl b{ color:var(--bone); font-family:var(--f-ui); font-size:11px; }
.dura-track{ height:14px; border:2px solid var(--frame-edge); border-radius:8px; background:var(--slot);
  box-shadow:inset 0 2px 4px rgba(0,0,0,.6); overflow:hidden; }
.dura-fill{ height:100%; width:100%; border-radius:6px; transition:width .2s ease, background .3s;
  background:linear-gradient(180deg,var(--gold-pale),var(--gold) 60%,var(--ochre));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4); }
.dura-fill.warn{ background:linear-gradient(180deg,#ffd36b,var(--ember)); }
.dura-fill.crit{ background:linear-gradient(180deg,#ff9d6b,var(--danger)); }

/* ---------- board ---------- */
.board-frame{ padding:14px; }
.board{ position:relative; display:grid; gap:4px; border-radius:4px; overflow:hidden;
  background:#0a0805; box-shadow:inset 0 0 0 2px var(--frame-edge), inset 0 0 30px rgba(0,0,0,.7);
  touch-action:manipulation; }

.cell{ position:relative; aspect-ratio:1; border-radius:3px; cursor:pointer; overflow:hidden;
  background-color:#1a140d; outline:none; transition:transform .05s; }
.cell::before{ content:""; position:absolute; inset:0; border-radius:3px; transition:opacity .12s, background .12s; }
.cell::after{ content:""; position:absolute; inset:0; border-radius:3px; pointer-events:none;
  background-image:
    radial-gradient(circle at 30% 28%, rgba(0,0,0,.35) 0 18%, transparent 19%),
    radial-gradient(circle at 72% 64%, rgba(0,0,0,.28) 0 14%, transparent 15%);
  opacity:0; transition:opacity .15s; }

/* terrain depth skins (applied via data-d) */
.cell[data-d="4"]::before{ background:
  linear-gradient(150deg,#2a2014,#17100a), repeating-linear-gradient(45deg, rgba(0,0,0,.28) 0 2px, transparent 2px 6px);
  box-shadow:inset 0 2px 0 rgba(255,255,255,.05), inset 0 -4px 7px rgba(0,0,0,.6); }
.cell[data-d="4"]::after{ opacity:1; }
.cell[data-d="3"]::before{ background:
  linear-gradient(150deg,#3a2c1c,#241a10), repeating-linear-gradient(45deg, rgba(0,0,0,.18) 0 3px, transparent 3px 7px);
  box-shadow:inset 0 2px 0 rgba(255,255,255,.06), inset 0 -3px 6px rgba(0,0,0,.55); }
.cell[data-d="3"]::after{ opacity:1; }
.cell[data-d="2"]::before{ background:linear-gradient(150deg,#4a3722,#311f12);
  box-shadow:inset 0 2px 0 rgba(255,255,255,.07), inset 0 -3px 6px rgba(0,0,0,.45); }
.cell[data-d="2"]::after{ opacity:.5; }
.cell[data-d="1"]::before{ background:linear-gradient(150deg,#6b4a28,#4a3119);
  box-shadow:inset 0 2px 0 rgba(255,255,255,.08), inset 0 -2px 5px rgba(0,0,0,.35); }
.cell[data-d="0"]::before{ background:radial-gradient(circle at 50% 38%, #2b251c, #141009);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.5), inset 0 2px 8px rgba(0,0,0,.6); }

.cell.diggable:hover::before{ filter:brightness(1.18); }
.cell.diggable:hover{ transform:translateY(-1px); }
.cell.struck{ animation:cell-strike .22s ease; }
@keyframes cell-strike{ 0%{ transform:scale(.86); } 55%{ transform:scale(1.06); } 100%{ transform:scale(1); } }

/* bedrock — undiggable stone */
.cell.bedrock{ cursor:not-allowed; }
.cell.bedrock::before{ background:
  linear-gradient(150deg,#555049,#2c2823), repeating-linear-gradient(115deg, rgba(255,255,255,.05) 0 2px, transparent 2px 6px);
  box-shadow:inset 0 2px 0 rgba(255,255,255,.12), inset 0 -3px 6px rgba(0,0,0,.55); }
.cell.bedrock::after{ opacity:.0; }

/* exposed treasure slice */
.cell .gem-slice{ position:absolute; inset:0; background-repeat:no-repeat; opacity:0;
  transition:opacity .25s ease; z-index:2; }
.cell.shown .gem-slice{ opacity:1; }
.cell.collected{ box-shadow:inset 0 0 0 2px rgba(169,255,255,.45); }
.cell.collected .gem-slice{ filter:drop-shadow(0 0 6px rgba(169,255,255,.55)); }

/* sparkle on full collect */
.cell.flash::after{ content:""; opacity:1; z-index:3;
  background:radial-gradient(circle at 50% 50%, rgba(255,255,255,.9), rgba(169,255,255,.4) 35%, transparent 70%);
  animation:gem-flash .5s ease forwards; }
@keyframes gem-flash{ from{ opacity:.95; transform:scale(.4);} to{ opacity:0; transform:scale(1.5);} }

/* dust particle */
.spark{ position:absolute; width:6px; height:6px; border-radius:50%; pointer-events:none; z-index:5;
  background:var(--gold-pale); box-shadow:0 0 5px var(--gold); }

.board.shake{ animation:shake .25s ease; }
@keyframes shake{ 0%,100%{ transform:translate(0,0);} 25%{ transform:translate(-3px,2px);} 50%{ transform:translate(3px,-2px);} 75%{ transform:translate(-2px,-1px);} }

/* ---------- side panel ---------- */
.side{ display:flex; flex-direction:column; gap:14px; }
@media (max-width:760px){ .side{ order:-1; flex-direction:row; flex-wrap:wrap; } }

/* miner */
.miner-box{ padding:12px; text-align:center; }
.miner-stage{ height:150px; display:flex; align-items:flex-end; justify-content:center; }
.miner-stage img{ height:140px; width:auto; filter:drop-shadow(0 6px 6px rgba(0,0,0,.5));
  transition:transform .12s; }
.miner-stage img.swing{ animation:miner-swing .26s ease; }
@keyframes miner-swing{ 0%{ transform:rotate(-7deg) translateY(0);} 45%{ transform:rotate(4deg) translateY(2px);} 100%{ transform:rotate(0) translateY(0);} }
.miner-say{ font-family:var(--f-ui); font-size:13px; color:var(--bone-dim); margin-top:6px; min-height:18px; }

/* tool picker */
.tools{ padding:12px; }
.tools-h{ font-family:var(--f-pixel); font-size:8px; letter-spacing:.06em; color:var(--muted); text-transform:uppercase; margin-bottom:9px; text-align:center; }
.tool-row{ display:flex; gap:9px; }
.tool{ flex:1; display:flex; flex-direction:column; align-items:center; gap:5px; padding:10px 6px; cursor:pointer;
  border:2px solid var(--frame-edge); border-radius:5px; background:linear-gradient(180deg,#2a2217,#1b150d);
  box-shadow:inset 0 2px 0 rgba(255,255,255,.05); transition:transform .1s, box-shadow .1s, border-color .1s; }
.tool:hover{ transform:translateY(-1px); }
.tool.sel{ border-color:var(--gold); box-shadow:inset 0 2px 0 rgba(255,255,255,.08), 0 0 0 2px rgba(245,166,35,.35), 0 0 14px rgba(245,166,35,.25); }
.tool img{ width:40px; height:40px; object-fit:contain; }
.tool .tn{ font-family:var(--f-ui); font-weight:700; font-size:13px; color:var(--bone); }
.tool .td{ font-family:var(--f-pixel); font-size:7px; letter-spacing:.04em; color:var(--gold-bright); text-transform:uppercase; }
.tool .tc{ font-family:var(--f-pixel); font-size:7px; letter-spacing:.03em; text-transform:uppercase;
  color:var(--bone-dim); padding:2px 6px; border-radius:10px; background:rgba(0,0,0,.3); border:1px solid var(--frame-edge); }
.tool .tc.cost{ color:var(--ember); }

/* finds list */
.finds{ padding:12px; flex:1; min-width:150px; }
.finds-h{ font-family:var(--f-pixel); font-size:8px; letter-spacing:.06em; color:var(--muted); text-transform:uppercase; margin-bottom:10px; text-align:center; }
.find{ display:flex; align-items:center; gap:9px; padding:5px 4px; border-radius:4px; opacity:.4; transition:opacity .3s, background .3s; }
.find.got{ opacity:1; background:rgba(169,255,255,.06); }
.find img{ width:26px; height:26px; object-fit:contain; filter:grayscale(1) brightness(.6); transition:filter .3s; }
.find.got img{ filter:none drop-shadow(0 0 4px rgba(169,255,255,.4)); }
.find .fn{ font-family:var(--f-ui); font-size:12.5px; font-weight:600; color:var(--bone); flex:1; }
.find .fp{ font-family:var(--f-ui); font-size:12px; font-weight:700; color:var(--gold-bright); }
.find .fc{ font-family:var(--f-pixel); font-size:9px; color:var(--diamond-glow); }

/* ---------- buttons ---------- */
.gbtn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; cursor:pointer; user-select:none;
  font-family:var(--f-ui); font-weight:700; font-size:15px; color:#2a1a06; text-decoration:none;
  padding:11px 20px; border:2px solid var(--frame-edge); border-radius:5px;
  background:linear-gradient(180deg,var(--gold-pale),var(--gold) 55%,var(--ochre));
  box-shadow:inset 0 2px 0 rgba(255,255,255,.45), 0 4px 0 #6b3f1a, 0 6px 10px rgba(0,0,0,.4);
  transition:transform .08s, box-shadow .08s; }
.gbtn:active{ transform:translateY(3px); box-shadow:inset 0 2px 0 rgba(255,255,255,.4), 0 1px 0 #6b3f1a; }
.gbtn.ghost{ color:var(--bone); background:linear-gradient(180deg,#332a1d,#221a10); box-shadow:inset 0 2px 0 rgba(255,255,255,.06), 0 4px 0 var(--frame-edge); }
.gbtn img{ width:20px; height:20px; }
.gbtn.gem{ background:linear-gradient(180deg,#cfffff,var(--diamond-deep) 60%,#159a9a); color:#06302f; box-shadow:inset 0 2px 0 rgba(255,255,255,.5), 0 4px 0 #0c6b6b, 0 6px 10px rgba(0,0,0,.4); }

/* ---------- overlays ---------- */
.overlay{ position:fixed; inset:0; z-index:50; display:none; align-items:center; justify-content:center; padding:20px;
  background:radial-gradient(1000px 700px at 50% 40%, rgba(12,9,5,.78), rgba(8,6,4,.94)); backdrop-filter:blur(3px); }
.overlay.show{ display:flex; animation:fade .25s ease; }
@keyframes fade{ from{ opacity:0;} to{ opacity:1;} }
.panel{ width:min(440px,94vw); padding:26px 24px 24px; text-align:center; }
.panel .pic{ height:150px; display:flex; align-items:center; justify-content:center; margin-bottom:6px; }
.panel .pic img{ height:150px; filter:drop-shadow(0 8px 10px rgba(0,0,0,.6)); }
.panel h2{ font-family:var(--f-display); font-weight:400; font-size:clamp(30px,6vw,46px); line-height:1;
  color:var(--bone); text-shadow:0 3px 0 #2a2018; margin-bottom:8px; }
.panel h2 .gem{ color:var(--diamond-glow); text-shadow:0 3px 0 #1c6b6b; }
.panel h2 .gold{ color:var(--gold-bright); text-shadow:0 3px 0 #6b3f1a; }
.panel p{ font-family:var(--f-ui); font-size:15px; color:var(--bone-dim); line-height:1.55; margin:0 auto 18px; max-width:340px; }
.panel .howto{ text-align:left; margin:0 auto 20px; max-width:330px; display:flex; flex-direction:column; gap:11px; }
.panel .howto .h{ display:flex; gap:11px; align-items:center; font-family:var(--f-ui); font-size:13.5px; color:var(--bone); }
.panel .howto .h img{ width:34px; height:34px; object-fit:contain; flex-shrink:0; }
.panel .howto .h b{ color:var(--gold-bright); }
.panel .score-big{ font-family:var(--f-ui); font-weight:700; font-size:46px; line-height:1; color:var(--gold-bright); margin:2px 0; }
.panel .score-lbl{ font-family:var(--f-pixel); font-size:9px; letter-spacing:.08em; color:var(--muted); text-transform:uppercase; }
.panel .best{ font-family:var(--f-ui); font-size:13px; color:var(--diamond-glow); margin-top:6px; }
.panel .btns{ display:flex; gap:10px; justify-content:center; margin-top:20px; flex-wrap:wrap; }

.mute{ position:fixed; right:16px; bottom:16px; z-index:40; width:42px; height:42px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:18px;
  border:2px solid var(--frame-edge); background:linear-gradient(180deg,#2a2217,#1b150d);
  box-shadow:0 3px 0 var(--frame-edge); color:var(--bone); }

.foot{ text-align:center; margin-top:30px; font-family:var(--f-ui); font-size:13px; color:var(--muted); }
.foot a{ color:var(--gold-bright); text-decoration:none; }

/* =========================================================================
   Difficulty selector, side-best, leaderboard, wallet entry
   ========================================================================= */

/* HUD difficulty pill */
.diff-pill{ font-family:var(--f-pixel); font-size:8px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--diamond-glow); padding:5px 10px; border:2px solid var(--frame-edge); border-radius:20px;
  background:rgba(43,214,214,.08); box-shadow:inset 0 1px 0 rgba(255,255,255,.05); white-space:nowrap; }

/* side "best" card */
.side-best{ padding:11px 12px; display:flex; justify-content:space-between; align-items:center; }
.side-best .sb-lbl{ font-family:var(--f-pixel); font-size:8px; letter-spacing:.06em; color:var(--muted); text-transform:uppercase; }
.side-best .sb-val{ font-family:var(--f-ui); font-weight:700; font-size:18px; color:var(--diamond-glow); }

/* nav leaderboard link */
.lb-link{ cursor:pointer; }

/* ---- difficulty picker (intro) ---- */
.diff-pick{ margin:4px auto 14px; max-width:360px; }
.diff-h{ font-family:var(--f-pixel); font-size:8px; letter-spacing:.06em; color:var(--muted); text-transform:uppercase; margin-bottom:9px; }
.diff-row{ display:flex; gap:8px; }
.diff{ flex:1; cursor:pointer; padding:10px 6px; border:2px solid var(--frame-edge); border-radius:5px;
  background:linear-gradient(180deg,#2a2217,#1b150d); box-shadow:inset 0 2px 0 rgba(255,255,255,.05);
  display:flex; flex-direction:column; gap:3px; align-items:center; text-align:center; transition:transform .1s, box-shadow .1s, border-color .1s; }
.diff:hover{ transform:translateY(-1px); }
.diff.sel{ border-color:var(--gold); box-shadow:inset 0 2px 0 rgba(255,255,255,.08), 0 0 0 2px rgba(245,166,35,.35), 0 0 14px rgba(245,166,35,.22); }
.diff .dn{ font-family:var(--f-ui); font-weight:700; font-size:14px; color:var(--bone); }
.diff .dd{ font-family:var(--f-pixel); font-size:7px; letter-spacing:.03em; color:var(--gold-bright); text-transform:uppercase; }

.intro-best{ font-family:var(--f-ui); font-size:13px; color:var(--bone-dim); margin-bottom:4px; }
.intro-best b{ color:var(--diamond-glow); }

/* ---- leaderboard submit (end screen) ---- */
.submit-wrap{ margin:16px auto 4px; max-width:340px; }
.submit-h{ font-family:var(--f-pixel); font-size:8px; letter-spacing:.06em; color:var(--gold-bright); text-transform:uppercase; margin-bottom:9px; }
.wallet-row{ display:flex; gap:8px; }
.wallet-input{ flex:1; min-width:0; font-family:var(--f-ui); font-size:14px; color:var(--bone); padding:10px 12px;
  border:2px solid var(--frame-edge); border-radius:5px; background:var(--slot); box-shadow:inset 0 2px 4px rgba(0,0,0,.5); outline:none; }
.wallet-input::placeholder{ color:var(--muted-d); }
.wallet-input:focus{ border-color:var(--diamond-deep); box-shadow:inset 0 2px 4px rgba(0,0,0,.5), 0 0 0 2px rgba(43,214,214,.3); }
.wallet-connect{ padding:10px 14px; font-size:13px; flex-shrink:0; }
.wallet-err{ font-family:var(--f-ui); font-size:12px; color:var(--danger); min-height:16px; margin:6px 2px 0; text-align:left; }
.submit-btn{ width:100%; margin-top:6px; }

.submit-done{ margin:14px auto 2px; max-width:360px; }
.rank-line{ font-family:var(--f-display); font-size:24px; color:var(--bone); margin-bottom:12px; }
.rank-line b{ color:var(--gold-bright); }
.end-view{ display:inline-block; margin-top:12px; font-family:var(--f-ui); font-size:13px; color:var(--gold-bright); text-decoration:none; }
.end-view:hover{ color:var(--gold-pale); }

/* ---- leaderboard list rows ---- */
.lb-list{ display:flex; flex-direction:column; gap:5px; text-align:left; }
.lb-row{ display:flex; align-items:center; gap:10px; padding:8px 11px; border-radius:5px;
  background:linear-gradient(180deg,#2a2217,#1c160e); border:2px solid var(--frame-edge); }
.lb-row.me{ border-color:var(--diamond-deep); box-shadow:0 0 0 1px rgba(43,214,214,.4), inset 0 0 12px rgba(43,214,214,.12); }
.lb-rank{ font-family:var(--f-ui); font-weight:700; font-size:15px; color:var(--gold-bright); width:30px; text-align:center; flex-shrink:0; }
.lb-wallet{ flex:1; font-family:var(--f-ui); font-size:14px; color:var(--bone); letter-spacing:.02em; }
.lb-wallet b{ font-family:var(--f-pixel); font-size:8px; color:var(--diamond-glow); text-transform:uppercase; margin-left:6px; }
.lb-score{ font-family:var(--f-ui); font-weight:700; font-size:16px; color:var(--diamond-glow); }
.lb-empty{ font-family:var(--f-ui); font-size:14px; color:var(--muted); padding:20px 10px; text-align:center; }
.end-lb{ margin-top:2px; }

/* ---- leaderboard overlay ---- */
.lb-panel{ width:min(440px,94vw); position:relative; }
.lb-x{ position:absolute; top:12px; right:12px; width:30px; height:30px; border-radius:50%; cursor:pointer;
  border:2px solid var(--frame-edge); background:#1b150d; color:var(--bone); font-size:13px; line-height:1; }
.lb-tabs{ display:flex; gap:7px; justify-content:center; margin:14px 0 16px; }
.lb-tab{ cursor:pointer; font-family:var(--f-ui); font-weight:600; font-size:13px; color:var(--bone-dim);
  padding:7px 13px; border:2px solid var(--frame-edge); border-radius:20px; background:#1b150d; transition:color .1s, border-color .1s; }
.lb-tab.sel{ color:#2a1a06; background:linear-gradient(180deg,var(--gold-pale),var(--gold)); border-color:var(--frame-edge); }
.lb-note{ font-family:var(--f-ui); font-size:12px; color:var(--muted); margin-top:14px; }

@media (max-width:760px){
  .diff-pill{ order:3; }
  .submit-wrap, .submit-done, .diff-pick{ max-width:100%; }
}

/* =========================================================================
   Endless descent — levels, supply caches, descend overlay
   ========================================================================= */

.hud-stat .val.lv{ color:var(--diamond-glow); }

/* swing-refill pulse on the durability bar */
.dura-fill.refill{ animation:refill-pulse .6s ease; }
@keyframes refill-pulse{ 0%{ filter:brightness(1);} 35%{ filter:brightness(1.9) saturate(1.3);} 100%{ filter:brightness(1);} }

/* cache treasure tiles + list rows get a teal/ember tint to read as "supply" */
.cell.is-cache.collected{ box-shadow:inset 0 0 0 2px rgba(131,194,78,.5); }
.cell.is-cache.collected .gem-slice{ filter:drop-shadow(0 0 6px rgba(131,194,78,.6)); }
.find.is-cache .fn{ color:var(--green); }
.find .fp.swing{ color:var(--green); }
.find.is-cache.got{ background:rgba(131,194,78,.08); }

/* end-screen run meta */
.run-meta{ font-family:var(--f-ui); font-size:15px; color:var(--diamond-glow); margin:2px 0 10px; }
.run-meta b{ color:var(--gold-bright); }

/* descend overlay */
.descend-panel{ width:min(420px,94vw); }
.descend-panel .pic{ height:120px; }
.descend-panel .pic img{ height:120px; }
.dsc-stats{ display:flex; gap:12px; justify-content:center; margin:14px 0 4px; }
.dsc-stat{ flex:1; max-width:150px; padding:11px 8px; border:2px solid var(--frame-edge); border-radius:6px;
  background:linear-gradient(180deg,#2a2217,#1b150d); box-shadow:inset 0 2px 0 rgba(255,255,255,.05);
  display:flex; flex-direction:column; gap:4px; }
.dsc-v{ font-family:var(--f-ui); font-weight:700; font-size:22px; color:var(--gold-bright); line-height:1; }
.dsc-v.gem{ color:var(--diamond-glow); }
.dsc-l{ font-family:var(--f-pixel); font-size:7px; letter-spacing:.05em; color:var(--muted); text-transform:uppercase; }

/* leaderboard level chip */
.lb-lv{ font-family:var(--f-pixel); font-size:8px; letter-spacing:.03em; text-transform:uppercase; color:var(--gold-bright);
  padding:3px 7px; border-radius:10px; background:rgba(245,166,35,.12); border:1px solid var(--frame-edge); white-space:nowrap; }
