*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow-x:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{width:100%;min-height:100vh}.battle-view[data-v-0f1d1d02]{padding:5px;width:100%;max-width:100%;margin:0 auto;box-sizing:border-box}.controls[data-v-0f1d1d02]{display:flex;gap:5px;margin-bottom:8px;justify-content:center;flex-wrap:wrap}button[data-v-0f1d1d02]{padding:6px 10px;font-size:12px;cursor:pointer;border:1px solid #ccc;border-radius:4px;background:#fff;min-width:60px;touch-action:manipulation}button[data-v-0f1d1d02]:active:not(:disabled){background:#e0e0e0}button[data-v-0f1d1d02]:disabled{opacity:.5;cursor:not-allowed}.battle-result[data-v-0f1d1d02]{padding:6px;margin-bottom:8px;border-radius:4px;text-align:center;font-size:11px}.battle-result h2[data-v-0f1d1d02]{font-size:12px;margin-bottom:4px}.battle-result .victory[data-v-0f1d1d02]{color:#4caf50;font-weight:700;font-size:12px}.battle-result .defeat[data-v-0f1d1d02]{color:#f44336;font-weight:700;font-size:12px}.battlefield-container[data-v-0f1d1d02]{margin-bottom:8px;display:flex;flex-direction:column;align-items:center;width:100%}.grid[data-v-0f1d1d02]{border:1px solid #333;display:inline-block;max-width:100%}.grid-row[data-v-0f1d1d02]{display:flex}.grid-cell[data-v-0f1d1d02]{width:calc((100vw - 20px)*.1);height:calc((100vw - 20px)*.1);border:1px solid #ccc;position:relative;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.grid-cell.player-area[data-v-0f1d1d02]{background:#e3f2fd}.grid-cell.enemy-area[data-v-0f1d1d02]{background:#ffebee}.grid-cell.attacker[data-v-0f1d1d02]{border:2px solid #2196f3;box-shadow:0 0 5px #2196f380}.grid-cell.target[data-v-0f1d1d02]{border:2px solid #f44336;box-shadow:0 0 5px #f4433680}.action-marker[data-v-0f1d1d02]{position:absolute;top:2px;right:2px;font-size:12px;font-weight:700;z-index:10;pointer-events:none}.attacker-marker[data-v-0f1d1d02]{color:#2196f3;text-shadow:0 0 3px rgba(255,255,255,.8)}.target-marker[data-v-0f1d1d02]{color:#f44336;text-shadow:0 0 3px rgba(255,255,255,.8)}.grid-cell.predicted-target[data-v-0f1d1d02]{border:2px solid #f44336;background:#f443364d;animation:targetBlink-0f1d1d02 .5s infinite}.grid-cell.predicted-target-empty[data-v-0f1d1d02]{border:2px solid #ff9800;background:#ff980033;animation:targetBlinkEmpty-0f1d1d02 .5s infinite}@keyframes targetBlink-0f1d1d02{0%,to{background:#f443364d;box-shadow:0 0 10px #f44336cc}50%{background:#f4433699;box-shadow:0 0 15px #f44336}}@keyframes targetBlinkEmpty-0f1d1d02{0%,to{background:#ff980033;box-shadow:0 0 8px #ff980099}50%{background:#ff980059;box-shadow:0 0 12px #ff9800cc}}.damage-number[data-v-0f1d1d02]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:16px;font-weight:700;color:#f44336;z-index:20;pointer-events:none;animation:damageFloat-0f1d1d02 3s ease-out forwards;text-shadow:0 0 3px rgba(255,255,255,.8)}@keyframes damageFloat-0f1d1d02{0%{opacity:1;transform:translate(-50%,-50%) translateY(0)}to{opacity:0;transform:translate(-50%,-50%) translateY(-30px)}}.character[data-v-0f1d1d02]{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:8px;padding:2px;box-sizing:border-box;text-align:center}.char-name-in-grid[data-v-0f1d1d02]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}.hp-bar[data-v-0f1d1d02]{width:90%;height:4px;background:#ddd;border-radius:2px;margin-top:2px;overflow:hidden}.hp-fill[data-v-0f1d1d02]{height:100%;background:#4caf50;transition:width .3s}.hp-text[data-v-0f1d1d02]{font-size:7px;margin-top:1px}.characters-container[data-v-0f1d1d02]{margin-bottom:8px}.characters-section[data-v-0f1d1d02]{margin-bottom:6px}.characters-section h3[data-v-0f1d1d02]{margin-bottom:4px;font-size:11px;text-align:center}.characters-list-horizontal[data-v-0f1d1d02]{display:flex;gap:4px;flex-wrap:wrap;justify-content:center}.character-card[data-v-0f1d1d02]{padding:4px;border:1px solid #ccc;border-radius:3px;background:#fff;width:calc((100vw - 40px) / 3);max-width:100px;flex:0 0 auto;box-sizing:border-box}.character-card.player[data-v-0f1d1d02]{border-color:#2196f3;background:#e3f2fd}.character-card.enemy[data-v-0f1d1d02]{border-color:#f44336;background:#ffebee}.character-card.dead[data-v-0f1d1d02]{opacity:.5;background:#f5f5f5}.character-card.current-attacker[data-v-0f1d1d02]{border:2px solid #4caf50;box-shadow:0 0 8px #4caf5099}.char-name[data-v-0f1d1d02]{font-weight:700;font-size:10px;margin-bottom:3px}.char-stats[data-v-0f1d1d02]{font-size:9px;margin-bottom:2px}.char-stats div[data-v-0f1d1d02]{margin:1px 0}.char-position[data-v-0f1d1d02]{font-size:8px;color:#666;margin-top:2px}.dead-label[data-v-0f1d1d02]{color:#f44336;font-weight:700;margin-top:2px;font-size:8px}.battle-log[data-v-0f1d1d02]{border:1px solid #ccc;border-radius:3px;padding:5px;margin-bottom:5px}.battle-log h2[data-v-0f1d1d02]{margin-bottom:4px;font-size:11px}.log-content[data-v-0f1d1d02]{max-height:120px;overflow-y:auto;background:#f9f9f9;padding:4px;border-radius:3px}.log-entry[data-v-0f1d1d02]{padding:2px 0;border-bottom:1px solid #eee;font-size:9px;line-height:1.3}.log-time[data-v-0f1d1d02]{color:#666;margin-right:5px;font-size:8px}.log-message[data-v-0f1d1d02]{color:#333}
