/* Tiny Dungeon Rush — chrome ported 1:1 from the Claude Design mockup
   (palette PAL, wooden banners, parchment plaques, Pixelify/VT323). */

@font-face{font-family:'Pixelify Sans';font-weight:400;font-display:swap;
  src:url('fonts/pixelify-400.woff2') format('woff2')}
@font-face{font-family:'Pixelify Sans';font-weight:500;font-display:swap;
  src:url('fonts/pixelify-500.woff2') format('woff2')}
@font-face{font-family:'Pixelify Sans';font-weight:600;font-display:swap;
  src:url('fonts/pixelify-600.woff2') format('woff2')}
@font-face{font-family:'Pixelify Sans';font-weight:700;font-display:swap;
  src:url('fonts/pixelify-700.woff2') format('woff2')}
@font-face{font-family:'VT323';font-weight:400;font-display:swap;
  src:url('fonts/vt323-400.woff2') format('woff2')}

:root{
  --bg:#1a1422; --floor:#2d2438; --floorLight:#3d3450; --wall:#4a3d54;
  --woodDark:#3d2818; --wood:#6e4a2a; --woodLight:#a87a3a;
  --parch:#f0d9a8; --parchDark:#c9a86a; --ink:#2a1f12;
  --hpRed:#c0394a; --hpGreen:#7aab3a; --hpBlue:#5ec8ff;
  --gold:#f5c84a; --ember:#ff8a2a; --ghost:#fff5d6;
  --px:'Pixelify Sans','VT323',monospace;
  --vt:'VT323','Pixelify Sans',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
/* Toolbar popup: Chrome sizes the popup to the document, so the body
   MUST stay a definite 480x600 here (do not use %/vh — it collapses). */
html,body{width:480px;height:600px;margin:0;background:var(--bg);overflow:hidden;
  user-select:none;font-family:var(--px);color:var(--parch)}
img{image-rendering:pixelated;image-rendering:crisp-edges}
#wrap{position:relative;width:480px;height:600px;transform-origin:center center}
#game{display:block;width:480px;height:600px;image-rendering:pixelated}
/* Opened as a real tab/window: fill the whole viewport and center the
   game, scaled as large as it fits (JS fit()). Gate on WIDTH only —
   the toolbar popup is 480px wide so it never matches; a tab is always
   far wider, even when the window is short (the old min-height:680
   trigger failed on laptops, leaving it stuck tiny). The game is a
   480x600 portrait box, so a wide screen keeps themed side margins —
   that's intentional letterboxing, made to look like an arcade frame. */
@media (min-width:620px){
  html,body{width:100vw;height:100vh;display:flex;
    align-items:center;justify-content:center;
    background:
      radial-gradient(ellipse at 50% 38%, #241a30 0%, #140f1c 60%, #0a0710 100%);}
  #wrap{flex:0 0 auto;border-radius:6px;
    box-shadow:0 0 0 3px #0a0710, 0 0 0 6px #2a2238,
      0 22px 60px rgba(0,0,0,.7), 0 0 70px rgba(245,200,74,.10)}
}
.hidden{display:none!important}

/* ===== Wooden banner (recurring surface) ===== */
.banner{position:relative;padding:6px 10px;border-radius:3px;
  background:linear-gradient(to bottom,var(--woodLight) 0%,var(--wood) 35%,var(--wood) 70%,#4a2f1a 100%);
  border:2px solid var(--woodDark);
  box-shadow:0 3px 0 rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.18),inset 0 -2px 0 rgba(0,0,0,.35)}
.banner::before,.banner::after,.banner>.riv{content:""}
.rivet{position:absolute;width:3px;height:3px;background:#1a0f08;border-radius:50%;
  box-shadow:0 1px 0 rgba(255,255,255,.15)}
.rivet.tl{top:2px;left:2px}.rivet.tr{top:2px;right:2px}
.rivet.bl{bottom:2px;left:2px}.rivet.br{bottom:2px;right:2px}

/* ===== HUD ===== */
#hud{position:absolute;top:8px;left:8px;right:8px;z-index:8;
  display:flex;flex-direction:column;gap:6px;pointer-events:none}
/* The floating MENU (top-left) and AUTOPLAY (top-right) buttons are
   pinned at top:8 and used to land right on top of the boss nameplate
   + HP bar. Inset just that first banner so it lives in the gap
   BETWEEN the two buttons (MENU is the narrow one, AUTOPLAY/STOP AUTO
   the wide one — hence the asymmetric margins). The FAITH bar and
   stat row sit lower than the ~31px-tall buttons, so they stay full
   width and are intentionally left alone. */
#hud>.banner:not(.faith){margin:0 132px 0 86px}
.boss-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.boss-name{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;font-family:var(--px);font-weight:700;font-size:12px;
  line-height:1;color:var(--parch);text-shadow:1px 1px 0 #1a0f08;letter-spacing:.04em}
.phase-tag{flex:0 0 auto;font-family:var(--vt);font-size:9px;color:var(--parchDark);letter-spacing:.15em}
.phase-tag b{color:var(--gold);font-size:12px;font-weight:400}
.hpbar{position:relative;background:#1a0f08;border:1px solid #0a0510;
  box-shadow:inset 0 1px 0 rgba(0,0,0,.6);height:10px;margin-top:4px}
.hpbar>i{display:block;height:100%;transition:width .25s}
.hpbar.red>i{background:linear-gradient(to bottom,#ff6a7a 0%,var(--hpRed) 60%,#8a2a3a 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 0 6px #c0394a88}
.hpbar.green>i{background:linear-gradient(to bottom,#a8e065 0%,var(--hpGreen) 60%,#4a7020 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 0 6px #7aab3a88}
.hpbar.xp>i{background:linear-gradient(to bottom,#9be7ff 0%,var(--hpBlue) 55%,#2f6f8c 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 0 6px #5ec8ff88}
.hud-lab b{color:var(--gold);font-weight:700}
.hpbar.gold>i{background:linear-gradient(to bottom,#ffe9a0 0%,var(--gold) 55%,#a9781f 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45),0 0 6px #f5c84a88}
.hud-row{display:flex;gap:6px}
.hud-row .banner{flex:1;display:flex;align-items:center;gap:6px}
/* compact stat strip (replaces the extra bars) */
.mini-row{display:flex;align-items:center;gap:8px;padding:1px 4px}
.mini-row #hearts{display:flex;gap:2px}
.mini-spacer{flex:1}
.mini-stat{display:flex;align-items:center;gap:3px;font-family:var(--px);
  font-weight:700;font-size:13px;color:var(--parch);text-shadow:1px 1px 0 #1a0f08}
.mini-stat b{color:var(--gold)}
.mini-stat .coin-img{width:13px;height:13px;display:block}
#shield-pip{font-size:13px;line-height:1;color:#3a3550;
  text-shadow:1px 1px 0 #0a0510;transition:color .15s}
#shield-pip.up{color:var(--hpBlue);text-shadow:0 0 6px #5ec8ffaa}
.banner.faith{display:flex;align-items:center;gap:7px}
.smite-tag{display:none;font-family:var(--px);font-weight:700;font-size:10px;
  color:var(--ink);letter-spacing:.08em;white-space:nowrap;
  background:linear-gradient(to bottom,#ffe9a0,var(--gold));
  padding:2px 6px;border:1px solid var(--woodDark);border-radius:2px;
  text-shadow:1px 1px 0 rgba(255,255,255,.35)}
.banner.faith.ready{box-shadow:0 3px 0 rgba(0,0,0,.5),
  inset 0 1px 0 rgba(255,255,255,.18),inset 0 -2px 0 rgba(0,0,0,.35),
  0 0 12px #f5c84a99;animation:tbr-faith .7s ease-in-out infinite}
.banner.faith.ready .smite-tag{display:inline-block}
.banner.faith.ready .hpbar.gold>i{box-shadow:inset 0 1px 0 rgba(255,255,255,.6),
  0 0 10px #ffe9a0,0 0 16px #f5c84a}
@keyframes tbr-faith{0%,100%{filter:brightness(1)}50%{filter:brightness(1.18)}}
/* floating in-run autoplay toggle (above all overlays) */
#auto-toggle{position:absolute;top:8px;right:8px;z-index:40;cursor:pointer;
  font-family:var(--px);font-weight:700;font-size:11px;letter-spacing:.1em;
  color:var(--parch);padding:6px 12px;border:2px solid var(--woodDark);border-radius:3px;
  background:linear-gradient(to bottom,var(--woodLight) 0%,var(--wood) 100%);
  text-shadow:1px 1px 0 #1a0f08;
  box-shadow:0 3px 0 rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.25)}
#auto-toggle:hover{filter:brightness(1.12)}
#auto-toggle:active{transform:translateY(2px);box-shadow:0 1px 0 rgba(0,0,0,.5)}
#auto-toggle.on{color:#ffe9a0;border-color:#7a2433;
  background:linear-gradient(to bottom,#c0546a 0%,#7a2433 100%);
  box-shadow:0 3px 0 rgba(0,0,0,.5),0 0 10px #c0546a88}
#auto-toggle.hidden{display:none!important}
/* floating in-run "to main menu" button (mirrors auto-toggle, top-left) */
#to-menu{position:absolute;top:8px;left:8px;z-index:40;cursor:pointer;
  font-family:var(--px);font-weight:700;font-size:11px;letter-spacing:.1em;
  color:var(--parch);padding:6px 11px;border:2px solid var(--woodDark);border-radius:3px;
  background:linear-gradient(to bottom,var(--woodLight) 0%,var(--wood) 100%);
  text-shadow:1px 1px 0 #1a0f08;
  box-shadow:0 3px 0 rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.25)}
#to-menu:hover{filter:brightness(1.12)}
#to-menu:active{transform:translateY(2px);box-shadow:0 1px 0 rgba(0,0,0,.5)}
#to-menu.hidden{display:none!important}
/* character shown on the menu, below the title */
#menu-char{width:96px;height:96px;display:block;margin:2px auto 0;
  filter:drop-shadow(0 6px 0 rgba(0,0,0,.45));animation:tbr-bob 1.6s ease-in-out infinite}
@keyframes tbr-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.hud-lab{font-family:var(--vt);font-size:10px;color:var(--parchDark);letter-spacing:.15em}
#hearts{display:flex;gap:2px}
.heart{font-size:11px;line-height:1;color:var(--hpRed);text-shadow:1px 1px 0 #0a0510}
.heart.empty{color:#3a2825}
.coin-banner{flex:0 0 auto!important;padding:6px 8px!important}
.coin-img{width:14px;height:14px;display:block}
.coin-n{font-family:var(--px);font-weight:700;font-size:15px;color:var(--gold);
  text-shadow:1px 1px 0 #1a0f08;line-height:1}

/* ===== Screens ===== */
.screen{position:absolute;inset:0;z-index:20;animation:fade .25s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.scrim{position:absolute;inset:0;background:rgba(10,6,16,.55)}

/* Title plaque */
.plaque{position:absolute;left:0;right:0;top:248px;text-align:center;z-index:7;
  animation:tbr-title 2.6s ease-in-out infinite}
.plaque-in{display:inline-block;padding:12px 24px;border-radius:4px;
  background:linear-gradient(to bottom,var(--parch) 0%,var(--parchDark) 100%);
  border:3px solid var(--woodDark);transform:rotate(-1.5deg);
  box-shadow:0 5px 0 rgba(0,0,0,.5),inset 0 2px 0 rgba(255,255,255,.4)}
.t-top{font-family:var(--px);font-weight:700;color:var(--ink);font-size:38px;
  line-height:1;letter-spacing:.03em;text-shadow:2px 2px 0 var(--woodLight),3px 3px 0 var(--woodDark)}
.t-bot{font-family:var(--px);font-weight:700;color:var(--hpRed);font-size:54px;
  line-height:1;letter-spacing:.05em;margin-top:2px;text-shadow:2px 2px 0 var(--ink),4px 4px 0 var(--woodDark)}
.t-ver{margin-top:6px;font-family:var(--vt);font-size:13px;color:var(--parchDark);letter-spacing:.3em}

/* Buttons */
.btns{position:absolute;left:0;right:0;z-index:7;display:flex;
  flex-direction:column;align-items:center;gap:10px}
.btn{font-family:var(--px);font-weight:700;font-size:17px;letter-spacing:.18em;
  min-width:220px;padding:10px 24px;border:2px solid var(--woodDark);border-radius:3px;
  cursor:pointer;color:var(--parch);
  background:linear-gradient(to bottom,var(--woodLight) 0%,var(--wood) 100%);
  text-shadow:1px 1px 0 var(--ink);
  box-shadow:0 4px 0 rgba(0,0,0,.55),inset 0 2px 0 rgba(255,255,255,.3),inset 0 -2px 0 rgba(0,0,0,.3);
  transition:transform .07s}
.btn:hover{filter:brightness(1.08)}
.btn:active{transform:translateY(3px);box-shadow:0 1px 0 rgba(0,0,0,.55),inset 0 2px 0 rgba(255,255,255,.3)}
.btn.primary{color:var(--ink);text-shadow:1px 1px 0 rgba(255,255,255,.3);
  background:linear-gradient(to bottom,var(--gold) 0%,#c8932a 100%)}
.btn.small{min-width:158px;font-size:13px;padding:8px 14px;letter-spacing:.12em}
.btn.on{color:var(--ink);text-shadow:1px 1px 0 rgba(255,255,255,.3);
  background:linear-gradient(to bottom,#7be08a 0%,#3f8a3a 100%);
  box-shadow:0 4px 0 rgba(0,0,0,.55),inset 0 2px 0 rgba(255,255,255,.35),0 0 14px #7be08a66}

/* Menu = one centered column so the title + buttons can never overlap */
/* Lighter scrim so the dungeon scene + character behind stay visible */
#screen-menu{display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:12px;padding:18px 0;
  background:linear-gradient(to bottom,rgba(10,6,16,.12),
    rgba(10,6,16,.34) 55%,rgba(10,6,16,.55))}
/* small, unobtrusive quit */
#btn-quit{min-width:0;font-size:10px;letter-spacing:.1em;
  padding:5px 12px;opacity:.7;box-shadow:0 2px 0 rgba(0,0,0,.5)}
#btn-quit:hover{opacity:1}
#screen-menu .plaque{position:static;left:auto;right:auto;top:auto}
#screen-menu .actcol{position:static;left:auto;right:auto;bottom:auto;
  background:none;padding:0;gap:9px}

/* Bottom-anchored action column (game over) — no overlap, ever */
.actcol{position:absolute;left:0;right:0;bottom:0;z-index:7;display:flex;
  flex-direction:column;align-items:center;gap:9px;padding:14px 0 16px;
  background:linear-gradient(to bottom,transparent 0%,rgba(10,6,16,.35) 24%,
    rgba(10,6,16,.74) 60%,rgba(10,6,16,.86) 100%)}
.actcol.over{gap:8px}
.brow{display:flex;gap:10px}
.foot2{display:flex;justify-content:space-between;width:300px;margin-top:2px;
  font-family:var(--vt);font-size:11px;color:var(--parchDark);letter-spacing:.1em}
.actcol .over-title{position:static;left:auto;right:auto;top:auto;
  font-size:42px;margin-bottom:2px}
.actcol .scroll{position:static;left:auto;right:auto;top:auto;width:320px;margin-bottom:2px}
.foot{position:absolute;left:0;right:0;bottom:16px;z-index:7;display:flex;
  justify-content:space-between;padding:0 18px;font-family:var(--vt);
  font-size:12px;color:var(--parchDark);letter-spacing:.18em}
.bmc{display:block;text-align:center;font-family:var(--vt);font-size:12px;
  color:var(--parchDark);letter-spacing:.2em;text-decoration:none}
.bmc:hover{color:var(--gold)}

/* Game over */
.over-title{position:absolute;left:0;right:0;top:300px;text-align:center;z-index:7;
  font-family:var(--px);font-weight:700;font-size:52px;line-height:1;letter-spacing:.1em}
.over-title.win{color:var(--gold);text-shadow:3px 3px 0 var(--ink),5px 5px 0 rgba(0,0,0,.5),0 0 18px #f5c84a88}
.over-title.lose{color:var(--hpRed);text-shadow:3px 3px 0 var(--ink),5px 5px 0 rgba(0,0,0,.5),0 0 18px #c0394a88}
.scroll{position:absolute;left:70px;right:70px;top:380px;z-index:7;padding:12px 18px;border-radius:4px;
  background:linear-gradient(to bottom,var(--parch) 0%,var(--parchDark) 100%);
  border:2px solid var(--woodDark);box-shadow:0 5px 0 rgba(0,0,0,.5),inset 0 2px 0 rgba(255,255,255,.3)}
.stat{display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--vt);font-size:14px;color:var(--ink);letter-spacing:.15em;
  padding:3px 0;border-bottom:1px dashed rgba(61,40,24,.27)}
.stat span{opacity:.75}
.stat b{font-family:var(--px);font-size:17px;font-weight:700;color:var(--hpRed)}

/* Shop */
.shop-title{position:absolute;top:14px;left:12px;right:12px;z-index:7;text-align:center}
.shop-title .banner{padding:8px 12px}
.shop-h{font-family:var(--px);font-weight:700;font-size:22px;color:var(--gold);
  letter-spacing:.15em;text-shadow:2px 2px 0 var(--ink)}
.shop-sub{margin-top:2px;display:flex;justify-content:center;align-items:center;gap:6px;
  font-family:var(--vt);font-size:14px;color:var(--parch);letter-spacing:.2em}
.shop-sub b{color:var(--gold);font-size:16px;font-weight:700}
.shop-tabs{position:absolute;top:88px;left:18px;right:18px;z-index:8;
  display:flex;gap:8px;justify-content:center}
.shop-tab{flex:1;max-width:150px;cursor:pointer;font-family:var(--px);font-weight:700;
  font-size:12px;letter-spacing:.12em;color:var(--parchDark);padding:6px 10px;
  border:2px solid var(--woodDark);border-radius:3px;
  background:linear-gradient(to bottom,#2a2238,#1a1426);
  box-shadow:0 2px 0 rgba(0,0,0,.5)}
.shop-tab:hover{filter:brightness(1.15)}
.shop-tab.on{color:var(--ink);
  background:linear-gradient(to bottom,var(--gold) 0%,#c8932a 100%);
  box-shadow:0 2px 0 rgba(0,0,0,.5),0 0 10px #f5c84a66}
#shop-list{position:absolute;top:124px;left:18px;right:18px;bottom:64px;z-index:7;
  display:flex;flex-direction:column;gap:8px;overflow-y:auto}
.shop-item{display:grid;grid-template-columns:36px 1fr auto auto;align-items:center;gap:10px;
  padding:8px 10px;border-radius:3px;background:rgba(20,12,28,.85);
  border:2px solid var(--woodDark);box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 2px 0 rgba(0,0,0,.4)}
.shop-item img{width:28px;height:28px;display:block;margin:0 auto}
.si-name{font-family:var(--px);font-weight:700;font-size:14px;color:var(--parch);letter-spacing:.1em}
.si-tag{font-family:var(--vt);font-size:10px;letter-spacing:.12em;color:var(--parchDark);
  vertical-align:middle;margin-left:5px}
.shop-item:has(.si-buy.maxed) .si-tag{color:var(--gold)}
.si-desc{font-family:var(--vt);font-size:12px;color:var(--gold);letter-spacing:.06em;
  margin-top:2px;opacity:.92}
/* Skin ability — every skin has one; make it impossible to miss */
.si-ability{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:3px;
  padding:3px 6px;border-left:3px solid var(--gold);border-radius:2px;
  background:linear-gradient(to right,rgba(245,200,74,.16),rgba(245,200,74,.04))}
.si-ab-tag{flex:0 0 auto;font-family:var(--px);font-weight:700;font-size:9px;
  letter-spacing:.1em;color:var(--ink);background:linear-gradient(to bottom,#ffe9a0,var(--gold));
  padding:2px 5px;border-radius:2px;text-shadow:1px 1px 0 rgba(255,255,255,.35)}
.si-ab-txt{font-family:var(--vt);font-size:12px;color:var(--gold);letter-spacing:.05em}
.si-dots{display:flex;gap:2px;margin-top:3px}
.si-dots i{width:14px;height:4px;background:#3a2825;display:block}
.si-dots i.on{background:var(--gold);box-shadow:0 0 4px #f5c84a88}
.si-cost{display:flex;align-items:center;gap:4px;font-family:var(--px);
  font-weight:700;font-size:14px;color:var(--gold)}
.si-cost img{width:12px;height:12px}
.si-buy{font-family:var(--px);font-weight:700;font-size:11px;letter-spacing:.15em;
  padding:6px 10px;border:1.5px solid var(--woodDark);cursor:pointer;color:var(--parch);
  background:linear-gradient(to bottom,var(--hpGreen) 0%,#4a7020 100%);
  text-shadow:1px 1px 0 var(--ink);box-shadow:0 3px 0 rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.3)}
.si-buy:disabled{background:linear-gradient(to bottom,#5a5550,#3a3530);
  color:#8a8378;cursor:not-allowed;box-shadow:0 2px 0 rgba(0,0,0,.4)}
.si-buy.maxed{background:linear-gradient(to bottom,var(--gold),#c8932a);color:var(--ink)}
.shop-back{position:absolute;left:0;right:0;bottom:22px;z-index:7;text-align:center}

@keyframes tbr-title{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
#shop-list::-webkit-scrollbar{width:6px}
#shop-list::-webkit-scrollbar-thumb{background:var(--woodDark)}

/* ===== Level-up: choose a blessing ===== */
#screen-level,#screen-spoils{display:flex;align-items:center;justify-content:center;
  padding:0 16px;background:linear-gradient(to bottom,rgba(10,6,16,.82),rgba(10,6,16,.96))}
.level-wrap{width:100%;max-width:360px;margin:0 auto;display:flex;
  flex-direction:column;align-items:center;gap:10px;text-align:center}
.level-title{font-family:var(--px);font-weight:700;font-size:30px;color:var(--gold);
  letter-spacing:.12em;text-shadow:2px 2px 0 var(--ink),0 0 14px #f5c84a66}
.level-title b{color:var(--parch)}
.level-sub{font-family:var(--vt);font-size:15px;color:var(--parchDark);letter-spacing:.22em}
#perk-cards{display:flex;flex-direction:column;gap:9px;width:100%;margin-top:4px}
.perk-card{display:flex;align-items:center;gap:10px;width:100%;cursor:pointer;
  padding:11px 13px;border-radius:4px;text-align:left;
  background:linear-gradient(to bottom,var(--parch) 0%,var(--parchDark) 100%);
  border:3px solid var(--woodDark);
  box-shadow:0 4px 0 rgba(0,0,0,.5),inset 0 2px 0 rgba(255,255,255,.35);
  transition:transform .08s,filter .12s}
.perk-card:hover{filter:brightness(1.06);transform:translateY(-1px)}
.perk-card:active{transform:translateY(2px);box-shadow:0 2px 0 rgba(0,0,0,.5)}
.pk-key{flex:0 0 22px;height:22px;display:flex;align-items:center;justify-content:center;
  font-family:var(--px);font-weight:700;font-size:13px;color:var(--parch);
  background:var(--woodDark);border-radius:3px}
.pk-name{font-family:var(--px);font-weight:700;font-size:15px;color:var(--ink);
  letter-spacing:.06em;flex:0 0 auto}
.pk-desc{font-family:var(--vt);font-size:14px;color:#5a4a2a;letter-spacing:.04em;
  margin-left:auto;text-align:right}
.level-hint{font-family:var(--vt);font-size:12px;color:var(--parchDark);
  letter-spacing:.18em;margin-top:4px}
.hint1{font-family:var(--vt);font-size:12px;color:var(--parchDark);
  letter-spacing:.12em;text-align:center;opacity:.8;margin:2px 0}

/* ===== Ability charge bar (HUD) =====
   Fixed 6-column grid so the cells ALWAYS fit the 480px popup and can
   never wrap or run off-screen (the old flex-wrap did both). Each cell
   wears its ability colour on the top edge so the row reads as an
   intentional, tidy strip rather than a stack of mismatched boxes. */
.ability-bar{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;
  padding:2px 4px;margin-top:2px;pointer-events:none}
.ab-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-width:0;padding:3px 2px;border:2px solid var(--woodDark);
  border-top:2px solid var(--ability,#fff5);border-radius:3px;
  background:linear-gradient(to bottom,#241a30,#140f1c);
  font-family:var(--vt);font-size:9px;letter-spacing:.05em;color:var(--parchDark);
  text-align:center;overflow:hidden;transition:filter .12s,box-shadow .12s}
.ab-cell.live{box-shadow:0 0 8px var(--ability,#fff5)}
.ab-cell.dim{filter:grayscale(.7) brightness(.6);opacity:.5}
.ab-key{font-family:var(--px);font-weight:700;font-size:11px;color:var(--gold);
  line-height:1;letter-spacing:.04em}
.ab-name{font-family:var(--px);font-weight:700;font-size:8px;line-height:1.05;
  letter-spacing:.02em;color:var(--parch);margin-top:2px;
  max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* shared rune-charge counter pip (sits in the stat row by gold/level) */
.rune-stat .rune-glyph{font-size:12px;line-height:1;color:var(--hpBlue);
  text-shadow:0 0 6px #5ec8ff88}
.rune-stat b{color:var(--hpBlue)}
.rune-stat.empty{opacity:.5}
.rune-stat.empty .rune-glyph{color:#3a3550;text-shadow:none}

/* ===== Signature power badge (HUD) =====
   ONE power per equipped skin, cast with E. Replaces the 6-cell bar so
   the top is far less cluttered; the badge wears the power's colour. */
.sig-power{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;
  margin-top:3px;padding:3px 10px 3px 3px;border-radius:4px;pointer-events:none;
  border:2px solid var(--woodDark);border-left:4px solid var(--ability,var(--gold));
  background:linear-gradient(to bottom,var(--woodLight) 0%,var(--wood) 100%);
  box-shadow:0 3px 0 rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.18)}
.sig-power.empty{filter:grayscale(.55) brightness(.72);opacity:.75}
.sig-power.ready{box-shadow:0 3px 0 rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.18),
  0 0 12px var(--ability,#f5c84a);animat