*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a18;--bg2: #111128;--bg3: #181830;--border: #3333aa;--accent: #8844ff;--accent2: #cc88ff;--text: #eeeeff;--text-dim: #7777cc;--hp: #00cc44;--mp: #0088ff;--gold: #ffcc00;--radius: 0px;--px-shadow: 3px 3px 0 #00000088;font-family:VT323,monospace;font-size:18px}body{background:var(--bg);color:var(--text);min-height:100vh;display:flex;align-items:center;justify-content:center}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(to bottom,transparent 0px,transparent 3px,rgba(0,0,0,.06) 3px,rgba(0,0,0,.06) 4px);pointer-events:none;z-index:9999}#root{width:100%;max-width:560px;min-height:100vh;display:flex;flex-direction:column}.title-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:40px 24px;text-align:center}@media (max-width: 480px){.title-screen{padding:24px 20px;gap:12px}}.title-date{font-size:.78rem;color:var(--text-dim);letter-spacing:.12em}.game-title{font-family:"Press Start 2P",monospace;font-size:1.8rem;letter-spacing:.1em;color:var(--accent2);text-shadow:4px 4px 0 #2200aa,8px 8px 0 #11005544;line-height:1.4}@media (max-width: 480px){.game-title{font-size:1.2rem;letter-spacing:.06em}}.game-subtitle{color:var(--text-dim);font-size:.88rem;letter-spacing:.12em;text-transform:uppercase}.title-enemy{display:flex;flex-direction:column;align-items:center;gap:10px}.title-enemy-hint{color:var(--text-dim);font-size:.82rem;max-width:260px;line-height:1.5}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.start-btn{background:var(--accent);color:#fff;border:2px solid var(--accent2);padding:14px 52px;border-radius:0;font-size:1.2rem;font-family:inherit;cursor:pointer;letter-spacing:.12em;box-shadow:var(--px-shadow);transition:transform .08s,box-shadow .08s}.start-btn:hover{background:var(--accent2);color:#0a0a18}.start-btn:active{transform:translate(3px,3px);box-shadow:none}.title-rules{color:var(--text-dim);font-size:.74rem;line-height:2;text-align:center;max-width:300px}@media (max-width: 480px){.title-rules{font-size:.68rem;line-height:1.8;max-width:260px}}.dev-notice{color:#557;font-size:.85rem;letter-spacing:.08em;border:2px solid #222244;border-radius:0;padding:4px 12px}.title-run-preview{display:flex;flex-direction:column;align-items:center;gap:10px}.title-run-row{display:flex;gap:24px;align-items:flex-end}@media (max-width: 480px){.title-run-row{gap:16px}}.title-run-fight{display:flex;flex-direction:column;align-items:center;gap:4px}.title-run-label{font-size:.7rem;color:var(--text-dim);letter-spacing:.06em}.mode-toggle{display:flex;gap:8px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:4px}.mode-btn{background:none;border:2px solid transparent;color:var(--text-dim);font-family:inherit;font-size:1rem;padding:8px 20px;border-radius:0;cursor:pointer;transition:background .08s,color .08s}.mode-btn--active{background:var(--accent);color:#fff;border-color:var(--accent2)}.mode-desc{font-size:.75rem;color:var(--text-dim);max-width:280px;line-height:1.5;text-align:center}.fight-index-badge{font-size:.9rem;color:var(--accent2);letter-spacing:.08em;background:var(--bg2);border:2px solid var(--border);border-radius:0;padding:3px 10px}.inter-fight-screen{flex:1;display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px;min-height:100vh;text-align:center;background:radial-gradient(ellipse at center,#0d1a20 0%,var(--bg) 70%)}.inter-fight-header{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:380px}.inter-fight-badge{font-size:.82rem;color:var(--accent2);letter-spacing:.06em;font-weight:700}.mode-badge{font-size:.9rem;border-radius:0;padding:3px 10px;border:2px solid var(--border);color:var(--text-dim)}.inter-fight-summary{display:flex;flex-direction:column;align-items:center;gap:6px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 20px;width:100%;max-width:380px}.inter-fight-enemy-name{font-size:1rem;color:var(--accent2);letter-spacing:.06em}.inter-fight-turns{font-size:.82rem;color:var(--text-dim)}.inter-fight-emoji-row{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;padding:6px 0}.inter-fight-divider{color:var(--text-dim);letter-spacing:.2em;font-size:.82rem}.inter-fight-resources{width:100%;max-width:380px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;display:flex;flex-direction:column;gap:8px}.resource-restored{display:flex;align-items:center;gap:10px;font-size:.82rem;color:#2ecc71}.resource-restored-icon{font-size:1.1rem}.resource-carryover{display:flex;flex-direction:column;gap:8px}.resource-bar-row{display:flex;align-items:center;gap:8px;font-size:.75rem}.resource-label{width:24px;color:var(--text-dim);text-align:right;flex-shrink:0}.resource-track{flex:1;height:10px;background:#050510;border-radius:0;overflow:hidden;border:2px solid var(--border);position:relative}.resource-track:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(to right,transparent 0px,transparent 9px,rgba(0,0,0,.55) 9px,rgba(0,0,0,.55) 11px);pointer-events:none}.resource-fill{height:100%;border-radius:0;transition:width .15s steps(10)}.resource-fill--hp{background:var(--hp)}.resource-fill--mp{background:var(--mp)}.resource-value{width:68px;text-align:right;color:var(--text-dim);flex-shrink:0}.resource-warning{font-size:.74rem;color:#e67e22;text-align:center}.inter-fight-next{display:flex;flex-direction:column;align-items:center;gap:6px}.inter-fight-next-label{font-size:.7rem;letter-spacing:.1em;color:var(--text-dim);text-transform:uppercase}.inter-fight-next-hint{font-size:.78rem;color:var(--accent2)}.multi-fight-rows{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:380px}.fight-row-separator{font-size:1.2rem;color:var(--accent2);letter-spacing:.2em;padding:2px 0}.fight-row-label{font-size:.78rem;color:var(--text-dim);text-align:center}.fight-par-note{color:var(--text-dim);font-size:.72rem}.optimal-hint-toggle{width:100%;max-width:380px;display:flex;flex-direction:column;align-items:center;gap:10px}.hint-toggle-btn{background:none;border:2px solid var(--border);color:var(--text-dim);font-family:inherit;font-size:1rem;padding:7px 18px;border-radius:0;cursor:pointer;box-shadow:var(--px-shadow);transition:transform .08s,box-shadow .08s}.hint-toggle-btn:hover{border-color:var(--accent);color:var(--text)}.hint-toggle-btn:active{transform:translate(3px,3px);box-shadow:none}.optimal-hints-list{display:flex;flex-direction:column;gap:10px;width:100%}.battle-screen{flex:1;display:flex;flex-direction:column;min-height:100vh;padding:10px 12px 14px;gap:8px}@media (max-width: 480px){.battle-screen{padding:8px 10px 10px;gap:6px}.battle-log{max-height:140px}}.battle-header{display:flex;justify-content:space-between;align-items:center;padding:0 2px}.turn-counter{font-size:.95rem;color:var(--text-dim);letter-spacing:.08em;background:var(--bg2);border:2px solid var(--border);border-radius:0;padding:3px 10px}.sprite-wrapper{display:flex;align-items:center;justify-content:center}.sprite-animated{animation:float 3s ease-in-out infinite}.sprite-emoji{line-height:1}.sprite-md.sprite-emoji{font-size:4.5rem}.sprite-lg.sprite-emoji{font-size:5.5rem}.sprite-img{display:block;image-rendering:pixelated;image-rendering:crisp-edges;object-fit:contain}.sprite-md .sprite-img{width:96px;height:96px}.sprite-lg .sprite-img{width:128px;height:128px}.enemy-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;align-items:center;gap:8px}.enemy-name{font-size:1rem;font-weight:700;letter-spacing:.08em;color:var(--accent2)}.enemy-stats{width:100%}.inspect-facts{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.inspect-tag{background:#1a1a40;border:2px solid var(--accent);border-radius:0;padding:3px 10px;font-size:.85rem;color:var(--accent2)}.stat-bar{width:100%;margin-bottom:6px}.stat-bar-label{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-dim);margin-bottom:3px}.stat-bar-track{background:#050510;border-radius:0;height:12px;overflow:hidden;border:2px solid var(--border);position:relative}.stat-bar-track:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(to right,transparent 0px,transparent 9px,rgba(0,0,0,.55) 9px,rgba(0,0,0,.55) 11px);pointer-events:none;z-index:1}.stat-bar-fill{height:100%;border-radius:0;transition:width .15s steps(10)}.battle-log{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;overflow-y:auto;max-height:190px;display:flex;flex-direction:column;gap:3px}.log-entry{font-size:.8rem;padding:2px 0;line-height:1.45}.log-player{color:#74c7ec}.log-enemy{color:#f38ba8}.log-system{color:var(--text-dim);font-style:italic}.log-inspect{color:#a6e3a1}.log-heal{color:#fab387}.battle-bottom{display:flex;flex-direction:column;gap:8px}.player-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px}.player-name{font-size:.95rem;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:10px}.tier-badge{font-size:.85rem;background:#1a1035;border:2px solid var(--accent);border-radius:0;padding:2px 8px;color:var(--accent2);letter-spacing:.06em}.defending-badge{font-size:.85rem;background:#0d2a1a;border:2px solid var(--hp);border-radius:0;padding:2px 8px;color:var(--hp)}.player-stats{margin-bottom:6px}.player-meta{display:flex;gap:14px;font-size:.7rem;color:var(--text-dim)}.action-menu{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px}.action-submenu-title{font-size:.78rem;color:var(--text-dim);margin-bottom:8px;letter-spacing:.06em}.action-grid{display:grid;gap:7px}.main-grid{grid-template-columns:repeat(2,1fr)}.spell-grid,.item-grid{grid-template-columns:repeat(3,1fr)}.action-btn{background:var(--bg2);border:2px solid var(--border);color:var(--text);border-radius:0;padding:10px 8px;font-family:inherit;font-size:1rem;cursor:pointer;transition:transform .08s,box-shadow .08s;text-align:center;box-shadow:var(--px-shadow)}.action-btn:hover:not(:disabled){background:#1e1e44;border-color:var(--accent)}.action-btn:active:not(:disabled){transform:translate(3px,3px);box-shadow:none}.action-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.inspect-btn{grid-column:1 / -1}.spell-btn,.item-btn{display:flex;flex-direction:column;align-items:center;gap:4px}.spell-name,.item-name{font-weight:700}.spell-cost{font-size:.7rem;color:#5b9bd5}.item-count{font-size:.7rem;color:var(--gold)}.item-name{font-size:.8rem}.no-items{color:var(--text-dim);font-size:.8rem;padding:8px 0}.back-btn{margin-top:8px;background:none;border:none;color:var(--text-dim);font-family:inherit;font-size:1rem;cursor:pointer;padding:3px 0}.back-btn:hover{color:var(--text)}.optimal-hint{background:#0f0f28;border:1px solid var(--accent);border-radius:var(--radius);padding:12px 16px;width:100%;max-width:380px;text-align:center;display:flex;flex-direction:column;gap:6px}.optimal-hint-label{font-size:.7rem;letter-spacing:.1em;color:var(--accent2);text-transform:uppercase}.optimal-hint-emojis{font-size:1.5rem;letter-spacing:.1em}.optimal-hint-desc{font-size:.78rem;color:var(--text-dim);line-height:1.5}.action-emoji-row{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;max-width:380px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;min-height:44px;align-items:center}.action-emoji{font-size:1.4rem}.no-actions{font-size:.78rem;color:var(--text-dim)}.results-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:40px 24px;text-align:center;min-height:100vh}.results-screen.victory{background:radial-gradient(ellipse at center,#0a1f12 0%,var(--bg) 65%)}.results-screen.defeat{background:radial-gradient(ellipse at center,#1a0d0d 0%,var(--bg) 65%)}.results-header{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:380px}.results-battle-num{font-size:.88rem;font-weight:700;color:var(--accent2);letter-spacing:.06em}.results-date{font-size:.72rem;color:var(--text-dim);letter-spacing:.08em}.results-enemy-name{font-size:1rem;color:var(--accent2);letter-spacing:.08em}.results-headline{font-size:2rem;letter-spacing:.14em;font-weight:700}.victory-text{color:#2ecc71}.defeat-text{color:#e74c3c}.results-score-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;font-size:1.1rem;color:var(--text-dim);background:var(--bg2);border:2px solid var(--border);border-radius:0;padding:8px 16px;max-width:380px;width:100%}.score-seg{color:var(--text)}.score-divider{color:var(--border);font-size:1.1rem}.turn-number{font-size:1.1rem;color:var(--accent2)}.hp-seg{color:#e74c3c}.results-rating{font-size:1.4rem;font-weight:700;letter-spacing:.16em}.turn-bars{display:flex;gap:8px}.turn-bar{width:36px;height:36px;border-radius:0;border:2px solid var(--border);background:var(--bg2);transition:background .1s,border-color .1s}.turn-bar.filled{background:var(--accent);border-color:var(--accent2);box-shadow:2px 2px #20a}.results-log{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;width:100%;max-width:380px;text-align:left;display:flex;flex-direction:column;gap:3px}.results-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.share-btn{background:var(--bg2);color:var(--text);border:2px solid var(--border);padding:10px 28px;border-radius:0;font-family:inherit;font-size:1.1rem;cursor:pointer;box-shadow:var(--px-shadow);transition:transform .08s,box-shadow .08s}.share-btn:hover{border-color:var(--accent)}.share-btn:active{transform:translate(3px,3px);box-shadow:none}.replay-btn{background:var(--accent);color:#fff;border:2px solid var(--accent2);padding:10px 28px;border-radius:0;font-family:inherit;font-size:1.1rem;cursor:pointer;box-shadow:var(--px-shadow);transition:transform .08s,box-shadow .08s}.replay-btn:hover{background:var(--accent2);color:#0a0a18}.replay-btn:active{transform:translate(3px,3px);box-shadow:none}.dev-stats-panel{display:flex;gap:12px;background:#0a0a18cc;border:2px solid #3333aa55;padding:10px 12px;margin-top:10px;font-family:""VT323"",monospace;font-size:1rem;color:#aac}.dev-stats-col{flex:1;min-width:0}.dev-stats-heading{color:#66c;font-size:.85rem;letter-spacing:.08em;margin-bottom:4px}.dev-stats-divider{width:1px;background:#33a5;align-self:stretch}.dev-stats-table{width:100%;border-collapse:collapse}.dev-stat-label{color:#66a;padding-right:8px;white-space:nowrap;vertical-align:top;font-size:.9rem}.dev-stat-value{color:#ccf;font-size:.9rem;word-break:break-all}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}.loading-title{font-family:""Press Start 2P"",monospace;font-size:1.4rem;color:var(--accent2);text-shadow:var(--px-shadow)}.loading-msg{font-family:""VT323"",monospace;font-size:1.4rem;color:#66a;animation:blink 1s step-start infinite}@keyframes blink{50%{opacity:0}}.feedback-section{width:100%;border:2px solid #3333aa55;padding:14px 12px 10px;margin-top:16px}.feedback-heading{font-family:""Press Start 2P"",monospace;font-size:.6rem;color:#88c;letter-spacing:.06em;margin-bottom:10px}.feedback-thanks{color:var(--accent2);font-size:1.2rem;text-align:center;padding:8px 0}.feedback-form{display:flex;flex-direction:column;gap:8px}.feedback-scale-labels{display:flex;justify-content:space-between;font-size:.85rem;color:#66a}.difficulty-rating{display:flex;gap:4px;flex-wrap:wrap}.rating-btn{flex:1;min-width:28px;padding:6px 2px;background:var(--bg2);color:#aac;border:2px solid #3333aa;border-radius:0;font-family:inherit;font-size:1rem;cursor:pointer;box-shadow:var(--px-shadow);transition:transform .06s,box-shadow .06s}.rating-btn:hover{border-color:var(--accent);color:var(--accent2)}.rating-btn:active{transform:translate(2px,2px);box-shadow:none}.rating-btn--selected{background:var(--accent);color:#fff;border-color:var(--accent2);box-shadow:none}.feedback-text{width:100%;background:var(--bg2);color:#ccf;border:2px solid #3333aa;border-radius:0;font-family:""VT323"",monospace;font-size:1.05rem;padding:6px 8px;resize:none;outline:none}.feedback-text:focus{border-color:var(--accent)}.feedback-count{font-size:.85rem;color:#66a;text-align:right}.feedback-submit{align-self:flex-end;background:var(--accent);color:#fff;border:2px solid var(--accent2);border-radius:0;font-family:inherit;font-size:1rem;padding:7px 20px;cursor:pointer;box-shadow:var(--px-shadow);transition:transform .06s,box-shadow .06s}.feedback-submit:hover:not(:disabled){background:var(--accent2);color:#0a0a18}.feedback-submit:active:not(:disabled){transform:translate(2px,2px);box-shadow:none}.feedback-submit:disabled{opacity:.4;cursor:default}
