*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100dvh;overflow:hidden}body{background:#f5f0e8;color:#333;font-family:Comic Neue,Comic Sans MS,cursive;font-size:14px;-webkit-text-size-adjust:100%}#loading{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c2137;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:100;transition:opacity .4s ease;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}#loading.fade-out{opacity:0;pointer-events:none}#loading-text{font-size:clamp(24px,6vw,32px);font-weight:700;color:#ffd644;text-shadow:2px 2px 0 #e6b800,4px 4px 0 rgba(0,0,0,.3)}#loading-bar-track{width:min(200px,60vw);height:16px;background:#1a1423;border:3px solid #6bb8e0}#loading-bar-fill{height:100%;width:0%;background:#6bb8e0;transition:width .2s steps(10)}#loading-status{font-size:13px;color:#9b8fb0}#app{display:flex;flex-direction:column;height:100dvh;overflow:hidden}#header{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;padding-top:max(8px,env(safe-area-inset-top));padding-left:max(14px,env(safe-area-inset-left));padding-right:max(14px,env(safe-area-inset-right));background:#6bb8e0;border-bottom:3px solid #4a9cc4;flex:0 0 auto;min-height:0}#title{font-weight:700;font-size:clamp(14px,3.5vw,16px);color:#fff;text-shadow:1px 1px 0 #4a9cc4;white-space:nowrap}#counter{font-size:clamp(10px,2.5vw,12px);color:#fffc;white-space:nowrap;margin-left:8px}#game-canvas{flex:1 1 0;min-height:0;width:100%;display:block;image-rendering:pixelated;image-rendering:crisp-edges;touch-action:none}#bottom-bar{background:#eee8dc;border-top:3px solid #4a9cc4;padding:8px 12px;padding-bottom:max(8px,env(safe-area-inset-bottom));padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));flex:0 0 auto;display:flex;flex-direction:column;gap:4px}#character-form{display:flex;gap:8px}#character-input{flex:1 1 0;min-width:0;padding:8px 10px;background:#fff;border:2px solid #ccc;border-radius:0;color:#333;font-family:inherit;font-size:16px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}#character-input::placeholder{color:#aaa}#character-input:focus{border-color:#6bb8e0}#submit-btn{padding:8px 18px;background:#ffd644;border:2px solid #e6b800;color:#5a4a00;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;flex:0 0 auto;-webkit-tap-highlight-color:transparent}#submit-btn:hover{background:#ffe066}#submit-btn:active{border-style:inset}#submit-btn:disabled{background:#ddd;border-color:#bbb;color:#999;cursor:default}#status{font-size:12px;color:#888;min-height:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#progress-wrap{display:flex;align-items:center;gap:8px}#progress-track{flex:1 1 0;height:12px;background:#d4cdc0;border:2px solid #b8b0a0;overflow:hidden}#progress-fill{height:100%;width:0%;background:#6bb8e0;transition:none}#progress-fill.done{background:#7ecc5a}#progress-label{flex:0 0 auto;font-size:11px;font-weight:700;color:#6bb8e0;min-width:28px;text-align:right}
