*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f5f0e8;--color-surface: #faf6ee;--color-border: #8b6914;--color-border-dark: #5c4a1e;--color-text: #3a2a1a;--color-text-muted: #7a6a5a;--color-team-a: #c8e6c9;--color-team-b: #bbdefb;--color-team-a-dark: #2e7d32;--color-team-b-dark: #1565c0;--color-selected: #fff59d;--color-movable: rgba(100, 200, 100, .4);--color-danger: #b71c1c;--font-serif: "Hiragino Mincho ProN", "Yu Mincho", "MS Mincho", Georgia, serif}body{font-family:var(--font-serif);background-color:var(--color-bg);color:var(--color-text);min-height:100vh}button{font-family:var(--font-serif);cursor:pointer}input{font-family:var(--font-serif)}.top-page[data-v-1994487a]{min-height:100vh;display:flex;flex-direction:column}.top-header[data-v-1994487a]{text-align:center;padding:1.5rem;border-bottom:2px solid var(--color-border);background:var(--color-surface)}.logo[data-v-1994487a]{font-size:2.5rem;color:var(--color-border-dark);letter-spacing:.2em}.top-main[data-v-1994487a]{flex:1;display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;gap:1.5rem}.form-card[data-v-1994487a]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;padding:1.5rem;width:100%;max-width:420px}@media (max-width: 480px){.top-header[data-v-1994487a]{padding:1rem}.logo[data-v-1994487a]{font-size:2rem}.top-main[data-v-1994487a]{padding:1.5rem .8rem;gap:1rem}.form-card[data-v-1994487a]{padding:1.2rem}}.form-card h2[data-v-1994487a]{margin-bottom:1.5rem;font-size:1.2rem;color:var(--color-border-dark);border-bottom:1px solid var(--color-border);padding-bottom:.5rem}.form-group[data-v-1994487a]{margin-bottom:1rem}.form-group label[data-v-1994487a]{display:block;margin-bottom:.3rem;font-size:.9rem;color:var(--color-text-muted)}.form-group input[data-v-1994487a]{width:100%;padding:.6rem .8rem;border:1px solid var(--color-border);border-radius:3px;background:#fff;font-size:1rem}.btn-primary[data-v-1994487a],.btn-secondary[data-v-1994487a]{width:100%;padding:.8rem;border:none;border-radius:3px;font-size:1rem;margin-top:.5rem;transition:opacity .2s}.btn-primary[data-v-1994487a]{background:var(--color-border-dark);color:#fff}.btn-secondary[data-v-1994487a]{background:var(--color-surface);color:var(--color-border-dark);border:1px solid var(--color-border)}.btn-primary[data-v-1994487a]:hover,.btn-secondary[data-v-1994487a]:hover{opacity:.85}.btn-primary[data-v-1994487a]:disabled{opacity:.5;cursor:not-allowed}.divider[data-v-1994487a]{color:var(--color-text-muted);font-size:.9rem}.error-msg[data-v-1994487a]{color:var(--color-danger);font-size:.9rem}.piece-svg[data-v-a9a88928]{display:block;width:100%;height:100%}.piece-svg--flipped[data-v-a9a88928]{transform:rotate(180deg)}.hand-pieces[data-v-8857bed4]{padding:.4rem .5rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface);min-height:50px;width:100%;box-sizing:border-box}.hand-grid[data-v-8857bed4]{display:flex;flex-wrap:wrap;gap:.3rem}.hand-cell[data-v-8857bed4]{display:flex;flex-direction:column;align-items:center;padding:.3rem .5rem;border:1px solid var(--color-border);border-radius:3px;background:#fff;min-width:40px}.hand-cell--selectable[data-v-8857bed4]{cursor:pointer}.hand-cell--selectable[data-v-8857bed4]:hover{background:var(--color-selected)}.hand-cell--selected[data-v-8857bed4]{background:var(--color-selected);border-color:var(--color-border-dark)}.piece-img-wrapper[data-v-8857bed4]{width:34px;height:37px}@media (max-width: 768px){.piece-img-wrapper[data-v-8857bed4]{width:28px;height:30px}.hand-cell[data-v-8857bed4]{min-width:34px;padding:.2rem .35rem}}@media (max-width: 480px){.piece-img-wrapper[data-v-8857bed4]{width:24px;height:26px}.hand-cell[data-v-8857bed4]{min-width:28px;padding:.15rem .25rem}.piece-count[data-v-8857bed4]{font-size:.65rem}}.piece-count[data-v-8857bed4]{font-size:.72rem;color:var(--color-text);font-weight:700}.no-pieces[data-v-8857bed4]{font-size:.8rem;color:var(--color-text-muted)}.overlay[data-v-eabe6336]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.dialog[data-v-eabe6336]{background:var(--color-surface);border:2px solid var(--color-border-dark);border-radius:6px;padding:2rem;text-align:center}.dialog p[data-v-eabe6336]{font-size:1.3rem;margin-bottom:1.5rem}.buttons[data-v-eabe6336]{display:flex;gap:1rem;justify-content:center}.btn-promote[data-v-eabe6336],.btn-no-promote[data-v-eabe6336]{padding:.6rem 2rem;border-radius:4px;font-size:1rem;border:1px solid var(--color-border)}.btn-promote[data-v-eabe6336]{background:var(--color-border-dark);color:#fff;border-color:var(--color-border-dark)}.btn-no-promote[data-v-eabe6336]{background:#fff;color:var(--color-text)}.board-wrapper[data-v-7e69b32d]{--cell-size: 52px;--label-width: 24px;display:flex;flex-direction:column;gap:.3rem;align-items:stretch}.board[data-v-7e69b32d]{display:flex;flex-direction:column;gap:0;align-self:center}.col-labels[data-v-7e69b32d]{display:flex;align-items:center}.col-labels--top[data-v-7e69b32d]{margin-bottom:2px}.col-labels--bottom[data-v-7e69b32d]{margin-top:2px}.col-labels span[data-v-7e69b32d]{width:var(--cell-size);text-align:center;font-size:.8rem;color:var(--color-text-muted);font-weight:700}.row-label-spacer[data-v-7e69b32d]{width:var(--label-width);flex-shrink:0}.board-rows[data-v-7e69b32d]{display:flex;gap:0}.row-labels[data-v-7e69b32d]{display:flex;flex-direction:column;width:var(--label-width)}.row-labels span[data-v-7e69b32d]{height:var(--cell-size);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--color-text);font-weight:900}.grid[data-v-7e69b32d]{border:2px solid var(--color-border-dark)}.grid-row[data-v-7e69b32d]{display:flex}.cell[data-v-7e69b32d]{width:var(--cell-size);height:var(--cell-size);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;background:#e8d59a;position:relative;transition:background .1s}.cell[data-v-7e69b32d]:hover{background:#f5e8b0}.cell--selected[data-v-7e69b32d]{background:var(--color-selected)!important}.cell--last-move[data-v-7e69b32d]{background:#c8e6c9}.cell--last-move[data-v-7e69b32d]:hover{background:#a5d6a7}.cell--movable[data-v-7e69b32d]:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;background:var(--color-movable);pointer-events:none}.piece-wrapper[data-v-7e69b32d]{width:calc(var(--cell-size) - 6px);height:calc(var(--cell-size) - 6px);display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;position:relative;z-index:1}@media (max-width: 768px){.board-wrapper[data-v-7e69b32d]{--cell-size: 44px;--label-width: 20px}.row-labels span[data-v-7e69b32d]{font-size:.75rem}.col-labels span[data-v-7e69b32d]{font-size:.7rem}}@media (max-width: 480px){.board-wrapper[data-v-7e69b32d]{--cell-size: 36px;--label-width: 18px}.row-labels span[data-v-7e69b32d]{font-size:.65rem}.col-labels span[data-v-7e69b32d]{font-size:.6rem}.cell--movable[data-v-7e69b32d]:after{top:3px;right:3px;bottom:3px;left:3px}}.timer[data-v-7050b00a]{display:flex;flex-direction:column;align-items:center;padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface);min-width:80px}.timer--active[data-v-7050b00a]{border-color:var(--color-border-dark);background:#fff9c4}.timer--byoyomi[data-v-7050b00a]{border-color:#e65100}.timer--danger[data-v-7050b00a]{border-color:var(--color-danger);background:#ffebee;color:var(--color-danger)}.team-label[data-v-7050b00a]{font-size:.7rem;color:var(--color-text-muted);margin-bottom:.2rem}.time[data-v-7050b00a]{font-size:1.4rem;font-weight:700;letter-spacing:.05em}.byoyomi-label[data-v-7050b00a]{font-size:.65rem;color:#e65100;font-weight:700;margin-top:.1rem}.timer-compact[data-v-7050b00a]{display:flex;align-items:center;gap:.3rem}.timer-compact.timer--danger .time-compact[data-v-7050b00a]{color:var(--color-danger)}.time-compact[data-v-7050b00a]{font-size:1.1rem;font-weight:700;letter-spacing:.03em}.byoyomi-badge[data-v-7050b00a]{font-size:.6rem;color:#e65100;font-weight:700;background:#fff3e0;border:1px solid #e65100;border-radius:3px;padding:0 3px}.team-list[data-v-9f83794f]{width:160px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface)}@media (max-width: 768px){.team-list[data-v-9f83794f]{width:130px}.team-header[data-v-9f83794f]{font-size:.75rem;padding:.3rem .4rem}.player-item[data-v-9f83794f]{font-size:.8rem;padding:.25rem .35rem}}@media (max-width: 600px){.team-list[data-v-9f83794f]{width:100%}.my-turn-text[data-v-9f83794f]{font-size:.68rem}}.team-list--active[data-v-9f83794f]{border-color:var(--color-border-dark);box-shadow:0 0 0 1px var(--color-border-dark)}.team-header[data-v-9f83794f]{display:flex;align-items:center;justify-content:space-between;padding:.4rem .5rem;border-bottom:1px solid var(--color-border);font-size:.82rem;font-weight:700;gap:.4rem}.team-list--a .team-header[data-v-9f83794f]{background:var(--color-team-a);color:var(--color-team-a-dark)}.team-list--b .team-header[data-v-9f83794f]{background:var(--color-team-b);color:var(--color-team-b-dark)}.team-list--active.team-list--a .team-header[data-v-9f83794f],.team-list--active.team-list--b .team-header[data-v-9f83794f]{background:#f9e44a}.team-name[data-v-9f83794f]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.my-turn-bar[data-v-9f83794f]{display:flex;align-items:center;justify-content:space-between;padding:.3rem .5rem;background:#fff9c4;border-bottom:1px solid var(--color-border);gap:.4rem}.my-turn-text[data-v-9f83794f]{font-size:.72rem;font-weight:700;color:var(--color-text);white-space:nowrap}.btn-resign[data-v-9f83794f]{padding:.15rem .5rem;background:var(--color-danger);color:#fff;border:none;border-radius:3px;font-size:.72rem;cursor:pointer;white-space:nowrap;flex-shrink:0}.player-list[data-v-9f83794f]{padding:.25rem;min-height:60px}.player-item[data-v-9f83794f]{display:flex;align-items:center;gap:.3rem;padding:.3rem .4rem;margin-bottom:.15rem;border-radius:3px;background:#fff;border:1px solid transparent;cursor:grab;font-size:.88rem}.player-item--current[data-v-9f83794f]{border-color:var(--color-border-dark);background:#fff9c4;font-weight:700}.order[data-v-9f83794f]{color:var(--color-text-muted);font-size:.72rem;min-width:14px}.name[data-v-9f83794f]{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.turn-indicator[data-v-9f83794f]{font-size:.65rem;color:var(--color-border-dark);background:#fff3cd;border:1px solid var(--color-border-dark);border-radius:2px;padding:0 3px;white-space:nowrap}.player-item--next[data-v-9f83794f]{background:#f0f4ff}.next-indicator[data-v-9f83794f]{font-size:.65rem;color:#1565c0;background:#e3f2fd;border:1px solid #1565c0;border-radius:2px;padding:0 3px;white-space:nowrap}.empty[data-v-9f83794f]{padding:.4rem;font-size:.72rem;color:var(--color-text-muted);text-align:center}.spectator-section[data-v-5ea0cbed]{display:flex;gap:1rem;align-items:flex-start;flex-wrap:wrap}.section-title[data-v-5ea0cbed]{font-size:.75rem;color:var(--color-text-muted);margin-bottom:.3rem}.unassigned-area[data-v-5ea0cbed],.spectator-area[data-v-5ea0cbed]{padding:.5rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface);min-width:120px;min-height:60px}.drag-list[data-v-5ea0cbed]{display:flex;flex-wrap:wrap;gap:.3rem;min-height:32px}.player-chip[data-v-5ea0cbed]{padding:.2rem .6rem;background:#fff;border:1px solid var(--color-border);border-radius:12px;font-size:.85rem;cursor:grab}.spectator-names[data-v-5ea0cbed]{display:flex;flex-wrap:wrap;gap:.3rem}.spectator-name[data-v-5ea0cbed]{font-size:.8rem;color:var(--color-text-muted);padding:.1rem .4rem;background:#eee;border-radius:10px}.overlay[data-v-5b1eadf8]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:50}.modal[data-v-5b1eadf8]{background:var(--color-surface);border:2px solid var(--color-border-dark);border-radius:6px;padding:2rem;width:340px}.modal h2[data-v-5b1eadf8]{margin-bottom:1.5rem;font-size:1.2rem;color:var(--color-border-dark);border-bottom:1px solid var(--color-border);padding-bottom:.5rem}.setting-group[data-v-5b1eadf8]{margin-bottom:1rem}.setting-group label[data-v-5b1eadf8]{display:block;font-size:.85rem;color:var(--color-text-muted);margin-bottom:.3rem}.setting-group select[data-v-5b1eadf8]{width:100%;padding:.5rem;border:1px solid var(--color-border);border-radius:3px;font-family:var(--font-serif);font-size:1rem;background:#fff}.modal-buttons[data-v-5b1eadf8]{display:flex;gap:.5rem;margin-top:1.5rem;flex-wrap:wrap}.btn-save[data-v-5b1eadf8],.btn-start[data-v-5b1eadf8],.btn-cancel[data-v-5b1eadf8]{flex:1;padding:.6rem;border-radius:3px;border:1px solid var(--color-border);font-size:.9rem}.btn-save[data-v-5b1eadf8]{background:var(--color-surface);color:var(--color-text)}.btn-start[data-v-5b1eadf8]{background:var(--color-border-dark);color:#fff;border-color:var(--color-border-dark)}.btn-cancel[data-v-5b1eadf8]{background:#fff;color:var(--color-text-muted)}.error[data-v-5b1eadf8]{margin-top:.5rem;color:var(--color-danger);font-size:.85rem}.room-page[data-v-fe9d4431]{min-height:100vh;display:flex;flex-direction:column}.join-overlay[data-v-fe9d4431]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200}.join-card[data-v-fe9d4431]{background:var(--color-surface);border:2px solid var(--color-border-dark);border-radius:6px;padding:2rem;text-align:center;width:300px}.join-card h2[data-v-fe9d4431]{margin-bottom:1rem;font-size:1.1rem}.join-card input[data-v-fe9d4431]{width:100%;padding:.6rem;margin-bottom:.8rem;border:1px solid var(--color-border);border-radius:3px;font-size:1rem}.join-card button[data-v-fe9d4431]{width:100%;padding:.7rem;background:var(--color-border-dark);color:#fff;border:none;border-radius:3px;font-size:1rem}.room-header[data-v-fe9d4431]{display:flex;align-items:center;padding:.5rem .8rem;background:var(--color-surface);border-bottom:2px solid var(--color-border);gap:.6rem}.logo[data-v-fe9d4431]{font-size:1.2rem;font-weight:700;color:var(--color-border-dark);cursor:pointer;text-decoration:none;white-space:nowrap}.room-name[data-v-fe9d4431]{flex:1;font-size:1.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 480px){.logo[data-v-fe9d4431]{font-size:1rem}.room-name[data-v-fe9d4431]{font-size:.9rem}.player-name[data-v-fe9d4431]{display:none}}.header-right[data-v-fe9d4431]{display:flex;align-items:center;gap:.8rem;position:relative}.player-name[data-v-fe9d4431]{font-size:.9rem;color:var(--color-text-muted)}.menu-btn[data-v-fe9d4431]{background:none;border:1px solid var(--color-border);border-radius:4px;padding:.3rem .6rem;font-size:1rem}.dropdown[data-v-fe9d4431]{position:absolute;top:100%;right:0;background:#fff;border:1px solid var(--color-border);border-radius:4px;box-shadow:0 2px 8px #00000026;z-index:30;min-width:140px}.dropdown button[data-v-fe9d4431]{display:block;width:100%;padding:.6rem 1rem;text-align:left;background:none;border:none;font-size:.9rem;cursor:pointer}.dropdown button[data-v-fe9d4431]:hover{background:var(--color-bg)}.room-main[data-v-fe9d4431]{flex:1;padding:.5rem 1rem;display:flex;flex-direction:column;gap:.5rem;align-items:center}.result-banner[data-v-fe9d4431]{padding:.6rem 1.5rem;border-radius:4px;font-size:1.1rem;text-align:center;width:100%;max-width:600px}@media (max-width: 480px){.result-banner[data-v-fe9d4431]{font-size:.95rem;padding:.5rem 1rem}}.result-banner--a[data-v-fe9d4431]{background:var(--color-team-a);color:var(--color-team-a-dark)}.result-banner--b[data-v-fe9d4431]{background:var(--color-team-b);color:var(--color-team-b-dark)}.game-layout[data-v-fe9d4431]{display:flex;gap:.8rem;align-items:flex-start;width:100%;justify-content:center}.side-panel[data-v-fe9d4431]{flex:0 0 160px}.center-panel[data-v-fe9d4431]{flex:0 0 auto}@media (max-width: 768px){.side-panel[data-v-fe9d4431]{flex:0 0 130px}.game-layout[data-v-fe9d4431]{gap:.5rem}}@media (max-width: 600px){.game-layout[data-v-fe9d4431]{display:grid;grid-template-areas:"board board" "team-a team-b";grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:.4rem;width:100%}.center-panel[data-v-fe9d4431]{grid-area:board;display:flex;justify-content:center}.side-panel--a[data-v-fe9d4431]{grid-area:team-a}.side-panel--b[data-v-fe9d4431]{grid-area:team-b}.side-panel[data-v-fe9d4431]{flex:unset;width:100%}}.waiting-msg[data-v-fe9d4431]{text-align:center;padding:3rem;color:var(--color-text-muted)}.waiting-msg .hint[data-v-fe9d4431]{font-size:.85rem;margin-top:.5rem}.bottom-panel[data-v-fe9d4431]{width:100%;max-width:700px;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface)}@media (max-width: 600px){.bottom-panel[data-v-fe9d4431]{max-width:100%}}.error[data-v-fe9d4431]{color:var(--color-danger);font-size:.85rem;margin-top:.3rem}.rename-overlay[data-v-fe9d4431]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.rename-dialog[data-v-fe9d4431]{background:#fff;border-radius:8px;padding:1.5rem;min-width:280px;display:flex;flex-direction:column;gap:.8rem}.rename-dialog h3[data-v-fe9d4431]{margin:0;font-size:1rem}.rename-dialog input[data-v-fe9d4431]{padding:.5rem;border:1px solid var(--color-border);border-radius:4px;font-size:1rem}.rename-buttons[data-v-fe9d4431]{display:flex;gap:.5rem;justify-content:flex-end}.rename-buttons button[data-v-fe9d4431]{padding:.4rem 1rem;border-radius:4px;border:1px solid var(--color-border);cursor:pointer}.rename-buttons button[data-v-fe9d4431]:first-child{background:var(--color-primary, #4a90e2);color:#fff;border-color:transparent}
