@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=VT323&display=swap');

:root{
  --wood:#7a4a23; --wood2:#5e3717; --cream:#fff6e0; --grass:#7ec850; --grass2:#69b545;
  --sky:#bfe9ff; --gold:#ffcf48; --ink:#2b2118; --panel:rgba(38,26,15,.86); --line:#caa15e;
  --green:#5bbf5b; --blue:#5b8cff; --purple:#c061ff; --red:#e0664f;
  --px:'Press Start 2P',monospace; --read:'VT323',monospace;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;background:#3a6b2a;font-family:var(--read);color:var(--cream);touch-action:none}
#game{position:fixed;inset:0}
canvas{display:block;image-rendering:pixelated}

/* ---------- HUD ---------- */
.hud{position:fixed;inset:0;pointer-events:none;z-index:10}
.hud > *{pointer-events:auto}
.panel{background:var(--panel);border:3px solid var(--line);border-radius:10px;box-shadow:0 4px 0 rgba(0,0,0,.35),inset 0 0 0 2px rgba(0,0,0,.25)}
.px{font-family:var(--px)}

/* top bar */
.topbar{position:fixed;top:10px;left:10px;right:10px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:8px;padding:8px 12px}
.brand .logo{width:26px;height:26px;background:var(--gold);border:2px solid var(--wood2);border-radius:6px;display:grid;place-items:center;font-size:14px}
.brand h1{font-family:var(--px);font-size:11px;color:var(--gold);letter-spacing:1px;text-shadow:1px 1px 0 var(--wood2)}
.spacer{flex:1}
.pill{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:18px}
.pill .tier{font-family:var(--px);font-size:8px;padding:3px 6px;border-radius:5px;background:var(--green);color:#06210a}
.btn{font-family:var(--px);font-size:9px;color:var(--ink);background:var(--gold);border:3px solid var(--wood2);border-radius:8px;padding:9px 12px;cursor:pointer;box-shadow:0 3px 0 var(--wood2);transition:transform .05s}
.btn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--wood2)}
.btn.ghost{background:var(--cream);color:var(--ink)}
.iconbtn{width:42px;height:42px;display:grid;place-items:center;font-size:20px;cursor:pointer}

/* modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;align-items:center;justify-content:center;z-index:20;padding:18px}
.modal.show{display:flex}
.modal .box{width:100%;max-width:380px;padding:20px;max-height:90vh;overflow-y:auto}
.modal h2{font-family:var(--px);font-size:12px;color:var(--gold);margin-bottom:14px;text-align:center}
.wbtn{display:flex;align-items:center;gap:12px;width:100%;background:var(--cream);color:var(--ink);border:3px solid var(--line);border-radius:10px;padding:12px;margin-bottom:10px;cursor:pointer;font-size:20px}
.wbtn:active{transform:translateY(2px)}
.wbtn img{width:30px;height:30px;border-radius:6px}
.wbtn .sub{font-size:13px;color:#8a7a55;display:block;font-family:var(--read)}
.close{position:absolute;top:8px;right:12px;font-family:var(--px);font-size:12px;color:var(--cream);cursor:pointer}
.note{font-size:15px;color:#d9c9a3;text-align:center;margin-top:6px;line-height:1.3}

/* customize panel */
.cust{position:fixed;right:10px;top:64px;width:230px;padding:14px;display:none}
.cust.show{display:block}
.cust h3{font-family:var(--px);font-size:9px;color:var(--gold);margin-bottom:10px}
.row{margin-bottom:12px}
.row .lbl{font-size:15px;color:#e7d7af;margin-bottom:5px;text-transform:uppercase;letter-spacing:1px}
.swatches{display:flex;gap:6px;flex-wrap:wrap}
.sw{width:26px;height:26px;border-radius:6px;border:3px solid rgba(0,0,0,.3);cursor:pointer}
.sw.sel{border-color:#fff;box-shadow:0 0 0 2px var(--gold)}
.locked{opacity:.45;filter:grayscale(.6);position:relative}
.locked::after{content:'🔒';position:absolute;inset:0;display:grid;place-items:center;font-size:14px}

/* settings */
.settings{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:300px;padding:18px;display:none;z-index:21}
.settings.show{display:block}
.settings h3{font-family:var(--px);font-size:11px;color:var(--gold);margin-bottom:14px;text-align:center}
.srow{display:flex;align-items:center;justify-content:space-between;font-size:18px;margin-bottom:12px}
.toggle{width:48px;height:26px;background:#3a2a18;border:2px solid var(--line);border-radius:14px;position:relative;cursor:pointer}
.toggle.on{background:var(--green)}
.toggle .k{position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--cream);border-radius:50%;transition:left .12s}
.toggle.on .k{left:24px}

/* mobile joystick */
#joy{position:fixed;left:24px;bottom:24px;width:120px;height:120px;border-radius:50%;background:rgba(0,0,0,.25);border:3px solid rgba(255,255,255,.35);display:none;z-index:15;touch-action:none}
#joy .stick{position:absolute;left:35px;top:35px;width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.7);border:2px solid var(--wood2)}
body.touch #joy{display:block}

/* toast */
#toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:var(--panel);border:3px solid var(--line);border-radius:10px;padding:10px 16px;font-size:17px;color:var(--cream);z-index:30;opacity:0;transition:opacity .2s;pointer-events:none;max-width:90vw;text-align:center}
#toast.show{opacity:1}

@media (max-width:560px){
  .brand h1{font-size:9px}.brand{padding:6px 9px}
  .pill{font-size:15px;padding:6px 9px}.btn{font-size:8px;padding:8px 9px}
  .cust{width:200px;top:60px;right:8px}
  .iconbtn{width:38px;height:38px}
}
/* loading */
#load{position:fixed;inset:0;background:#3a6b2a;display:grid;place-items:center;z-index:40;color:var(--cream)}
#load .l{font-family:var(--px);font-size:12px;color:var(--gold);text-align:center;line-height:2}

/* bottom HUD bar */
.bottombar{position:fixed;left:0;right:0;bottom:16px;display:flex;align-items:flex-end;justify-content:space-between;padding:0 16px;gap:10px;z-index:14;pointer-events:none}
.bpanel{pointer-events:auto;background:var(--panel);border:3px solid var(--line);border-radius:12px;box-shadow:0 4px 0 rgba(0,0,0,.25)}
.bleft{display:flex;align-items:center;gap:10px;padding:8px 12px 8px 8px}
.bleft .avatar{width:42px;height:42px;border-radius:9px;background:var(--green);display:grid;place-items:center;font-size:24px;border:2px solid var(--wood2)}
.binfo .bname{font-family:var(--px);font-size:9px;color:var(--gold);margin-bottom:4px}
.binfo .btierTxt{font-size:13px;color:#e7d7af;text-transform:uppercase;letter-spacing:1px}
.bmid{display:flex;gap:6px;padding:8px 10px;border-radius:14px}
.emote{width:42px;height:42px;border-radius:10px;border:2px solid var(--line);background:#2c1f12;font-size:22px;cursor:pointer;transition:transform .08s,background .12s}
.emote:hover{background:#3a2a18}.emote:active{transform:scale(.86)}
.bright{display:flex;gap:6px;padding:8px 10px}
.menub{width:46px;height:46px;border-radius:11px;border:2px solid var(--line);background:#2c1f12;font-size:22px;cursor:pointer;transition:transform .08s,background .12s}
.menub:hover{background:#3a2a18}.menub:active{transform:scale(.9)}
.menub.act{background:var(--green);border-color:var(--gold)}

@media (max-width:560px){
  .bottombar{bottom:12px;padding:0 10px}
  .bmid{gap:4px;padding:6px}.emote{width:36px;height:36px;font-size:18px}
  .menub{width:40px;height:40px;font-size:18px}
  .binfo .bname{font-size:8px}.binfo .btierTxt{font-size:11px}
}
/* on touch the joystick owns bottom-left → hide the profile panel there */
body.touch .bleft{display:none}
