: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}.save-load-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.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}.settings-danger-group{margin-top:18px;display:flex;gap:12px;flex-wrap:wrap}.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,.save-load-grid 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;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:24px}.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-title{font-size:56px;font-weight:900;letter-spacing:2px;color:#f7f9fd}.menu-subtitle{margin-top:10px;color:#bac5db;font-size:18px}.menu-actions{margin-top:28px;display:flex;flex-direction:column;align-items:center;gap:12px}.menu-button{width:220px;min-height:54px;padding:0 22px;font-size:18px;font-weight:700;border-radius:12px}.menu-button-primary{background:linear-gradient(180deg,#446aa5,#38598e);border-color:#5d87ca}.menu-button-primary:hover{background:linear-gradient(180deg,#5077b4,#42659f)}.menu-button-secondary{background:linear-gradient(180deg,#384252,#2f3846);border-color:#56657d;color:#eef3ff}.menu-button-secondary:hover{background:linear-gradient(180deg,#425066,#374457)}.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}.record-header-meta{color:#aab5ca;font-size:13px;font-weight:600}.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}
