:root{color:#eef7e9;background:#121212;font-family:Trebuchet MS,Noto Sans SC,sans-serif}html,body{margin:0;width:100%;height:100%;touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;overflow:hidden}body{display:flex;align-items:center;justify-content:center}button,canvas{touch-action:manipulation}#app,#game-shell{width:100%;height:100%}#game-shell{position:relative;display:flex;flex-direction:column;align-items:center;padding-top:max(8px,env(safe-area-inset-top));box-sizing:border-box}#banner{font-size:20px;font-weight:700;color:#ffd166;text-align:center;padding:6px 0}#game-area{display:flex;align-items:flex-start;justify-content:center;gap:8px}.side-panel{width:100px;min-height:200px;padding:8px;background:#ffffff0f;border-radius:8px;font-size:13px;line-height:1.6;color:#ccc;overflow-y:auto;max-height:400px}.side-panel .stat{display:flex;align-items:center;justify-content:space-between;gap:4px}.sprite-icon{display:inline-block;width:24px;height:24px;background-size:24px auto;background-repeat:no-repeat;image-rendering:pixelated;flex-shrink:0;vertical-align:middle}.icon-text{display:inline-block;width:24px;height:24px;line-height:24px;text-align:center;font-size:9px;font-weight:700;color:#ffd166;flex-shrink:0}.side-panel .val{color:#fff;font-weight:700}.side-panel .section-title{color:#ffd166;font-weight:700;margin-top:6px;margin-bottom:2px;border-bottom:1px solid rgba(255,255,255,.15);padding-bottom:2px}.side-panel .monster-entry,.side-panel .item-entry{margin-bottom:4px;font-size:12px;display:flex;align-items:center;gap:4px;flex-wrap:wrap}.side-panel .m-name,.side-panel .i-name{color:#eee;font-weight:600}.side-panel .m-stats{color:#999;font-size:11px}.side-panel .safe{color:#80ed99}.side-panel .fatal{color:#ff5f56;font-weight:700}.side-panel .i-desc{color:#aaa;font-size:11px}#game-canvas{display:block;border:2px solid rgba(255,255,255,.12);background:#000;image-rendering:pixelated}#message{position:absolute;top:max(14px,env(safe-area-inset-top));left:50%;transform:translate(-50%);padding:10px 16px;border-radius:999px;background:#000000b3;color:#fff7dc;font-size:16px;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:10}#message.visible{opacity:1}#touch-controls{display:none}@media(pointer:coarse){#touch-controls{display:block}}#joystick-base{position:fixed;bottom:30px;left:30px;width:140px;height:140px;border-radius:50%;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);touch-action:none}#joystick-knob{display:none;position:absolute;width:60px;height:60px;border-radius:50%;background:#fff6;transform:translate(-50%,-50%);pointer-events:none}#shop-overlay{position:absolute;inset:0;display:none;align-items:center;justify-content:center;background:#0009;z-index:20}#shop-overlay.visible{display:flex}.shop-panel{background:#1a1a2e;border:2px solid #ffd166;border-radius:16px;padding:24px;text-align:center;min-width:220px}.shop-title{font-size:22px;font-weight:700;color:#ffd166;margin-bottom:8px}.shop-gold{color:#f6d04d;margin-bottom:12px}.shop-btn{display:block;width:100%;margin:6px 0;padding:10px;border:0;border-radius:8px;background:#ffffff26;color:#eef7e9;font:inherit;font-size:16px;cursor:pointer}.shop-btn:disabled{opacity:.35;cursor:not-allowed}.shop-btn:not(:disabled):hover{background:#ffd05c80}.shop-close{display:inline-block;margin-top:12px;padding:8px 24px;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:transparent;color:#ccc;font:inherit;font-size:14px;cursor:pointer}.shop-close:hover{background:#ffffff1a}.victory-overlay{position:absolute;inset:0;display:none;align-items:center;justify-content:center}.victory-overlay.visible{display:flex}.victory-canvas{position:absolute;inset:0;width:100%;height:100%}.victory-content{position:relative;z-index:1;padding:28px;border-radius:28px;background:#00000094;text-align:center;color:#fff8df}.victory-content h1{margin:0;font-size:clamp(48px,9vw,72px)}.victory-content p{margin:12px 0 0;font-size:clamp(20px,3vw,28px)}.victory-emoji{margin-top:18px;font-size:clamp(44px,8vw,68px);animation:bounce 1.4s ease-in-out infinite}.victory-replay{margin-top:20px;padding:0 28px;min-height:48px;border:0;border-radius:16px;background:#eef7e92e;color:#eef7e9;font:inherit;font-size:20px;cursor:pointer}.victory-replay:active{background:#ffd05cd9;color:#232018}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(max-width:700px){.side-panel{display:none}#game-area{gap:0}}@media(max-width:900px)and (min-width:701px){.side-panel{width:90px;font-size:11px}}
