/* 国际象棋页面补充样式（叠加在 style.css 之上） */

.chess-coin { font-family: inherit; font-size: 19px; color: #2b2b2b; }
.btn-sm { padding: 8px 12px; font-size: 13px; text-decoration: none; display: inline-flex; align-items: center; gap: 4px; }

.chess-wrap { max-width: min(78vh, 560px); }

/* 手机：上下布局时 .board-area 高度由内容决定，wrapper 的 height:100% 失效，
   canvas 取 min(宽,高) 会卡死在下限。用 aspect-ratio 让 wrapper 高度跟随宽度，
   棋盘铺满屏宽。 */
@media (max-width: 820px) {
  .chess-wrap {
    max-width: min(94vw, 460px);
    height: auto;
    aspect-ratio: 1 / 1;
  }
  .palette-btn { font-size: 28px; }
  .promo-btn { width: 58px; height: 58px; font-size: 36px; }
}

/* 摆棋调色板 */
.palette-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 14px; padding: 12px 14px;
}
.palette-row { display: flex; gap: 6px; margin-bottom: 6px; }
.palette-btn {
  flex: 1; aspect-ratio: 1; min-width: 0; font-size: 24px; line-height: 1;
  background: rgba(0, 0, 0, .22); border: 1px solid var(--line); border-radius: 10px;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .12s; padding: 0;
}
.palette-btn.white-piece { color: #faf3e3; text-shadow: 0 0 2px #33251a, 0 0 2px #33251a; }
.palette-btn.black-piece { color: #26201a; text-shadow: 0 0 2px rgba(245, 235, 215, .8), 0 0 2px rgba(245, 235, 215, .8); }
.palette-btn.eraser { font-size: 17px; color: var(--txt-dim); }
.palette-btn:hover { border-color: var(--gold); }
.palette-btn.active { border-color: var(--gold); background: rgba(224, 160, 8, .22); box-shadow: 0 0 0 1px var(--gold) inset; }

.setup-options { margin-bottom: 4px; }
.setup-tip {
  font-size: 12.5px; color: var(--txt-dim); line-height: 1.6;
  background: rgba(224, 160, 8, .08); border-left: 2px solid var(--gold);
  padding: 8px 11px; border-radius: 6px;
}

/* 对局中控制卡（谁来走 / 段位） */
.ctrl-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 14px; padding: 11px 14px;
}
.ctrl-title { font-size: 12px; color: var(--txt-dim); margin-bottom: 8px; }
.ctrl-row { display: flex; gap: 12px; flex-wrap: wrap; }

/* 升变选择 */
.promo-row { display: flex; gap: 10px; justify-content: center; }
.promo-btn {
  width: 64px; height: 64px; font-size: 40px; line-height: 1;
  background: var(--panel2); border: 1px solid var(--line); border-radius: 12px;
  cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .12s;
}
.promo-btn.white-piece { color: #faf3e3; text-shadow: 0 0 2px #33251a, 0 0 3px #33251a; }
.promo-btn.black-piece { color: #26201a; text-shadow: 0 0 2px rgba(245, 235, 215, .85), 0 0 3px rgba(245, 235, 215, .85); }
.promo-btn:hover { border-color: var(--gold); transform: scale(1.06); }

/* 棋谱（SAN 双列） */
.move-row.chess { grid-template-columns: 34px 1fr 1fr; }
.mv.white { color: #f3e7d4; }
.mv.blackp { color: #9fb6d6; }

