:root{
  --parch:#e8d4a8;
  --parch-dk:#cdb178;
  --wood:#5a3a22;
  --wood-dk:#3a2414;
  --ink:#2a1c10;
  --gold:#e0b04a;
  --blood:#9a3326;
  --sea:#123040;
  --good:#3a9d6a;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;width:100%;overflow:hidden;background:#0a1418;
  font-family:"Trebuchet MS","Segoe UI",system-ui,sans-serif;color:var(--ink);
  user-select:none;-webkit-user-select:none;touch-action:none;}
.hidden{display:none!important;}
.screen{position:fixed;inset:0;}

/* ---------- HUB ---------- */
.hub{display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.06), transparent 60%),
    repeating-linear-gradient(45deg,#34200f 0 14px,#3c2613 14px 28px);
  padding:20px;}
.hub-panel{
  width:min(760px,94vw);max-height:94vh;overflow:auto;
  background:
    radial-gradient(circle at 80% 0%, rgba(255,255,255,.18), transparent 50%),
    linear-gradient(160deg,var(--parch),var(--parch-dk));
  border:6px solid var(--wood);border-radius:14px;
  box-shadow:0 18px 50px rgba(0,0,0,.6),inset 0 0 60px rgba(120,80,30,.25);
  padding:30px 34px 22px;}
.hub-title{font-size:clamp(30px,6vw,52px);letter-spacing:2px;color:var(--wood-dk);
  text-shadow:1px 1px 0 rgba(255,255,255,.4);text-align:center;}
.hub-sub{text-align:center;margin:8px 0 22px;font-style:italic;color:#5a4326;}
.game-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;}
.game-card{cursor:pointer;border:3px solid var(--wood);border-radius:10px;
  background:linear-gradient(160deg,#f1e0b8,#d8bd86);padding:14px;
  transition:transform .12s,box-shadow .12s;position:relative;overflow:hidden;}
.game-card:hover{transform:translateY(-3px);box-shadow:0 8px 22px rgba(0,0,0,.4);}
.game-card.locked{opacity:.5;cursor:not-allowed;}
.game-card h3{font-size:20px;color:var(--wood-dk);margin-bottom:6px;}
.game-card p{font-size:13px;color:#574021;line-height:1.35;}
.card-art{height:84px;border-radius:6px;margin-bottom:10px;
  background:linear-gradient(180deg,#1d4a5e,#0c2230);position:relative;overflow:hidden;border:2px solid var(--wood-dk);}
.hub-foot{margin-top:18px;text-align:center;font-size:12px;color:#6b5230;font-style:italic;}

/* ---------- GAME ROOT ---------- */
.game-root{background:#06121a;}
#game{display:block;width:100%;height:100%;}

.hub-btn{position:fixed;top:8px;right:8px;z-index:30;
  background:linear-gradient(180deg,var(--parch),var(--parch-dk));
  border:2px solid var(--wood);color:var(--wood-dk);font-weight:bold;
  padding:6px 12px;border-radius:8px;cursor:pointer;font-size:14px;}
.hub-btn:hover{filter:brightness(1.08);}

/* ---------- OVERLAY (menus/cards/shop/end) ---------- */
.overlay{position:fixed;inset:0;z-index:20;display:flex;align-items:center;justify-content:center;
  pointer-events:none;}
.overlay.active{pointer-events:auto;background:rgba(4,12,18,.62);backdrop-filter:blur(2px);}
.overlay:empty{display:none;}
.panel{
  width:min(820px,94vw);max-height:92vh;overflow:auto;
  background:linear-gradient(160deg,var(--parch),var(--parch-dk));
  border:6px solid var(--wood);border-radius:14px;padding:22px 26px;
  box-shadow:0 18px 50px rgba(0,0,0,.7),inset 0 0 50px rgba(120,80,30,.25);
  pointer-events:auto;}
.panel h2{color:var(--wood-dk);font-size:clamp(22px,4vw,34px);text-align:center;
  letter-spacing:1px;margin-bottom:4px;text-shadow:1px 1px 0 rgba(255,255,255,.35);}
.panel .lead{text-align:center;font-style:italic;color:#5a4326;margin-bottom:16px;}
.row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;}
.section-label{font-weight:bold;color:var(--wood-dk);margin:14px 0 8px;text-transform:uppercase;
  font-size:13px;letter-spacing:1px;border-bottom:2px solid var(--wood);padding-bottom:3px;}

.choice{cursor:pointer;border:3px solid var(--wood);border-radius:9px;
  background:linear-gradient(160deg,#f1e0b8,#d8bd86);padding:10px 12px;min-width:150px;
  flex:1 1 160px;max-width:230px;transition:transform .1s,box-shadow .1s;}
.choice:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.35);}
.choice.selected{outline:3px solid var(--gold);background:linear-gradient(160deg,#fff0c8,#e8cf90);}
.choice h4{color:var(--wood-dk);font-size:16px;margin-bottom:4px;}
.choice .small{font-size:12px;color:#5a4326;line-height:1.35;}
.choice .rarity{display:inline-block;font-size:10px;font-weight:bold;padding:1px 6px;border-radius:6px;margin-bottom:5px;color:#fff;}
.r-common{background:#6b7280;}.r-rare{background:#2f6fb0;}.r-epic{background:#7a3fb0;}.r-cursed{background:#9a3326;}

.btn{cursor:pointer;border:3px solid var(--wood-dk);border-radius:9px;
  background:linear-gradient(180deg,#caa24a,#a87f2c);color:#2a1c08;font-weight:bold;
  padding:11px 20px;font-size:16px;letter-spacing:.5px;transition:filter .1s,transform .1s;}
.btn:hover{filter:brightness(1.1);}
.btn:active{transform:translateY(1px);}
.btn.secondary{background:linear-gradient(180deg,#d8bd86,#bb9c5e);color:var(--wood-dk);}
.btn.danger{background:linear-gradient(180deg,#c0503e,#8f2d20);color:#fff;}
.btn:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.4);}
.btn-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:18px;}

.shop-item{display:flex;justify-content:space-between;align-items:center;gap:10px;
  border:2px solid var(--wood);border-radius:8px;background:rgba(255,255,255,.25);
  padding:8px 12px;margin-bottom:8px;}
.shop-item .desc{flex:1;}.shop-item h4{color:var(--wood-dk);font-size:15px;}
.shop-item .small{font-size:12px;color:#5a4326;}
.cost{font-weight:bold;color:var(--blood);white-space:nowrap;}

.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 18px;margin:10px 0;}
.stats-grid .s-row{display:flex;justify-content:space-between;border-bottom:1px dotted #8a6c3a;padding:3px 0;font-size:14px;}
.stats-grid .s-row b{color:var(--wood-dk);}

.best-banner{text-align:center;background:var(--gold);color:#2a1c08;font-weight:bold;
  border-radius:8px;padding:6px;margin-bottom:10px;border:2px solid var(--wood-dk);}

/* ---------- TOUCH CONTROLS ---------- */
.touch-controls{position:fixed;inset:0;z-index:15;pointer-events:none;}
.joy-zone{position:absolute;left:0;bottom:0;width:46%;height:42%;pointer-events:auto;}
.joy-base{position:absolute;width:120px;height:120px;border-radius:50%;
  border:3px solid rgba(232,212,168,.5);background:rgba(20,40,55,.4);
  left:40px;bottom:40px;display:none;}
.joy-stick{position:absolute;width:54px;height:54px;border-radius:50%;left:33px;top:33px;
  background:radial-gradient(circle at 35% 30%,#f0dca8,#b88f3a);border:2px solid var(--wood-dk);}
.ability-btn{position:absolute;right:30px;bottom:46px;width:96px;height:96px;border-radius:50%;
  pointer-events:auto;background:radial-gradient(circle at 35% 30%,#caa24a,#8f2d20);
  border:4px solid var(--wood-dk);color:#fff;font-weight:bold;font-size:14px;letter-spacing:1px;
  box-shadow:0 4px 14px rgba(0,0,0,.5);}
.ability-btn:active{filter:brightness(1.2);}
.ability-btn.cooling{opacity:.45;}

/* HUD is drawn on canvas; this just keeps DOM minimal */
@media (max-width:560px){
  .panel{padding:16px 14px;}
  .choice{min-width:120px;flex-basis:130px;}
}
