:root{font-family:Microsoft YaHei UI,Segoe UI,sans-serif;color:#f4f4f4;background:#1e1f22}*{box-sizing:border-box}body{margin:0;background:#1e1f22}button{cursor:pointer;border:1px solid #4d5566;background:#2d3442;color:#f4f4f4;border-radius:8px;padding:10px 14px;font-size:14px}button:hover{background:#394154}button:disabled{cursor:not-allowed;opacity:.6}pre{background:#141518;padding:12px;border-radius:10px;overflow:auto;white-space:pre-wrap;word-break:break-word}.page{min-height:100vh;padding:24px;background:#1e1f22}.layout{max-width:1600px;margin:0 auto;display:grid;grid-template-columns:760px 1fr;gap:24px;align-items:start}.left-column{display:flex;flex-direction:column;gap:16px}.right-column{display:flex;flex-direction:column}.panel{width:100%;background:#262a31;border:1px solid #3a404c;border-radius:16px;padding:24px}.section{margin-top:20px}.button-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.ok{color:#7ee787}.error{color:#ff7b72}.board-panel{width:100%;background:#262a31;border:1px solid #3a404c;border-radius:16px;padding:18px}.board-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:8px}.board-cell{aspect-ratio:1 / 1;width:100%;min-width:0;padding:4px;border-radius:12px;border:1px solid #475066;background:#31384a;display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;position:relative;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.board-cell-clickable:hover{background:#3c455a}.board-cell-highlight-drop{background:#35503b;border-color:#62a06f;box-shadow:inset 0 0 0 2px #7ee78738}.board-cell-highlight-eat{background:#5a3939;border-color:#c96b6b;box-shadow:inset 0 0 0 2px #ff7b7238}.board-cell-highlight-muzzle{background:#5a4f34;border-color:#c9b36b;box-shadow:inset 0 0 0 2px #ffd45b3d}.board-cell-highlight-fire{background:#334760;border-color:#6ba4d6;box-shadow:inset 0 0 0 2px #6ea8fe3d}.cell-piece-wrap{flex:1;display:flex;align-items:center;justify-content:center}.piece{width:56px;height:56px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-weight:700;border:2px solid rgba(255,255,255,.16);box-shadow:inset 0 2px 8px #ffffff14}.piece-red{background:#a64040;color:#fff7f7}.piece-blue{background:#4068b0;color:#f6f9ff}.piece-level{font-size:24px;line-height:1}.board-panel-busy{opacity:.82}.board-panel-busy .board-cell{cursor:wait}.pending-auto-box{background:#3d3523;border:1px solid #8f7a3d;border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px}.pending-auto-title{font-size:18px;font-weight:700;color:#ffd86a}.pending-auto-text{color:#f5e8b1;line-height:1.6;white-space:pre-wrap}.pending-auto-button{align-self:flex-start;background:#8c6d1f;border-color:#b99633;color:#fff7da}.pending-auto-button:hover{background:#a57d1a}.record-panel{max-height:280px;overflow-y:auto;border:1px solid #3b4350;border-radius:12px;background:#1b1d22;padding:12px;display:flex;flex-direction:column;gap:8px}.record-line{display:grid;grid-template-columns:42px 1fr;gap:10px;align-items:start;padding:6px 8px;border-radius:8px;background:#242831}.record-index{color:#9aa4bb;font-weight:700}.record-text{color:#f1f4fb;line-height:1.5;white-space:pre-wrap;word-break:break-word}.record-empty{color:#9aa4bb;padding:8px 4px}.piece-preview-wrap{opacity:.72;filter:saturate(.92) brightness(1.08)}.modal-overlay-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;pointer-events:none}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c1094;display:flex;align-items:center;justify-content:center;padding:24px;pointer-events:auto}.modal-mask-hidden{pointer-events:none;opacity:0}.modal-mask-top{pointer-events:auto;opacity:1}.modal-card{width:min(560px,100%);background:#262a31;border:1px solid #434c5d;border-radius:16px;padding:20px;box-shadow:0 18px 60px #00000059}.modal-card-danger{border-color:#7a4b4b}.modal-title{font-size:22px;font-weight:700;margin-bottom:14px}.modal-message{color:#e7ebf4;line-height:1.7;white-space:pre-wrap}.modal-actions{margin-top:18px;display:flex;justify-content:flex-end;gap:10px}.settings-list{display:flex;flex-direction:column;gap:12px}.settings-item{display:flex;align-items:center;gap:10px;color:#eef2fb}.danger-button{background:#7a3434;border-color:#a45050;color:#fff3f3}.danger-button:hover{background:#8e3c3c}.modal-card-gameover{border-color:#5b6478}.gameover-winner{font-size:28px;font-weight:800;color:#ffd86a;margin-bottom:12px}.board-shell{display:flex;flex-direction:column;gap:8px}.board-top-coords{display:grid;grid-template-columns:34px repeat(9,1fr);gap:8px;align-items:center}.board-middle{display:grid;grid-template-columns:34px 1fr;gap:8px}.board-left-coords{display:grid;grid-template-rows:repeat(9,1fr);gap:8px}.board-corner{width:34px;height:34px}.board-outer-coord{display:flex;align-items:center;justify-content:center;color:#b9c3d8;font-size:13px;font-weight:700;-webkit-user-select:none;user-select:none}.board-outer-coord-side{min-height:70px}.board-cell-highlight-fire-red.board-cell-hovered,.board-cell-highlight-fire-blue.board-cell-hovered{box-shadow:0 0 0 2px #ffffff29,0 0 18px #ffffff1f}.board-cell-highlight-muzzle.board-cell-hovered{border-color:#ffe08a;box-shadow:0 0 0 2px #ffd45b47,0 0 18px #ffd45b29}.board-cell-highlight-fire-red{background:#5b3a3a;border-color:#d07878;box-shadow:inset 0 0 0 2px #ff7b7b33}.board-cell-highlight-fire-blue{background:#334b67;border-color:#6fa8e6;box-shadow:inset 0 0 0 2px #6fa8e633}.board-cell-highlight-eat-red{background:#5b3a3a;border-color:#d07878;box-shadow:inset 0 0 0 2px #ff7b7b33}.board-cell-highlight-eat-blue{background:#334b67;border-color:#6fa8e6;box-shadow:inset 0 0 0 2px #6fa8e633}h1{margin:0;font-size:34px;font-weight:800;color:#f7f9fd;letter-spacing:.5px}h2{margin:0 0 10px;font-size:20px;font-weight:700;color:#eaf0fb}.panel{width:100%;background:linear-gradient(180deg,#2a2f37,#242930);border:1px solid #3e4654;border-radius:18px;padding:24px;box-shadow:0 12px 34px #0000002e}.board-panel{width:100%;background:linear-gradient(180deg,#2a2f37,#242930);border:1px solid #3e4654;border-radius:18px;padding:18px;box-shadow:0 12px 34px #0000002e}.right-column-compact .panel{padding:18px}.right-column-compact .section{margin-top:14px}.right-column-compact .record-panel{max-height:220px}.button-grid button,.modal-actions button,.pending-auto-button{min-height:42px;font-weight:600}.settings-group{margin-top:16px;padding:14px 14px 10px;border:1px solid #3b4352;border-radius:12px;background:#1f232a}.settings-group:first-of-type{margin-top:0}.settings-group-title{margin-bottom:12px;font-size:15px;font-weight:800;color:#dbe6fa;letter-spacing:.3px}.settings-list{display:flex;flex-direction:column;gap:10px}.settings-item{display:flex;align-items:center;gap:10px;color:#eef2fb;line-height:1.5;min-height:28px}.settings-item input[type=checkbox]{width:16px;height:16px;accent-color:#6fa8e6}.modal-card{width:min(580px,100%);background:linear-gradient(180deg,#2b3038,#232830);border:1px solid #434c5d;border-radius:18px;padding:22px;box-shadow:0 20px 60px #0000005c}.modal-title{font-size:24px;font-weight:800;margin-bottom:14px;color:#f5f8ff}.modal-message{color:#e7ebf4;line-height:1.75;white-space:pre-wrap}.record-panel{max-height:300px;overflow-y:auto;border:1px solid #3b4350;border-radius:12px;background:#1b1d22;padding:12px;display:flex;flex-direction:column;gap:8px}.record-line{display:grid;grid-template-columns:42px 1fr;gap:10px;align-items:start;padding:8px 10px;border-radius:10px;background:#242831}.pending-auto-box{background:linear-gradient(180deg,#40331d,#3a2e1a);border:1px solid #8f7a3d;border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 24px #0000002e}.pending-auto-title{font-size:18px;font-weight:800;color:#ffd86a}.board-cell{aspect-ratio:1 / 1;width:100%;min-width:0;padding:4px;border-radius:12px;border:1px solid #475066;background:linear-gradient(180deg,#343c4c,#2f3747);display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;position:relative;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .15s ease}.board-cell-clickable:hover{background:linear-gradient(180deg,#3d4659,#364052)}.board-cell-hovered{transform:translateY(-1px);border-color:#8aa4d4;box-shadow:0 0 0 2px #8aa4d433}.cell-coord{font-size:12px;color:#b8c0d4;text-align:left;line-height:1}.cell-arrow{position:absolute;top:6px;right:8px;font-size:18px;font-weight:800;color:#f6e7a6;line-height:1;pointer-events:none;text-shadow:0 1px 4px rgba(0,0,0,.35)}.board-cell-highlight-drop{background:linear-gradient(180deg,#3c5c42,#34503a);border-color:#6daa76;box-shadow:inset 0 0 0 2px #7ee7872e}.board-cell-highlight-muzzle{background:linear-gradient(180deg,#66552f,#584826);border-color:#d6b86b;box-shadow:inset 0 0 0 2px #ffd45b38}.board-cell-highlight-fire-red,.board-cell-highlight-eat-red{background:linear-gradient(180deg,#654040,#593737);border-color:#d07878;box-shadow:inset 0 0 0 2px #ff7b7b33}.board-cell-highlight-fire-blue,.board-cell-highlight-eat-blue{background:linear-gradient(180deg,#39506e,#314762);border-color:#6fa8e6;box-shadow:inset 0 0 0 2px #6fa8e633}.danger-button{background:linear-gradient(180deg,#7f3b3b,#703232);border-color:#a45050;color:#fff3f3}.danger-button:hover{background:linear-gradient(180deg,#934242,#823939)}.menu-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(circle at top,rgba(111,168,230,.12),transparent 36%),linear-gradient(180deg,#1c1e23,#17191d);padding:32px 24px;gap:40px}.menu-header{text-align:center}.menu-title{font-size:52px;font-weight:900;letter-spacing:2px;color:#f7f9fd;margin:0}.menu-subtitle{margin-top:8px;color:#8896b4;font-size:18px}.menu-card{width:min(540px,100%);padding:38px 34px;border-radius:24px;background:linear-gradient(180deg,#2c3139,#232830);border:1px solid #434c5d;box-shadow:0 24px 70px #00000052;text-align:center}.menu-button{min-height:48px;padding:0 24px;font-size:16px;font-weight:700;border:1px solid transparent;border-radius:12px;cursor:pointer;color:#eef3ff}.menu-button-primary,.menu-button-secondary{background:linear-gradient(180deg,#384252,#2f3846);border-color:#56657d}.menu-button-primary:hover,.menu-button-secondary:hover{background:linear-gradient(180deg,#425066,#374457)}.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;width:min(760px,100%)}.mode-grid-bottom{display:flex;justify-content:center;width:min(760px,100%)}.mode-grid-bottom .mode-card{max-width:calc(50% - 12px)}.mode-card{width:100%;padding:30px 28px 26px;border-radius:20px;background:linear-gradient(180deg,#2c3139,#232830);border:1px solid #434c5d;box-shadow:0 16px 48px #00000047;display:flex;flex-direction:column}.mode-card-active{border-color:#4f6d9a;box-shadow:0 16px 48px #00000047,0 0 0 1px #446aa540}.mode-card-disabled{opacity:.72;filter:grayscale(.3)}.mode-status{margin-bottom:8px}.mode-badge{display:inline-block;padding:3px 14px;border-radius:20px;font-size:13px;font-weight:700;letter-spacing:.5px}.mode-badge-live{background:#4caf782e;color:#6fcf8a;border:1px solid rgba(111,207,138,.35)}.mode-badge-dev{background:#e5a75029;color:#e5a750;border:1px solid rgba(229,167,80,.35)}.mode-name{font-size:24px;font-weight:800;color:#eef3ff;margin:10px 0 8px}.mode-desc{font-size:15px;color:#95a3bb;line-height:1.7;margin:0 0 20px;flex:1}.mode-actions{display:flex;flex-direction:column;align-items:center;gap:10px}.mode-button{width:180px;min-height:48px;padding:0 20px;font-size:16px;font-weight:700;border-radius:12px;cursor:pointer;border:1px solid transparent;transition:background .15s}.mode-button-primary{background:linear-gradient(180deg,#446aa5,#38598e);border-color:#5d87ca;color:#fff}.mode-button-primary:hover{background:linear-gradient(180deg,#5077b4,#42659f)}.mode-button-ghost{background:transparent;border-color:#434c5d;color:#8896b4;font-size:14px;min-height:36px}.mode-button-ghost:hover{background:#ffffff0a;color:#bac5db}.mode-button-disabled{background:linear-gradient(180deg,#303540,#282d35);border-color:#3b4352;color:#5a6478;cursor:not-allowed}.danger-actions-panel{margin-top:18px;padding:14px 14px 12px;border:1px solid #5b4040;border-radius:14px;background:linear-gradient(180deg,#2f2424,#281f1f)}.danger-actions-title{margin-bottom:10px;font-size:15px;font-weight:800;color:#ffcbcb}.board-danger-panel{margin-top:0}.danger-actions-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.danger-actions-row-bottom{margin-top:12px;grid-template-columns:1fr}.danger-actions-wide{width:100%}.save-load-list{margin-top:16px;display:flex;flex-direction:column;gap:12px}.save-load-row{display:grid;grid-template-columns:84px 1fr;gap:12px;align-items:center;padding:12px;border-radius:12px;background:#1f232a;border:1px solid #384151}.save-load-slot-label{font-weight:800;color:#e9eef9}.save-load-row-actions{display:flex;gap:10px;flex-wrap:wrap}.record-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.modal-card-gameover{width:min(620px,100%);border-color:#5b6478;text-align:center}.gameover-badge{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:0 12px;border-radius:999px;font-size:13px;font-weight:800;color:#d9e5fa;background:#354055;margin-bottom:14px}.gameover-winner{font-size:34px;font-weight:900;color:#ffd86a;margin-bottom:12px}.gameover-reason{color:#e6ebf4;line-height:1.7}.gameover-summary{margin-top:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.gameover-summary-item{padding:14px 12px;border-radius:12px;background:#1f232a;border:1px solid #394254;display:flex;flex-direction:column;gap:8px}.gameover-summary-item span{color:#aab5ca;font-size:13px}.gameover-summary-item strong{color:#f5f8ff;font-size:22px}.gameover-actions{margin-top:20px;flex-wrap:wrap;justify-content:center}.record-header-actions{display:flex;gap:8px}.record-pagination{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:10px}.record-pagination-text{color:#b9c3d8;font-size:13px}.user-bar{position:absolute;top:20px;right:28px;display:flex;align-items:center;gap:14px}.user-bar-name{color:#bcc5db;font-size:15px;font-weight:700}.user-bar-logout{padding:6px 16px;font-size:13px;border-radius:8px;background:transparent;border:1px solid #4d5566;color:#95a3bb;cursor:pointer}.user-bar-logout:hover{background:#ffffff0f;color:#d0d7e8}.user-bar-info{display:flex;align-items:center;gap:10px}.user-bar-role{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:700;letter-spacing:.5px}.user-bar-role-owner{background:#4a3020;color:#f5c060;border:1px solid #6b4a28}.user-bar-role-admin{background:#1f3040;color:#6db3e0;border:1px solid #305570}.auth-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(circle at top,rgba(111,168,230,.12),transparent 36%),linear-gradient(180deg,#1c1e23,#17191d);padding:32px 24px}.auth-loading{color:#8896b4;font-size:16px}.auth-card{width:min(420px,100%);padding:38px 34px;border-radius:24px;background:linear-gradient(180deg,#2c3139,#232830);border:1px solid #434c5d;box-shadow:0 24px 70px #00000052}.auth-title{text-align:center;font-size:42px;font-weight:900;letter-spacing:2px;color:#f7f9fd;margin:0 0 6px}.auth-subtitle{text-align:center;color:#8896b4;font-size:15px;margin:0 0 28px}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-label{font-size:14px;font-weight:700;color:#bcc5db}.auth-input,.auth-textarea{padding:10px 14px;border-radius:10px;border:1px solid #434c5d;background:#1c1f26;color:#f4f4f4;font-size:15px;font-family:inherit;outline:none;transition:border-color .15s}.auth-input:focus,.auth-textarea:focus{border-color:#5d87ca}.auth-input:disabled,.auth-textarea:disabled{opacity:.6}.auth-textarea{resize:vertical;min-height:80px}.auth-error{background:#3d2020;border:1px solid #6b4040;border-radius:10px;padding:10px 14px;color:#f5a0a0;font-size:14px}.auth-button{min-height:48px;padding:0 24px;font-size:16px;font-weight:700;border:1px solid #5d87ca;border-radius:12px;background:linear-gradient(180deg,#446aa5,#38598e);color:#fff;cursor:pointer;margin-top:4px;transition:background .15s}.auth-button:hover{background:linear-gradient(180deg,#5077b4,#42659f)}.auth-button:disabled{cursor:not-allowed;opacity:.6}.auth-link-row{margin-top:22px;text-align:center;color:#75829a;font-size:14px}.auth-link{color:#7ea5da;text-decoration:none;font-weight:700}.auth-link:hover{text-decoration:underline}.user-page{min-height:100vh;display:grid;grid-template-columns:240px 1fr;background:#1e1f22}.user-sidebar{background:#1a1c21;border-right:1px solid #333946;padding:24px 0;display:flex;flex-direction:column}.user-sidebar-header{padding:0 20px;margin-bottom:24px}.user-back-button{background:transparent;border:1px solid #3b4252;color:#95a3bb;padding:7px 14px;border-radius:8px;font-size:14px;cursor:pointer}.user-back-button:hover{background:#ffffff0d;color:#d0d7e8}.user-sidebar-avatar{display:flex;flex-direction:column;align-items:center;padding:0 20px 24px;border-bottom:1px solid #2a2f38;margin-bottom:12px}.user-avatar-circle{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#446aa5,#38598e);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;margin-bottom:12px}.user-sidebar-name{font-size:18px;font-weight:800;color:#eef3ff;margin-bottom:6px}.user-sidebar-role{display:inline-block;padding:2px 12px;border-radius:12px;font-size:12px;font-weight:700;background:#2a3040;color:#95a3bb;border:1px solid #3b4252}.user-sidebar-role-owner{background:#4a3020;color:#f5c060;border-color:#6b4a28}.user-sidebar-role-admin{background:#1f3040;color:#6db3e0;border-color:#305570}.user-sidebar-nav{display:flex;flex-direction:column;padding:0 12px}.user-nav-item{background:transparent;border:none;color:#8896b4;padding:11px 16px;border-radius:10px;font-size:15px;font-weight:600;text-align:left;cursor:pointer;transition:background .12s,color .12s}.user-nav-item:hover{background:#ffffff0a;color:#d0d7e8}.user-nav-item-active{background:#2a3140;color:#eef3ff}.user-content{padding:32px 40px;overflow-y:auto}.user-content-loading,.user-content-error{color:#8896b4;font-size:16px;padding:40px 0}.user-content-error{color:#f5a0a0}.user-panel{max-width:680px}.user-panel-title{font-size:24px;font-weight:900;color:#f7f9fd;margin:0 0 6px}.user-panel-desc{color:#75829a;font-size:14px;margin:0 0 28px}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}.info-item{padding:16px 18px;border-radius:12px;background:#262a31;border:1px solid #363c49;display:flex;flex-direction:column;gap:6px}.info-label{font-size:13px;color:#75829a;font-weight:600}.info-value{font-size:16px;color:#eef3ff;font-weight:700}.info-section{margin-bottom:28px;padding:22px 24px;border-radius:14px;background:#262a31;border:1px solid #363c49}.info-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.info-section-title{font-size:16px;font-weight:800;color:#d0d7e8;margin:0}.info-edit-button{background:transparent;border:1px solid #4d5566;color:#95a3bb;padding:5px 14px;border-radius:7px;font-size:13px;cursor:pointer}.info-edit-button:hover{background:#ffffff0d;color:#d0d7e8}.info-intro-text{color:#bcc5db;font-size:15px;line-height:1.7;margin:0;white-space:pre-wrap}.info-edit-form{display:flex;flex-direction:column;gap:12px}.info-textarea,.info-input{padding:10px 14px;border-radius:10px;border:1px solid #434c5d;background:#1c1f26;color:#f4f4f4;font-size:15px;font-family:inherit;outline:none;transition:border-color .15s}.info-textarea:focus,.info-input:focus{border-color:#5d87ca}.info-textarea{resize:vertical;min-height:80px}.info-field{display:flex;flex-direction:column;gap:6px}.info-field-label{font-size:14px;font-weight:600;color:#95a3bb}.info-edit-actions{display:flex;gap:10px}.info-save-button{padding:8px 20px;border-radius:8px;border:1px solid #5d87ca;background:linear-gradient(180deg,#446aa5,#38598e);color:#fff;font-size:14px;font-weight:700;cursor:pointer}.info-save-button:hover{background:linear-gradient(180deg,#5077b4,#42659f)}.info-save-button:disabled{opacity:.6;cursor:not-allowed}.info-cancel-button{padding:8px 20px;border-radius:8px;border:1px solid #4d5566;background:transparent;color:#95a3bb;font-size:14px;cursor:pointer}.info-cancel-button:hover{background:#ffffff0d;color:#d0d7e8}.info-message{padding:10px 14px;border-radius:10px;font-size:14px;font-weight:600}.info-message-error{background:#3d2020;border:1px solid #6b4040;color:#f5a0a0}.info-message-success{background:#1f3030;border:1px solid #305050;color:#70c0a0}.settings-group{margin-bottom:24px}.settings-group-title{font-size:14px;font-weight:800;color:#8896b4;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #333946}.settings-list{display:flex;flex-direction:column;gap:8px}.settings-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;color:#c5cdde;font-size:14px;cursor:pointer;transition:background .1s}.settings-item:hover{background:#ffffff08}.settings-item input[type=checkbox]{accent-color:#5d87ca;width:16px;height:16px;cursor:pointer}.settings-item input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.settings-actions{margin-top:24px}.user-bar-name-link{background:transparent!important;border:none!important;padding:0!important;cursor:pointer;color:#bcc5db;font-size:15px;font-weight:700;text-decoration:none}.user-bar-name-link:hover{color:#eef3ff;text-decoration:underline}.room-selection-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(circle at top,rgba(111,168,230,.12),transparent 36%),linear-gradient(180deg,#1c1e23,#17191d);padding:32px 24px;gap:32px}.room-selection-header{text-align:center}.room-selection-header h1{font-size:42px;font-weight:900;letter-spacing:2px;color:#f7f9fd;margin:0}.room-selection-header p{margin-top:8px;color:#8896b4;font-size:16px}.room-error{background:#3d2020;border:1px solid #6b4040;border-radius:10px;padding:10px 18px;color:#f5a0a0;font-size:14px;max-width:600px;text-align:center}.room-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;width:min(760px,100%)}.room-card{width:100%;padding:30px 28px 26px;border-radius:20px;background:linear-gradient(180deg,#2c3139,#232830);border:1px solid #434c5d;box-shadow:0 16px 48px #00000047;display:flex;flex-direction:column}.room-card-create{border-color:#4f6d9a;box-shadow:0 16px 48px #00000047,0 0 0 1px #446aa540}.room-card h2{font-size:22px;font-weight:800;color:#eef3ff;margin:0 0 8px}.room-card p{font-size:15px;color:#95a3bb;line-height:1.7;margin:0 0 20px;flex:1}.room-card-button{min-height:44px;padding:0 20px;font-size:15px;font-weight:700;border-radius:12px;cursor:pointer;border:1px solid transparent;transition:background .15s}.room-card-button-primary{background:linear-gradient(180deg,#446aa5,#38598e);border-color:#5d87ca;color:#fff}.room-card-button-primary:hover{background:linear-gradient(180deg,#5077b4,#42659f)}.room-card-button-primary:disabled{opacity:.6;cursor:not-allowed}.join-by-code{margin-bottom:20px}.join-code-label{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:700;color:#8896b4;margin-bottom:8px}.join-code-row{display:flex;gap:10px}.join-code-input{flex:1;padding:10px 14px;border-radius:10px;border:1px solid #434c5d;background:#1c1f26;color:#f4f4f4;font-size:18px;font-family:Courier New,monospace;letter-spacing:4px;text-transform:uppercase;outline:none;transition:border-color .15s}.join-code-input:focus{border-color:#5d87ca}.join-code-input::placeholder{letter-spacing:1px;color:#556;font-size:14px}.room-list-section{border-top:1px solid #333946;padding-top:16px}.room-refresh-button{background:transparent;border:1px solid #3b4252;color:#95a3bb;padding:4px 12px;border-radius:6px;font-size:12px;cursor:pointer}.room-refresh-button:hover{background:#ffffff0d;color:#d0d7e8}.room-list-empty{color:#5a6478;font-size:14px;text-align:center;padding:16px 0}.room-list{display:flex;flex-direction:column;gap:8px;max-height:240px;overflow-y:auto}.room-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:10px;background:#1f232a;border:1px solid #333946}.room-list-item-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.room-list-code{font-family:Courier New,monospace;font-size:16px;font-weight:800;color:#eef3ff;letter-spacing:2px}.room-list-players{font-size:13px;color:#95a3bb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-list-count{font-size:12px;color:#5a6478;white-space:nowrap}.room-list-join-button{padding:6px 16px;font-size:13px;font-weight:700;border-radius:8px;cursor:pointer;border:1px solid #5d87ca;background:linear-gradient(180deg,#446aa5,#38598e);color:#fff;white-space:nowrap}.room-list-join-button:hover{background:linear-gradient(180deg,#5077b4,#42659f)}.room-list-join-button:disabled{background:#303540;border-color:#3b4352;color:#5a6478;cursor:not-allowed}.room-back-button{background:transparent;border:1px solid #3b4252;color:#95a3bb;padding:8px 24px;border-radius:10px;font-size:14px;cursor:pointer}.room-back-button:hover{background:#ffffff0d;color:#d0d7e8}.room-game-page{min-height:100vh;display:flex;flex-direction:column;background:#1e1f22}.room-info-bar{display:flex;align-items:center;justify-content:space-between;padding:6px 20px;background:#1a1c21;border-bottom:1px solid #333946;min-height:38px}.room-info-bar-left{flex:1}.room-info-bar-title{font-size:14px;font-weight:800;color:#bcc5db}.room-info-bar-center{display:flex;align-items:center;gap:10px}.room-info-bar-code{font-family:Courier New,monospace;font-size:14px;font-weight:800;color:#eef3ff;letter-spacing:3px;cursor:pointer;padding:2px 10px;border-radius:6px;transition:background .15s}.room-info-bar-code:hover{background:#ffffff14}.room-info-bar-right{flex:1;text-align:right}.room-info-turn-indicator{font-size:12px;font-weight:700;color:#8896b4;padding:3px 10px;border-radius:6px;background:#ffffff0a}.room-info-disconnected{font-size:12px;color:#e5a750;font-weight:600}.chat-panel{display:flex;flex-direction:column;width:100%;max-width:100%;overflow:hidden}.chat-panel-title{font-size:13px;font-weight:800;color:#8896b4;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #333946}.chat-message-list{width:100%;max-width:100%;height:140px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:4px;padding:4px 0;margin-bottom:8px;background:#1a1c21;border-radius:8px;border:1px solid #2a2f38}.chat-empty{color:#4a5568;font-size:13px;text-align:center;padding:20px 0}.chat-message{padding:3px 10px;font-size:13px;line-height:1.5;word-break:break-all;overflow-wrap:break-word;max-width:100%}.chat-message-sender{font-weight:700;white-space:nowrap}.chat-message-red .chat-message-sender{color:#e08080}.chat-message-blue .chat-message-sender{color:#6fa8e6}.chat-message-text{color:#c5cdde;word-break:break-all;overflow-wrap:break-word}.chat-input-row{display:flex;gap:8px;width:100%;max-width:100%}.chat-input{flex:1;min-width:0;padding:7px 10px;border-radius:8px;border:1px solid #434c5d;background:#1c1f26;color:#f4f4f4;font-size:13px;font-family:inherit;outline:none;transition:border-color .15s}.chat-input:focus{border-color:#5d87ca}.chat-input:disabled{opacity:.5}.chat-send-button{padding:7px 14px;font-size:13px;font-weight:700;border-radius:8px;cursor:pointer;border:1px solid #5d87ca;background:linear-gradient(180deg,#446aa5,#38598e);color:#fff;white-space:nowrap;flex-shrink:0}.chat-send-button:hover{background:linear-gradient(180deg,#5077b4,#42659f)}.chat-send-button:disabled{opacity:.5;cursor:not-allowed}.chat-char-count{text-align:right;font-size:11px;color:#556;margin-top:2px}.room-info-panel{width:100%;max-width:100%;overflow:hidden}.room-info-panel-title{font-size:13px;font-weight:800;color:#8896b4;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #333946}.room-info-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;gap:8px;max-width:100%;overflow:hidden}.room-info-label{font-size:13px;font-weight:600;color:#95a3bb;white-space:nowrap;flex-shrink:0}.room-info-value{font-size:13px;color:#c5cdde;text-align:right;word-break:break-all;overflow-wrap:break-word;min-width:0}.room-info-code-value{font-family:Courier New,monospace;font-size:14px;font-weight:800;color:#eef3ff;letter-spacing:2px;cursor:pointer;text-align:right;word-break:break-all}.room-info-code-value:hover{color:#6fa8e6}.room-info-status{display:inline-block;margin-left:6px;font-size:11px;font-weight:700;padding:1px 6px;border-radius:4px}.room-info-status-online{color:#6fcf8a;background:#4caf781f}.room-info-status-offline{color:#e5a750;background:#e5a7501f}.room-waiting{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px}.room-waiting-card{text-align:center;padding:48px 40px;border-radius:24px;background:linear-gradient(180deg,#2c3139,#232830);border:1px solid #434c5d;box-shadow:0 24px 70px #00000052;max-width:440px;width:100%}.room-waiting-card h2{font-size:28px;font-weight:900;color:#f7f9fd;margin:0 0 16px}.room-waiting-code{font-size:18px;color:#95a3bb;margin:0 0 12px}.room-waiting-code strong{font-family:Courier New,monospace;font-size:28px;letter-spacing:4px;color:#eef3ff}.room-waiting-hint{color:#6a7590;font-size:14px;margin:0 0 28px}.room-waiting-copy{padding:12px 32px;font-size:16px;font-weight:700;border-radius:12px;border:1px solid #5d87ca;background:linear-gradient(180deg,#446aa5,#38598e);color:#fff;cursor:pointer;margin-bottom:12px}.room-waiting-copy:hover{background:linear-gradient(180deg,#5077b4,#42659f)}.room-waiting-leave{display:block;margin:0 auto;background:transparent;border:1px solid #3b4252;color:#95a3bb;padding:8px 20px;border-radius:8px;font-size:14px;cursor:pointer}.room-waiting-leave:hover{background:#ffffff0d;color:#d0d7e8}
