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

:root{
  --crema:#f5e7c4;
  --crema2:#ead7a8;
  --oro:#e8b84b;
  --oro-osc:#b8862c;
  --marron:#3a2a18;
  --verde:#5a8f3c;
  --rojo:#c0392b;
  --azul:#2e6a9e;
  --panel:#2b2118;
  --tinta:#1c140c;
}
*{box-sizing:border-box; -webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;background:#1c140c;color:#fff;
  font-family:'Press Start 2P', monospace;
  image-rendering:pixelated;}
body{display:flex;flex-direction:column;align-items:center;min-height:100vh;
  background:
    repeating-conic-gradient(#241a10 0% 25%, #2c2114 0% 50%) 0 0 / 64px 64px;
}
#game{width:100%;max-width:960px;margin:0 auto;padding:10px;}
.screen{display:none;}
.screen.active{display:block;animation:fadein .35s ease;}
@keyframes fadein{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

.panel{background:var(--panel);border:4px solid var(--oro);
  box-shadow:0 0 0 4px var(--tinta),0 8px 0 4px rgba(0,0,0,.4);
  padding:18px;border-radius:6px;}
h1,h2,h3{line-height:1.5;margin:0 0 14px;}
h1{font-size:20px;color:var(--oro);text-shadow:3px 3px 0 #000;text-align:center;}
h2{font-size:14px;color:var(--oro);text-shadow:2px 2px 0 #000;}
h3{font-size:11px;color:#ffe9b0;}
p{font-size:10px;line-height:1.9;color:#f3e7cf;}
.small{font-size:8px;line-height:1.8;color:#cdb48f;}

/* botones (sirve para <button> y para <a>) */
.btn{font-family:inherit;cursor:pointer;font-size:11px;color:#fff;
  display:inline-block;text-decoration:none;text-align:center;
  background:var(--verde);border:3px solid #2f5a22;
  box-shadow:0 4px 0 #1f3a16, inset 0 0 0 2px rgba(255,255,255,.15);
  padding:12px 16px;border-radius:4px;margin:6px;transition:transform .05s;}
.btn:hover{filter:brightness(1.1);}
.btn:active{transform:translateY(3px);box-shadow:0 1px 0 #1f3a16;}
.btn.oro{background:var(--oro);border-color:var(--oro-osc);box-shadow:0 4px 0 #7a5a1c;color:#3a2a10;}
.btn.azul{background:var(--azul);border-color:#1d486e;box-shadow:0 4px 0 #143147;}
.btn.rojo{background:var(--rojo);border-color:#7d271d;box-shadow:0 4px 0 #5d1c14;}
.btn:disabled{filter:grayscale(.7) brightness(.7);cursor:not-allowed;}

.center{text-align:center;}
.row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;}

/* ---------- mapa ---------- */
#mapWrap{position:relative;}
canvas{image-rendering:pixelated;max-width:100%;height:auto;display:block;margin:0 auto;
  border:4px solid var(--oro);box-shadow:0 0 0 4px var(--tinta);border-radius:4px;background:#bfe0a0;}
#mapHud{display:flex;justify-content:space-between;align-items:center;margin:10px 2px;flex-wrap:wrap;gap:8px;}
.badge{background:var(--tinta);border:2px solid var(--oro);padding:8px 10px;border-radius:4px;font-size:9px;color:var(--oro);}

/* ---------- minijuegos ---------- */
.opt{font-family:inherit;cursor:pointer;font-size:13px;color:#3a2a10;
  background:var(--crema);border:3px solid var(--oro-osc);
  box-shadow:0 4px 0 #9a7424;padding:14px;border-radius:6px;min-width:90px;
  transition:transform .05s;}
.opt:hover{filter:brightness(1.05);}
.opt:active{transform:translateY(3px);box-shadow:0 1px 0 #9a7424;}
.opt.good{background:var(--verde);color:#fff;border-color:#2f5a22;box-shadow:0 4px 0 #1f3a16;}
.opt.bad{background:var(--rojo);color:#fff;border-color:#7d271d;box-shadow:0 4px 0 #5d1c14;}
.qbox{background:var(--tinta);border:3px solid var(--oro);border-radius:6px;padding:16px;margin:12px 0;text-align:center;}
.qtext{font-size:15px;color:#ffe9b0;line-height:1.7;}
.feedback{font-size:11px;min-height:22px;margin:10px 0;text-align:center;}
.stars{font-size:14px;letter-spacing:3px;text-align:center;color:var(--oro);margin:6px 0;}
.progressbar{height:16px;background:#000;border:2px solid var(--oro);border-radius:8px;overflow:hidden;margin:8px 0;}
.progressbar > div{height:100%;background:linear-gradient(90deg,var(--verde),#7fd048);width:0;transition:width .3s;}

.party{display:flex;gap:4px;justify-content:center;align-items:flex-end;margin:6px 0;flex-wrap:wrap;}
.narr{background:#20180f;border-left:5px solid var(--oro);padding:12px;margin:10px 0;border-radius:4px;}
.narr p{color:#ffeec2;font-size:9px;}
.speaker{color:var(--oro);font-size:9px;}

.coin{font-family:inherit;cursor:pointer;border-radius:50%;width:64px;height:64px;
  border:3px solid #9a7424;font-size:9px;color:#3a2a10;margin:4px;
  box-shadow:0 4px 0 #6e521a;display:inline-flex;align-items:center;justify-content:center;text-align:center;line-height:1.2;}
.coin:active{transform:translateY(3px);box-shadow:0 1px 0 #6e521a;}
.c-euro{background:#ffd84d;} .c-cent{background:#e8a24a;} .c-small{background:#d98a3a;}

.fracPiece{font-family:inherit;cursor:pointer;font-size:12px;color:#fff;background:var(--azul);
  border:3px solid #1d486e;box-shadow:0 4px 0 #143147;padding:12px 14px;border-radius:6px;margin:4px;}
.fracPiece:active{transform:translateY(3px);box-shadow:0 1px 0 #143147;}

.victory-emoji{font-size:30px;text-align:center;letter-spacing:6px;line-height:1.6;}
a.reset{font-size:8px;color:#8a7656;cursor:pointer;text-decoration:underline;}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:6px;flex-wrap:wrap;}
.hint{font-size:8px;color:#cdb48f;line-height:1.8;}
.tag{display:inline-block;background:var(--oro);color:#3a2a10;font-size:8px;padding:4px 8px;border-radius:4px;margin:2px;}

/* ---------- menú índice ---------- */
.chapGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:14px 0;}
@media(max-width:560px){.chapGrid{grid-template-columns:1fr;}}
.chapCard{background:var(--tinta);border:3px solid var(--oro-osc);border-radius:6px;
  padding:14px;text-decoration:none;color:#ffe9b0;display:block;transition:transform .05s;
  box-shadow:0 4px 0 #6e521a;}
.chapCard:hover{filter:brightness(1.1);}
.chapCard:active{transform:translateY(3px);box-shadow:0 1px 0 #6e521a;}
.chapCard .num{font-size:18px;color:var(--oro);}
.chapCard .tp{font-size:9px;line-height:1.6;display:block;margin-top:6px;}

/* ---------- modo plataformas ---------- */
.plat-hud{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:8px;}
.plat-controls{display:flex;gap:10px;justify-content:center;margin-top:10px;}
.plat-btn{font-family:inherit;font-size:15px;color:#3a2a10;background:var(--oro);
  border:3px solid var(--oro-osc);box-shadow:0 4px 0 #7a5a1c;border-radius:8px;
  padding:16px 18px;min-width:74px;cursor:pointer;user-select:none;touch-action:none;}
.plat-btn:active{transform:translateY(3px);box-shadow:0 1px 0 #7a5a1c;}
#doorOverlay:empty{display:none;}
.door-modal{position:fixed;inset:0;background:rgba(10,8,4,.86);z-index:9999;
  display:flex;align-items:center;justify-content:center;padding:14px;}
.door-card{max-width:520px;width:100%;text-align:center;}

/* ---------- tienda ---------- */
.shop-modal{position:fixed;inset:0;background:rgba(10,8,4,.9);z-index:10000;
  display:flex;align-items:flex-start;justify-content:center;padding:14px;overflow:auto;}
.shop-card{max-width:620px;width:100%;}
.shop-card h3{color:var(--oro);border-bottom:2px solid var(--oro-osc);padding-bottom:4px;margin:14px 0 8px;}
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;}
.shop-item{background:var(--tinta);border:3px solid var(--oro-osc);border-radius:6px;
  padding:8px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;box-shadow:0 3px 0 #6e521a;}
.shop-item .si-emoji{font-size:26px;line-height:1;}
.shop-item .si-desc{font-size:7px;line-height:1.5;color:#e9d9b8;background:rgba(0,0,0,.25);
  border-radius:4px;padding:5px 6px;margin:2px 0;min-height:42px;}
.shop-item .btn{font-size:9px;padding:8px 10px;margin:2px 0;}
