:root{color:#162635;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#eef3f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}.game-app{color:#162635;background:#eef3f8;align-items:center;min-height:100vh;padding:24px;display:grid}.game-frame{background:#f8fbff;border:1px solid #97a8ba;grid-template-columns:150px minmax(0,1fr) 72px;width:min(100%,980px);min-height:560px;margin:0 auto;display:grid;box-shadow:0 18px 42px #21304324}.status-panel,.bad-guess-rail{background:#e5edf6}.status-panel{border-right:1px solid #b8c6d6;flex-direction:column;align-items:center;gap:14px;padding:16px 12px;display:flex}.score-block{border-bottom:1px solid #b8c6d6;justify-items:center;gap:8px;width:100%;padding-bottom:10px;display:grid}.score-trophy{object-fit:contain;width:58px;height:58px}.score-fraction{color:#162635;justify-items:center;gap:3px;font-size:1.45rem;font-weight:800;line-height:1;display:grid}.score-rule{border-top:2px solid #162635;width:34px}.badge-button,.action-button,.guess-form button,.dialog-actions button{color:#162635;font:inherit;cursor:pointer;background:#f8fbff;border:1px solid #879aac;border-radius:8px}.badge-button{place-items:center;width:126px;height:76px;padding:8px;line-height:0;display:grid}.difficulty-button{padding:3px}.badge-button:disabled,.action-button:disabled,.guess-form input:disabled,.guess-form button:disabled{cursor:default;opacity:.62}.badge-button:not(:disabled):hover,.action-button:not(:disabled):hover,.guess-form button:not(:disabled):hover,.dialog-actions button:hover{background:#edf7f0;border-color:#4f8c67}.language-badge{object-fit:contain;object-position:center center;width:112px;max-width:100%;height:56px;max-height:100%}.difficulty-badge{object-fit:contain;object-position:center center;width:116px;max-width:100%;height:70px;max-height:100%}.action-button{place-items:center;width:96px;min-height:82px;margin-top:auto;padding:8px;font-weight:800;display:grid}.action-icon{object-fit:contain;width:42px;height:42px}.play-panel{background:#f4f8fc;grid-template-rows:minmax(280px,1fr) 42px auto auto;min-width:0;display:grid}.drawing-surface{background:#e9eff7;border:1px solid #6c7a8d;min-height:300px;margin:16px;position:relative;overflow:hidden}.drawing-surface:after{content:"";pointer-events:none;border:1px solid #aab6c5;position:absolute;inset:4px}.character-stack{width:min(82%,420px);max-width:calc(100% - 48px);position:absolute;top:24px;bottom:24px;left:50%;transform:translate(-50%)}.character-layer{object-fit:contain;object-position:center bottom;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;inset:0}.message-row{align-items:center;min-height:42px;padding:0 16px;display:flex}.message,.message-placeholder{border-radius:6px;align-items:center;width:100%;min-height:28px;padding:4px 10px;font-weight:700;display:flex}.message.info{color:#1f4e79;background:#e5f1ff}.message.success{color:#245b38;background:#e2f6e8}.message.error{color:#8a2d23;background:#fde9e7}.word-area{background:#eaf5ec;border-top:1px solid #b8c6d6;flex-wrap:wrap;justify-content:center;align-items:center;gap:7px;min-height:78px;padding:10px 16px 14px;display:flex}.word-slot{background:#f6fcf6;border:2px solid #1c3e59;place-items:center;width:36px;height:54px;font-size:1.3rem;font-weight:900;display:grid}.setup-title{color:#162635;font-size:2.1rem;font-weight:900}.guess-form{background:#eaf5ec;justify-content:center;align-items:center;gap:10px;min-height:78px;padding:12px 16px 18px;display:flex}.guess-form label{font-weight:800}.guess-form input{color:#162635;width:96px;height:38px;font:inherit;text-align:center;background:#ebf8ff;border:2px solid #4a97db;border-radius:4px;font-size:1.2rem;font-weight:800}.guess-form button{min-height:38px;padding:0 14px;font-weight:800}.bad-guess-rail{border-left:1px solid #b8c6d6;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:10px;display:flex}.bad-guess-slot{background:#eef4fb;border:1px solid #6c7a8d;place-items:center;width:30px;height:40px;font-size:1.1rem;font-weight:900;display:grid}.dialog-backdrop{background:#1626356b;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.dialog{color:#162635;text-align:center;background:#f8fbff;border:1px solid #879aac;border-radius:8px;gap:16px;width:min(100%,460px);padding:24px;display:grid;box-shadow:0 18px 42px #1626353d}.dialog h2,.dialog p{margin:0}.dialog-summary{gap:6px;font-size:1.1rem;font-weight:800;display:grid}.dialog-prompt{font-weight:900}.dialog-actions{justify-content:center;gap:10px;display:flex}.dialog-actions button{min-width:88px;min-height:38px;padding:0 14px;font-weight:900}.dialog-actions .primary{background:#dff3e7;border-color:#4f8c67}@media (width<=760px){.game-app{align-items:stretch;padding:0}.game-frame{border-left:0;border-right:0;grid-template-rows:auto minmax(0,1fr) auto;grid-template-columns:1fr;min-height:100vh}.status-panel{padding:10px max(12px, env(safe-area-inset-right)) 10px max(12px, env(safe-area-inset-left));border-bottom:1px solid #b8c6d6;border-right:0;flex-direction:row;justify-content:center;gap:clamp(6px,2vw,10px);overflow-x:hidden}.score-block{border-bottom:0;width:auto;min-width:clamp(52px,14vw,64px);padding-bottom:0}.score-trophy{width:clamp(36px,10vw,46px);height:clamp(36px,10vw,46px)}.score-fraction{font-size:clamp(1rem,5vw,1.25rem)}.badge-button{flex:0 clamp(72px,24vw,92px);width:auto;height:clamp(54px,16vw,64px);min-height:0;padding:5px}.language-badge,.difficulty-badge{width:auto;height:auto}.action-button{flex:0 clamp(58px,19vw,72px);width:auto;min-height:clamp(54px,16vw,64px);margin-top:0;padding:6px}.action-icon{width:clamp(30px,10vw,38px);height:clamp(30px,10vw,38px)}.play-panel{grid-template-rows:minmax(260px,1fr) 48px auto auto}.drawing-surface{min-height:260px;margin:10px}.character-stack{width:min(90%,360px);top:18px;bottom:18px}.bad-guess-rail{border-top:1px solid #b8c6d6;border-left:0;flex-direction:row;min-height:64px}.guess-form{flex-wrap:wrap}.word-area{flex-wrap:nowrap;gap:4px;min-height:70px;padding:10px 12px 14px}.word-slot{width:var(--word-slot-size,36px);height:var(--word-slot-height,54px);border-width:var(--word-slot-border,2px);font-size:var(--word-slot-font,1.3rem)}}
