:root{--bg:#355330;--panel:#e8c983;--panel-dark:#d0a463;--ink:#2f2419;--field:#63814f;--error:#8f2d2d;--danger:#7d1e1e}*{box-sizing:border-box}body{color:var(--ink);background-color:#274220;background-image:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20width='16'%20height='16'%20viewBox='0%200%2016%2016'%3e%3crect%20width='16'%20height='16'%20fill='%2363814f'/%3e%3crect%20x='2'%20y='3'%20width='1'%20height='1'%20fill='%2373975b'/%3e%3crect%20x='6'%20y='6'%20width='1'%20height='1'%20fill='%2373975b'/%3e%3crect%20x='11'%20y='10'%20width='1'%20height='1'%20fill='%2373975b'/%3e%3c/svg%3e");background-size:32px 32px;margin:0;font-family:Pixelify Sans,monospace}button,input,select,textarea{border:3px solid var(--ink);color:var(--ink);background:#f0d89f;border-radius:0;padding:8px;font-family:Pixelify Sans,monospace}button{cursor:pointer;text-transform:uppercase;font-weight:700}button.secondary{background:#ceb684}button.danger{color:#fff3e6;background:#c55a5a}.app-shell{max-width:1200px;min-height:100vh;margin:0 auto;padding:12px}.pixel-panel{border:4px solid var(--ink);background:var(--panel)}.hud{padding:10px}.hud h1,.legend h2,.modal h2{font-family:"Press Start 2P",monospace;font-size:14px;line-height:1.4}.actions-inline{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.game-layout{margin-top:12px;display:block}.game-card{background:var(--panel-dark);padding:8px;position:relative;overflow:hidden}#game-root{aspect-ratio:832/576;width:100%;min-height:576px}#game-root canvas{width:100%;height:auto;image-rendering:pixelated;border:4px solid var(--ink);display:block}.touch-controls{inset:auto 12px calc(12px + env(safe-area-inset-bottom)) 12px;pointer-events:none;justify-content:space-between;align-items:end;gap:12px;display:flex;position:absolute}.touch-joystick,.touch-interact{pointer-events:auto}.touch-joystick{border:3px solid var(--ink);touch-action:none;background:#f8e9b9d1;border-radius:999px;width:128px;height:128px;position:relative}.touch-joystick-knob{border:3px solid var(--ink);background:#d0a463f2;border-radius:999px;width:46px;height:46px;position:absolute;top:calc(50% - 23px);left:calc(50% - 23px)}.touch-interact{touch-action:manipulation;min-width:132px;min-height:72px;font-size:15px}.legend{padding:12px}.overlay{background:#15100ca6;place-items:center;padding:16px;display:grid;position:fixed;top:0;bottom:0;left:0;right:0}.modal{width:min(860px,98vw);max-height:92vh;padding:16px;overflow:auto}.modal-centered{text-align:center}.modal-centered .actions-inline{justify-content:center}.modal-centered .welcome-body{text-align:center}.modal .grid-form,.modal .entry-list,.modal .scroll-meta,.modal .signature-block{text-align:left}.modal.large{width:min(960px,98vw)}.welcome-card{width:min(calc(var(--wrap-ch,62) * 1ch + 64px), 96vw)}.info-card{width:min(560px,94vw)}.language-card,.character-card,.experience-card{width:min(700px,96vw)}.language-card{text-align:center}.language-prompt{text-align:center;font-size:16px}.selection-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0;display:grid}.language-option,.character-option{text-align:center;background:#f4dfa7;justify-items:center;gap:6px;min-height:90px;display:grid}.language-selection{justify-items:stretch}.language-option{text-align:center;justify-items:center;min-height:140px;padding:12px;font-size:18px}.language-option .language-title{font-size:22px}.language-flag{border:3px solid var(--ink);background:#fff;width:72px;height:48px}.character-option{min-height:176px;padding:12px;font-size:18px}.character-option.selected{outline:4px solid #355f8f}.sex-icon{width:72px;height:72px;image-rendering:pixelated;display:block}.welcome-body{border:3px solid var(--ink);background:#f3dd9f;max-height:min(46vh,420px);margin-bottom:10px;padding:10px;overflow-y:auto}.welcome-body p{margin:0 0 10px;line-height:1.4}.welcome-body p:last-child{margin-bottom:0}.stack{gap:8px;display:grid}.grid-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.grid-form .full{grid-column:1/-1}.grid-form label{gap:6px;display:grid}textarea{resize:vertical;min-height:140px}.signature-canvas{border:3px solid var(--ink);touch-action:none;width:100%;max-width:420px;image-rendering:pixelated}.message{white-space:pre-wrap;border:3px solid var(--ink);background:#f4dc9f;padding:8px}.experience-option{text-align:center;background:#f4dfa7;justify-items:center;gap:6px;min-height:140px;padding:12px;font-size:18px;display:grid}.experience-icon{border:3px solid var(--ink);background:#f8e6b4;width:72px;height:48px;position:relative}.experience-icon.mobile{width:44px;height:72px}.experience-icon:after{content:"";border:2px solid var(--ink);position:absolute;top:6px;bottom:6px;left:6px;right:6px}.experience-hint{margin-top:6px;font-size:14px}.scroll-modal{gap:12px;display:grid}.scroll-modal .message{margin:0}.scroll-meta{border:3px solid var(--ink);background:#f4dc9f;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:8px;display:grid}.scroll-meta .meta-item{align-items:baseline;gap:6px;display:flex}.scroll-meta .meta-label{font-weight:700}.signature-block{justify-items:start;gap:10px;display:grid}.signature-block .scroll-actions{justify-content:flex-end;width:100%;display:flex}.signature-preview{border:3px solid var(--ink);background:#f8e9b9;width:100%;max-width:300px}.entry-list{gap:10px;margin-bottom:12px;display:grid}.entry-list article{border:3px solid var(--ink);background:#f0d89f;padding:8px}.entry-list header{justify-content:space-between;margin-bottom:6px;display:flex}.error{color:var(--error);font-weight:700}.status{color:#2f5a26;font-weight:700}@media (max-width:960px){.grid-form{grid-template-columns:1fr}.actions-inline{align-items:stretch}.actions-inline button{min-height:42px}#game-root{min-height:320px}.hud h1,.legend h2,.modal h2{font-size:11px}.selection-grid,.scroll-meta{grid-template-columns:1fr}.touch-controls{display:flex}}@media (max-width:640px){.app-shell,.hud{padding:8px}.modal{padding:12px}#game-root{min-height:240px}.touch-joystick{width:110px;height:110px}.touch-joystick-knob{width:40px;height:40px;top:calc(50% - 20px);left:calc(50% - 20px)}.touch-interact{min-width:112px;min-height:60px;font-size:13px}.language-option{min-height:128px;font-size:16px}.language-option .language-title{font-size:20px}.language-flag{width:64px;height:42px}}
