:root {
  --bg: #f3f6f7;
  --surface: #ffffff;
  --text: #17202a;
  --muted: #637083;
  --line: #dce4eb;
  --accent: #0f766e;
  --accent-strong: #0a5c56;
  --gold: #f5b73d;
  --shadow: 0 14px 34px rgba(22, 33, 45, 0.08);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  overflow-x: hidden;
  overflow-y: auto;
  background: radial-gradient(circle at top left, #fff8e8 0, #f3f6f7 34%, #eef4f2 100%);
  color: var(--text);
  font-family: Inter, "Segoe UI", Arial, sans-serif;
}

button,
a {
  font: inherit;
}

button {
  border: 0;
  border-radius: 8px;
  padding: 11px 16px;
  background: var(--accent);
  color: #fff;
  cursor: pointer;
}

button:hover {
  background: var(--accent-strong);
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

button.secondary {
  color: var(--text);
  background: #e8eef2;
}

.game-shell {
  width: min(1320px, calc(100vw - 28px));
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto auto auto auto;
  gap: 10px;
  margin: 0 auto;
  overflow: visible;
  padding: 12px 0;
}

.topbar,
.status-strip,
.opponents-panel,
.panel,
.market-panel {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 20px 22px;
}

.back-link {
  display: inline-flex;
  margin-bottom: 8px;
  color: var(--accent);
  text-decoration: none;
  font-weight: 700;
}

h1,
h2,
p {
  margin: 0;
}

h1 {
  font-size: 30px;
}

h2 {
  font-size: 18px;
}

.topbar p,
.market-head p,
.hint {
  color: var(--muted);
  line-height: 1.6;
  overflow-wrap: anywhere;
}

.score-card {
  min-width: 140px;
  padding: 14px 16px;
  border-radius: 8px;
  background: #f7fbfa;
  border: 1px solid var(--line);
}

.score-card span,
.status-box span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  margin-bottom: 5px;
}

.score-card strong,
.status-box strong {
  font-size: 24px;
}

.status-strip {
  display: grid;
  grid-template-columns: minmax(210px, 0.9fr) minmax(360px, 1.2fr) auto;
  align-items: center;
  gap: 12px;
  margin: 0;
  padding: 14px 16px;
}

.player-quick {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  min-width: 0;
}

.quick-stat {
  display: grid;
  gap: 7px;
  min-width: 0;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.68);
}

.quick-stat > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.quick-token-row {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 5px;
}

.quick-token {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  min-width: 0;
  min-height: 27px;
  border: 1px solid rgba(220, 228, 235, 0.9);
  border-radius: 999px;
  background: #fff;
}

.quick-token .gem img {
  width: 18px;
  height: 18px;
}

.quick-token strong {
  font-size: 12px;
}

.status-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.opponents-panel {
  display: grid;
  gap: 12px;
  padding: 16px;
}

.opponents-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
}

.opponents-head p {
  color: var(--muted);
  line-height: 1.5;
}

.opponents-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.opponent-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(240, 248, 247, 0.82)),
    repeating-linear-gradient(45deg, rgba(15, 118, 110, 0.05) 0 8px, transparent 8px 16px);
}

.opponent-card.danger {
  border-color: rgba(220, 38, 38, 0.28);
  box-shadow: inset 0 0 0 1px rgba(220, 38, 38, 0.08);
}

.opponent-top {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.opponent-top div {
  min-width: 0;
}

.opponent-top strong,
.opponent-top span {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.opponent-top span {
  color: var(--muted);
  font-size: 12px;
  margin-top: 3px;
}

.opponent-avatar {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  flex: 0 0 auto;
  border-radius: 50%;
  background: #10243a;
  color: #fff;
  font-weight: 900;
}

.opponent-score {
  font-size: 22px;
  font-weight: 900;
}

.opponent-tokens {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 5px;
}

.opponent-token {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  min-width: 0;
  padding: 4px 3px;
  border: 1px solid rgba(220, 228, 235, 0.86);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
}

.opponent-token .gem img {
  width: 17px;
  height: 17px;
}

.opponent-token strong {
  font-size: 12px;
}

.opponent-meta {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.opponent-meta span {
  padding: 4px 7px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: var(--muted);
  font-size: 12px;
}

.layout {
  display: grid;
  grid-template-columns: minmax(360px, 380px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  min-height: 0;
  overflow: visible;
}

.player-panel {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 14px;
  align-content: start;
  min-width: 0;
  min-height: 0;
  overflow: visible;
  position: sticky;
  top: 12px;
}

.player-panel .opponents-head {
  align-items: flex-start;
}

.player-panel .opponents-head p {
  display: none;
}

.player-panel .opponents-grid {
  grid-template-columns: 1fr;
}

.player-panel .opponent-card {
  gap: 7px;
  padding: 10px;
}

.player-panel .opponent-card {
  grid-template-columns: minmax(0, 1fr);
}

.player-panel .opponent-top {
  gap: 8px;
}

.player-panel .opponent-avatar {
  width: 32px;
  height: 32px;
}

.player-panel .opponent-score {
  font-size: 19px;
}

.player-stats-panel {
  display: none;
}

.panel,
.market-panel {
  padding: 16px;
  min-width: 0;
}

.bank,
.token-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.bank {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.token-grid.compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.chip-button,
.token-stat {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  background: #fff;
  color: var(--text);
  min-width: 0;
}

.chip-button.selected {
  outline: 3px solid rgba(15, 118, 110, 0.2);
  border-color: var(--accent);
}

.gem {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.gem img {
  display: block;
  width: 31px;
  height: 31px;
  object-fit: contain;
  filter: drop-shadow(0 4px 5px rgba(15, 23, 42, 0.2));
}

.gem-label {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.cost-item .gem img,
.reserved-main .gem img {
  width: 25px;
  height: 25px;
}

.cost-item .gem-label {
  font-size: 12px;
}

.token-grid.compact .gem img {
  width: 28px;
  height: 28px;
}

.gem-icon-only {
  flex: 0 0 auto;
}

.market-panel {
  min-width: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  min-height: 0;
  overflow: visible;
}

.market-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.market {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px;
  min-height: 0;
  overflow: visible;
  padding-right: 4px;
}

.card {
  position: relative;
  min-width: 0;
  min-height: 196px;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
  box-shadow: 0 10px 22px rgba(22, 33, 45, 0.06);
  overflow: hidden;
}

.card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.38), transparent 40%, rgba(255, 255, 255, 0.26));
}

.card.score-2,
.card.score-3,
.card.score-4 {
  border-color: rgba(217, 181, 83, 0.46);
}

.card.score-3,
.card.score-4 {
  box-shadow: 0 16px 30px rgba(22, 33, 45, 0.11), inset 0 0 0 1px rgba(255, 229, 143, 0.42);
}

.card.score-4 {
  border-color: rgba(191, 137, 29, 0.62);
  box-shadow: 0 18px 36px rgba(22, 33, 45, 0.14), inset 0 0 0 1px rgba(255, 235, 164, 0.62);
}

.card.score-3::before,
.card.score-4::before {
  opacity: 1;
}

.card.red { background: linear-gradient(160deg, #fff, #fff2f2); }
.card.green { background: linear-gradient(160deg, #fff, #eef9f3); }
.card.blue { background: linear-gradient(160deg, #fff, #edf5ff); }
.card.white { background: linear-gradient(160deg, #fff, #faf7ed); }
.card.black { background: linear-gradient(160deg, #fff, #eef0f4); }

.card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.card-name {
  font-weight: 800;
  overflow-wrap: anywhere;
}

.points {
  display: inline-flex;
  min-width: 34px;
  height: 34px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #17202a;
  color: #fff;
  font-weight: 800;
  box-shadow: 0 6px 12px rgba(15, 23, 42, 0.2);
}

.score-2 .points {
  background: linear-gradient(135deg, #17202a, #47606e);
}

.score-3 .points {
  background: linear-gradient(135deg, #825c10, #f0b84a);
}

.score-4 .points {
  background: linear-gradient(135deg, #53320b, #e9a82f 48%, #fff0a6);
  color: #1d1607;
}

.card-art {
  position: relative;
  display: grid;
  grid-template-rows: 1fr auto;
  place-items: center;
  min-height: 112px;
  overflow: hidden;
  border-radius: 8px;
  background:
    radial-gradient(circle at 30% 22%, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0) 36%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.24)),
    repeating-linear-gradient(45deg, rgba(15, 118, 110, 0.08) 0 8px, transparent 8px 16px);
  border: 1px solid rgba(255, 255, 255, 0.72);
}

.card-art::before,
.card-art::after {
  content: "";
  position: absolute;
  pointer-events: none;
  opacity: 0;
}

.card-art::before {
  inset: 9px;
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, 0.68);
}

.card-art::after {
  inset: -40%;
  background: conic-gradient(from 0deg, transparent, rgba(255, 255, 255, 0.72), transparent, rgba(255, 228, 136, 0.62), transparent);
}

.card-art.red {
  background:
    radial-gradient(circle at 32% 25%, rgba(255, 255, 255, 0.95), transparent 35%),
    linear-gradient(160deg, rgba(255, 244, 244, 0.96), rgba(255, 214, 219, 0.45)),
    repeating-linear-gradient(45deg, rgba(175, 31, 54, 0.09) 0 8px, transparent 8px 16px);
}

.card-art.green {
  background:
    radial-gradient(circle at 32% 25%, rgba(255, 255, 255, 0.96), transparent 35%),
    linear-gradient(160deg, rgba(240, 252, 246, 0.96), rgba(198, 238, 213, 0.48)),
    repeating-linear-gradient(45deg, rgba(33, 130, 83, 0.1) 0 8px, transparent 8px 16px);
}

.card-art.blue {
  background:
    radial-gradient(circle at 32% 25%, rgba(255, 255, 255, 0.96), transparent 35%),
    linear-gradient(160deg, rgba(239, 247, 255, 0.98), rgba(197, 224, 255, 0.5)),
    repeating-linear-gradient(45deg, rgba(30, 93, 163, 0.1) 0 8px, transparent 8px 16px);
}

.card-art.white {
  background:
    radial-gradient(circle at 32% 25%, rgba(255, 255, 255, 0.98), transparent 35%),
    linear-gradient(160deg, rgba(255, 253, 244, 0.98), rgba(231, 234, 238, 0.58)),
    repeating-linear-gradient(45deg, rgba(118, 128, 141, 0.1) 0 8px, transparent 8px 16px);
}

.card-art.black {
  background:
    radial-gradient(circle at 32% 25%, rgba(255, 255, 255, 0.7), transparent 32%),
    linear-gradient(160deg, rgba(248, 250, 252, 0.96), rgba(203, 210, 219, 0.56)),
    repeating-linear-gradient(45deg, rgba(15, 23, 42, 0.11) 0 8px, transparent 8px 16px);
}

.xiaobo-card-portrait {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 98px;
  height: 94px;
  border-radius: 24px;
  transform: translateY(0);
  overflow: visible;
}

.xiaobo-card-portrait::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 92px;
  height: 56px;
  border-radius: 42px 42px 16px 16px;
  transform: translateX(-50%);
  background:
    radial-gradient(circle at 20% 26%, rgba(255, 255, 255, 0.72) 0 6px, transparent 7px),
    radial-gradient(circle at 82% 30%, rgba(255, 255, 255, 0.52) 0 5px, transparent 6px),
    linear-gradient(135deg, rgba(45, 78, 115, 0.86), rgba(96, 116, 166, 0.9));
  border: 1px solid rgba(255, 255, 255, 0.72);
  box-shadow: 0 12px 20px rgba(17, 24, 39, 0.12);
}

.xiaobo-card-img {
  position: relative;
  z-index: 2;
  width: 96px;
  height: 96px;
  object-fit: cover;
  object-position: 50% 28%;
  border-radius: 28px 28px 22px 22px;
  border: 2px solid rgba(255, 255, 255, 0.78);
  background: #fbf2df;
  box-shadow:
    0 14px 24px rgba(15, 23, 42, 0.18),
    inset 0 0 0 1px rgba(255, 255, 255, 0.5);
}

.xiaobo-ear {
  position: absolute;
  top: 2px;
  width: 26px;
  height: 32px;
  border-radius: 8px 18px 8px 18px;
  background: linear-gradient(145deg, #8f8179, #f5e9df 62%);
  border: 2px solid rgba(78, 67, 61, 0.18);
}

.xiaobo-ear::after {
  content: "";
  position: absolute;
  inset: 7px 6px 5px;
  border-radius: inherit;
  background: rgba(255, 181, 196, 0.55);
}

.xiaobo-ear.left {
  left: 12px;
  transform: rotate(-22deg);
}

.xiaobo-ear.right {
  right: 12px;
  transform: scaleX(-1) rotate(-22deg);
}

.xiaobo-face {
  position: relative;
  width: 68px;
  height: 58px;
  margin-top: 10px;
  border-radius: 48% 48% 44% 44%;
  background:
    radial-gradient(circle at 34% 55%, #fff 0 16px, transparent 17px),
    radial-gradient(circle at 66% 55%, #fff 0 16px, transparent 17px),
    linear-gradient(90deg, #7f746e 0 28%, #f7f0e8 28% 68%, #6f6764 68%);
  border: 2px solid rgba(70, 62, 58, 0.14);
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.18);
}

.xiaobo-eye {
  position: absolute;
  top: 19px;
  width: 9px;
  height: 12px;
  border-radius: 50%;
  background: radial-gradient(circle at 34% 28%, #fff 0 2px, #2a3950 3px 8px, #111827 9px);
}

.xiaobo-eye.left {
  left: 20px;
}

.xiaobo-eye.right {
  right: 20px;
}

.xiaobo-nose {
  position: absolute;
  left: 50%;
  top: 34px;
  width: 9px;
  height: 7px;
  border-radius: 50% 50% 60% 60%;
  background: #e98ca3;
  transform: translateX(-50%);
}

.xiaobo-muzzle {
  position: absolute;
  left: 50%;
  bottom: 7px;
  width: 28px;
  height: 12px;
  border-radius: 50%;
  border-bottom: 2px solid rgba(98, 82, 74, 0.34);
  transform: translateX(-50%);
}

.xiaobo-collar {
  position: absolute;
  left: 50%;
  bottom: 3px;
  z-index: 4;
  display: grid;
  place-items: center;
  width: 44px;
  height: 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, #352b62, #6f5aa6);
  border: 1px solid rgba(255, 255, 255, 0.7);
  transform: translateX(-50%);
}

.xiaobo-collar img {
  width: 18px;
  height: 18px;
  filter: drop-shadow(0 3px 4px rgba(15, 23, 42, 0.28));
}

.card-art.red .xiaobo-card-portrait::before {
  background:
    radial-gradient(circle at 28% 36%, rgba(255, 255, 255, 0.78) 0 5px, transparent 6px),
    radial-gradient(circle at 72% 34%, rgba(255, 230, 230, 0.55) 0 4px, transparent 5px),
    linear-gradient(135deg, rgba(123, 34, 47, 0.9), rgba(221, 88, 96, 0.9));
}

.card-art.green .xiaobo-card-portrait::before {
  background:
    radial-gradient(circle at 28% 36%, rgba(255, 255, 255, 0.78) 0 5px, transparent 6px),
    radial-gradient(circle at 72% 34%, rgba(220, 255, 232, 0.56) 0 4px, transparent 5px),
    linear-gradient(135deg, rgba(24, 103, 69, 0.9), rgba(79, 171, 117, 0.9));
}

.card-art.blue .xiaobo-card-portrait::before {
  background:
    radial-gradient(circle at 28% 36%, rgba(255, 255, 255, 0.78) 0 5px, transparent 6px),
    radial-gradient(circle at 72% 34%, rgba(224, 242, 255, 0.56) 0 4px, transparent 5px),
    linear-gradient(135deg, rgba(30, 82, 139, 0.92), rgba(80, 155, 213, 0.9));
}

.card-art.white .xiaobo-card-portrait::before {
  background:
    radial-gradient(circle at 28% 36%, rgba(255, 255, 255, 0.88) 0 5px, transparent 6px),
    radial-gradient(circle at 72% 34%, rgba(255, 242, 196, 0.5) 0 4px, transparent 5px),
    linear-gradient(135deg, rgba(206, 211, 214, 0.9), rgba(255, 255, 251, 0.94));
}

.card-art.black .xiaobo-card-portrait::before {
  background:
    radial-gradient(circle at 28% 36%, rgba(255, 255, 255, 0.5) 0 5px, transparent 6px),
    radial-gradient(circle at 72% 34%, rgba(255, 229, 170, 0.34) 0 4px, transparent 5px),
    linear-gradient(135deg, rgba(19, 27, 42, 0.95), rgba(71, 79, 93, 0.92));
}

.xiaobo-jewel {
  position: absolute;
  z-index: 3;
  display: none;
}

.xiaobo-jewel img {
  width: 18px;
  height: 18px;
}

.crown-jewel {
  top: 5px;
  left: 50%;
  transform: translateX(-50%);
}

.side-jewel.left {
  left: -5px;
  top: 44px;
}

.side-jewel.right {
  right: -5px;
  top: 44px;
}

.card-art img {
  object-fit: contain;
  filter: drop-shadow(0 12px 12px rgba(15, 23, 42, 0.24));
}

.art-score-0 .xiaobo-card-portrait {
  transform: scale(0.9) translateY(3px);
}

.art-score-0 .xiaobo-collar {
  opacity: 0.78;
}

.art-score-1 .xiaobo-card-portrait {
  transform: scale(0.95) translateY(3px);
}

.art-score-2 .xiaobo-card-portrait {
  transform: scale(1) translateY(2px);
}

.art-score-2 .crown-jewel,
.art-score-3 .crown-jewel,
.art-score-4 .crown-jewel {
  display: block;
}

.art-score-3 .xiaobo-card-portrait,
.art-score-4 .xiaobo-card-portrait {
  transform: scale(1.06) translateY(1px);
}

.art-score-3 .xiaobo-jewel,
.art-score-4 .xiaobo-jewel {
  display: block;
}

.art-score-4 .xiaobo-face {
  box-shadow: 0 12px 20px rgba(15, 23, 42, 0.2), 0 0 22px rgba(255, 213, 88, 0.48);
}

.art-score-4 .xiaobo-collar {
  background: linear-gradient(135deg, #48330b, #d69a2d 48%, #fff0a6);
}

.art-score-4 .xiaobo-card-portrait::after {
  content: "";
  position: absolute;
  top: -4px;
  left: 50%;
  z-index: 5;
  width: 42px;
  height: 18px;
  transform: translateX(-50%);
  background:
    radial-gradient(circle at 18% 80%, #f2b72e 0 5px, transparent 6px),
    radial-gradient(circle at 50% 35%, #fff4b0 0 6px, transparent 7px),
    radial-gradient(circle at 82% 80%, #d99416 0 5px, transparent 6px),
    linear-gradient(to top, #c78a16 0 8px, transparent 9px);
  clip-path: polygon(0 100%, 12% 38%, 32% 76%, 50% 0, 68% 76%, 88% 38%, 100% 100%);
  filter: drop-shadow(0 3px 5px rgba(112, 78, 15, 0.22));
}

.art-glow {
  position: absolute;
  width: 92px;
  height: 92px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.64);
  box-shadow: 0 0 36px rgba(255, 255, 255, 0.9);
}

.art-frame {
  position: absolute;
  inset: 8px;
  border-radius: 7px;
  border: 1px solid rgba(255, 255, 255, 0.74);
  box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.04);
}

.art-rays {
  position: absolute;
  width: 138px;
  height: 138px;
  border-radius: 50%;
  opacity: 0;
  background:
    repeating-conic-gradient(from 12deg, rgba(255, 255, 255, 0.62) 0deg 8deg, transparent 8deg 20deg);
}

.art-orbit {
  position: absolute;
  z-index: 1;
  width: 118px;
  height: 48px;
  border: 1px solid rgba(23, 32, 42, 0.16);
  border-left-color: transparent;
  border-right-color: transparent;
  border-radius: 50%;
  opacity: 0.2;
  transform: rotate(-16deg);
}

.art-motif {
  position: absolute;
  z-index: 1;
  color: rgba(23, 32, 42, 0.16);
  font-weight: 900;
  line-height: 1;
  pointer-events: none;
}

.motif-main {
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 34px;
}

.motif-left {
  left: 17px;
  top: 42%;
  font-size: 22px;
}

.motif-right {
  right: 17px;
  top: 42%;
  font-size: 22px;
}

.art-crown {
  position: absolute;
  top: 9px;
  right: 12px;
  z-index: 2;
  color: #b7791f;
  font-size: 18px;
  font-weight: 900;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.8);
}

.art-label {
  position: relative;
  z-index: 1;
  margin-bottom: 8px;
  padding: 4px 10px;
  border: 1px solid rgba(220, 228, 235, 0.9);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  color: #17202a;
  font-size: 13px;
  font-weight: 800;
}

.art-stars {
  position: absolute;
  left: 10px;
  bottom: 9px;
  z-index: 2;
  color: rgba(23, 32, 42, 0.34);
  font-size: 11px;
  letter-spacing: 0;
}

.art-score-0 {
  min-height: 96px;
  filter: saturate(0.9);
}

.art-score-1 {
  min-height: 104px;
}

.art-score-2 {
  min-height: 116px;
}

.art-score-2 .art-frame,
.art-score-3 .art-frame,
.art-score-4 .art-frame {
  border-color: rgba(235, 190, 85, 0.5);
}

.art-score-2 .art-glow {
  width: 104px;
  height: 104px;
  background: rgba(255, 249, 222, 0.72);
}

.art-score-2 .art-orbit,
.art-score-3 .art-orbit,
.art-score-4 .art-orbit {
  opacity: 0.56;
}

.art-score-2 .motif-main {
  color: rgba(150, 101, 27, 0.18);
  font-size: 42px;
}

.art-score-3,
.art-score-4 {
  min-height: 130px;
}

.art-score-3 .art-rays,
.art-score-4 .art-rays,
.art-score-3::before,
.art-score-4::before,
.art-score-4::after {
  opacity: 1;
}

.art-score-3 .art-glow,
.art-score-4 .art-glow {
  width: 132px;
  height: 132px;
  background: rgba(255, 244, 194, 0.78);
  box-shadow: 0 0 44px rgba(255, 228, 132, 0.88);
}

.art-score-3 .art-orbit,
.art-score-4 .art-orbit {
  width: 142px;
  height: 58px;
  border-color: rgba(174, 118, 30, 0.28);
  border-left-color: transparent;
  border-right-color: transparent;
}

.art-score-3 .motif-main,
.art-score-4 .motif-main {
  color: rgba(125, 83, 18, 0.22);
  font-size: 54px;
}

.art-score-3 .motif-left,
.art-score-3 .motif-right,
.art-score-4 .motif-left,
.art-score-4 .motif-right {
  color: rgba(125, 83, 18, 0.24);
  font-size: 28px;
}

.art-score-4 .art-label {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(255, 229, 141, 0.82));
  border-color: rgba(190, 130, 24, 0.32);
}

.art-score-4 .art-frame {
  border-width: 2px;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.76),
    inset 0 0 22px rgba(255, 226, 130, 0.42);
}

.art-score-4 .art-crown {
  color: #8f5b07;
  font-size: 22px;
}

.cost {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.cost-item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 28px;
  padding: 3px 6px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.8);
  font-size: 13px;
  min-width: 0;
}

.cost-item strong {
  font-size: 12px;
}

.card-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.card-actions button {
  padding: 9px 8px;
}

.reserved-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.reserved-card {
  display: grid;
  gap: 9px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: #fff;
  min-width: 0;
}

.reserved-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}

.reserved-main span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.reserved-card button {
  flex: 0 0 auto;
  padding: 8px 10px;
}

.reserved-cost {
  display: grid;
  gap: 6px;
}

.cost-label {
  color: var(--muted);
  font-size: 12px;
}

@media (max-width: 980px) {
  .layout {
    grid-template-columns: 1fr;
  }

  .opponents-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .market {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  }
}

@media (max-width: 640px) {
  html,
  body {
    height: 100%;
    overflow: hidden;
  }

  .game-shell {
    width: 100%;
    height: 100dvh;
    display: grid;
    grid-template-rows: auto auto auto minmax(0, 1fr);
    gap: 6px;
    overflow: hidden;
    padding: 6px;
  }

  .topbar,
  .status-strip,
  .opponents-head {
    align-items: center;
    flex-direction: row;
  }

  .topbar,
  .status-strip,
  .panel,
  .market-panel,
  .opponents-panel {
    padding: 7px;
    border-radius: 8px;
  }

  .topbar {
    gap: 6px;
  }

  .back-link {
    margin-bottom: 0;
    font-size: 12px;
  }

  h1 {
    font-size: 18px;
  }

  h2 {
    font-size: 13px;
  }

  .topbar p,
  .opponents-head p,
  .panel .hint {
    display: none;
  }

  .score-card {
    min-width: 0;
    padding: 6px 9px;
  }

  .score-card strong,
  .status-box strong {
    font-size: 17px;
  }

  .score-card span,
  .status-box span {
    font-size: 11px;
    margin-bottom: 2px;
  }

  .status-strip {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 6px;
    margin: 0;
  }

  .status-box {
    padding: 2px 0;
  }

  .status-actions {
    display: grid;
    grid-template-columns: repeat(4, minmax(44px, auto));
    gap: 4px;
  }

  .status-actions button:first-child {
    grid-column: auto;
  }

  button {
    padding: 7px 8px;
    font-size: 12px;
  }

  .bank,
  .token-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .layout {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: minmax(0, 1fr) auto;
    gap: 6px;
    min-height: 0;
  }

  .market-panel {
    order: 1;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    min-height: 0;
    overflow: hidden;
  }

  .player-panel {
    order: 2;
    display: grid;
    grid-template-columns: 1.1fr 1.1fr 1fr 1fr;
    gap: 5px;
    max-height: 132px;
    overflow: hidden;
  }

  .player-panel .panel {
    min-height: 0;
    padding: 6px;
  }

  .token-grid.compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .chip-button,
  .token-stat {
    min-height: 26px;
    padding: 3px 5px;
  }

  .opponents-panel {
    display: grid;
    gap: 4px;
    overflow: hidden;
    margin-bottom: 0;
  }

  .opponents-head {
    display: none;
  }

  .opponents-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 4px;
    overflow: hidden;
    padding-bottom: 0;
    scroll-snap-type: none;
  }

  .opponent-card {
    min-width: 0;
    gap: 3px;
    padding: 5px;
    scroll-snap-align: none;
  }

  .opponent-top {
    gap: 6px;
  }

  .opponent-avatar {
    width: 23px;
    height: 23px;
    font-size: 12px;
  }

  .opponent-top strong {
    font-size: 12px;
  }

  .opponent-top span {
    display: none;
  }

  .opponent-score {
    font-size: 14px;
  }

  .opponent-tokens {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 3px;
  }

  .opponent-meta {
    display: none;
  }

  .opponent-token .gem img {
    width: 13px;
    height: 13px;
  }

  .opponent-token strong {
    font-size: 11px;
  }

  .market {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 5px;
    min-height: 0;
    overflow-y: auto;
    padding-right: 2px;
  }

  .market-head {
    align-items: center;
    flex-direction: row;
    gap: 6px;
    margin-bottom: 5px;
  }

  .market-head p {
    max-height: 18px;
    overflow: hidden;
    font-size: 11px;
  }

  .card {
    min-height: 0;
    gap: 4px;
    padding: 5px;
  }

  .card-top {
    align-items: flex-start;
  }

  .card-name {
    font-size: 11px;
    line-height: 1.25;
  }

  .points {
    min-width: 22px;
    height: 22px;
    font-size: 12px;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    min-height: 72px;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 58px;
    height: 58px;
    transform: scale(0.86) translateY(0);
  }

  .xiaobo-ear {
    top: 1px;
    width: 20px;
    height: 24px;
  }

  .xiaobo-ear.left {
    left: 8px;
  }

  .xiaobo-ear.right {
    right: 8px;
  }

  .xiaobo-face {
    width: 50px;
    height: 45px;
    margin-top: 8px;
  }

  .xiaobo-eye {
    top: 14px;
    width: 7px;
    height: 9px;
  }

  .xiaobo-eye.left {
    left: 15px;
  }

  .xiaobo-eye.right {
    right: 15px;
  }

  .xiaobo-nose {
    top: 26px;
    width: 7px;
    height: 5px;
  }

  .xiaobo-muzzle {
    bottom: 5px;
    width: 22px;
  }

  .xiaobo-collar {
    bottom: 0;
    width: 35px;
    height: 14px;
  }

  .xiaobo-collar img,
  .xiaobo-jewel img {
    width: 14px;
    height: 14px;
  }

  .motif-main {
    top: 9px;
    font-size: 28px;
  }

  .art-score-3 .motif-main,
  .art-score-4 .motif-main {
    font-size: 34px;
  }

  .motif-left,
  .motif-right,
  .art-score-3 .motif-left,
  .art-score-3 .motif-right,
  .art-score-4 .motif-left,
  .art-score-4 .motif-right {
    top: 38%;
    font-size: 16px;
  }

  .art-orbit {
    width: 82px;
    height: 32px;
  }

  .art-rays {
    width: 92px;
    height: 92px;
  }

  .art-glow,
  .art-score-3 .art-glow,
  .art-score-4 .art-glow {
    width: 80px;
    height: 80px;
  }

  .art-label {
    margin-bottom: 5px;
    padding: 3px 7px;
    font-size: 11px;
  }

  .art-stars,
  .art-crown {
    display: none;
  }

  .cost-item {
    font-size: 11px;
    padding: 2px 4px;
  }

  .cost-item .gem-label {
    display: none;
  }

  .cost-item .gem img {
    width: 15px;
    height: 15px;
  }

  .card-actions button {
    min-height: 28px;
    padding: 5px 4px;
    font-size: 11px;
  }

  .panel h2 {
    font-size: 12px;
  }

  .bank,
  .token-grid {
    gap: 3px;
    margin-top: 5px;
  }

  .chip-button,
  .token-stat {
    min-height: 24px;
  }

  .gem img {
    width: 17px;
    height: 17px;
  }

  .gem-label {
    font-size: 11px;
  }

  .bank .gem-label,
  .token-grid .gem-label {
    display: none;
  }

  .reserved-list {
    max-height: 72px;
    overflow-y: auto;
    gap: 4px;
    margin-top: 5px;
  }

  .reserved-card {
    gap: 5px;
    padding: 7px;
  }

  .reserved-cost {
    display: none;
  }

  .reserved-main {
    align-items: stretch;
    flex-direction: column;
  }

  .reserved-card button {
    width: 100%;
  }
}

@media (max-width: 390px) {
  .status-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .player-panel,
  .token-grid.compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  html,
  body {
    height: auto;
    min-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
  }

  body {
    background: linear-gradient(180deg, #fff2c7 0, #f7f1d9 38%, #edf4f2 100%);
  }

  .game-shell {
    width: 100%;
    height: auto;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow: visible;
    padding: 8px;
  }

  .topbar,
  .status-strip,
  .opponents-panel,
  .market-panel,
  .panel {
    border-radius: 12px;
    box-shadow: 0 8px 18px rgba(40, 50, 35, 0.08);
  }

  .topbar {
    padding: 12px 14px;
  }

  .topbar p {
    display: none;
  }

  .back-link {
    font-size: 13px;
  }

  h1 {
    font-size: 24px;
    line-height: 1.05;
  }

  .score-card {
    min-width: 92px;
    padding: 10px 12px;
  }

  .score-card strong {
    font-size: 25px;
  }

  .status-strip {
    grid-template-columns: 1fr auto;
    padding: 12px 14px;
  }

  .status-box strong {
    font-size: 24px;
  }

  .status-actions {
    grid-template-columns: repeat(2, minmax(76px, 1fr));
    width: min(180px, 46vw);
  }

  .status-actions button {
    min-height: 38px;
    padding: 7px 8px;
    font-size: 14px;
  }

  .opponents-panel {
    padding: 10px;
    background: #fff7ce;
  }

  .opponents-head {
    display: none;
  }

  .opponents-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
  }

  .opponent-card {
    min-height: 108px;
    padding: 8px;
    background: linear-gradient(160deg, #ffd83d, #f3be20);
    border-color: rgba(142, 96, 0, 0.14);
  }

  .opponent-avatar {
    width: 22px;
    height: 22px;
    background: rgba(16, 24, 39, 0.92);
  }

  .opponent-top {
    gap: 6px;
  }

  .opponent-top strong {
    color: #17202a;
    font-size: 13px;
  }

  .opponent-score {
    color: #17202a;
    font-size: 21px;
  }

  .opponent-tokens {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 3px;
  }

  .opponent-token {
    justify-content: center;
    min-height: 24px;
    padding: 2px 4px;
    background: rgba(255, 255, 255, 0.42);
  }

  .opponent-token .gem img {
    width: 16px;
    height: 16px;
  }

  .layout {
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow: visible;
  }

  .market-panel {
    order: 1;
    padding: 10px;
    overflow: visible;
  }

  .market-head {
    flex-direction: row;
    align-items: flex-end;
    margin-bottom: 8px;
  }

  .market-head h2 {
    font-size: 20px;
  }

  .market-head p {
    display: block;
    max-height: none;
    font-size: 13px;
    line-height: 1.35;
  }

  .market {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    overflow: visible;
    padding: 0;
  }

  .card {
    min-height: 0;
    padding: 8px;
    gap: 6px;
    border-radius: 12px;
  }

  .card-name {
    font-size: 14px;
  }

  .points {
    min-width: 28px;
    height: 28px;
    font-size: 15px;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    min-height: 102px;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 86px;
    height: 82px;
    transform: scale(0.96) translateY(2px);
  }

  .xiaobo-card-img {
    width: 84px;
    height: 84px;
    border-radius: 22px;
  }

  .xiaobo-card-portrait::before {
    width: 78px;
    height: 44px;
    bottom: 0;
  }

  .cost {
    gap: 5px;
  }

  .cost-item {
    min-height: 28px;
    font-size: 13px;
    padding: 3px 7px;
  }

  .cost-item .gem-label {
    display: none;
  }

  .cost-item .gem img {
    width: 18px;
    height: 18px;
  }

  .card-actions {
    gap: 6px;
  }

  .card-actions button {
    min-height: 34px;
    font-size: 14px;
  }

  .player-panel {
    order: 2;
    position: static;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    max-height: none;
    overflow: visible;
  }

  .player-panel .panel {
    padding: 10px;
  }

  .bank,
  .token-grid,
  .token-grid.compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
  }

  .chip-button,
  .token-stat {
    min-height: 34px;
    padding: 5px 7px;
  }

  .gem img {
    width: 20px;
    height: 20px;
  }

  .reserved-list {
    max-height: none;
    overflow: visible;
  }

  .reserved-cost {
    display: grid;
  }
}

@media (max-width: 390px) {
  .market {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .player-panel {
    grid-template-columns: 1fr;
  }
}

/* Final board layout guard: keep every game section visible on desktop and mobile. */
html,
body {
  height: auto !important;
  min-height: 100% !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
}

.game-shell {
  height: auto !important;
  min-height: 100vh !important;
  overflow: visible !important;
}

.layout,
.player-panel,
.market-panel,
.market,
.opponents-panel,
.opponents-grid,
.panel,
.card {
  max-height: none !important;
  overflow: visible !important;
}

.player-panel {
  align-self: start;
}

@media (min-width: 981px) {
  .game-shell {
    display: grid;
    grid-template-rows: auto auto auto auto;
  }

  .layout {
    display: grid;
    grid-template-columns: minmax(300px, 360px) minmax(0, 1fr);
    gap: 14px;
    align-items: start;
  }

  .player-panel {
    position: sticky;
    top: 12px;
    grid-template-rows: none;
  }

  .market {
    grid-template-columns: repeat(4, minmax(170px, 1fr));
  }
}

@media (max-width: 980px) {
  .player-panel {
    position: static !important;
  }
}

@media (max-width: 640px) {
  body {
    background: linear-gradient(180deg, #fff2c7 0, #f8efd3 44%, #edf4f2 100%);
  }

  .game-shell {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    padding: 8px !important;
  }

  .topbar,
  .status-strip,
  .opponents-panel,
  .market-panel,
  .panel {
    padding: 10px !important;
    border-radius: 12px !important;
  }

  .topbar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .topbar p,
  .opponents-head,
  .panel .hint {
    display: none !important;
  }

  h1 {
    font-size: 24px !important;
    line-height: 1.08 !important;
  }

  h2 {
    font-size: 18px !important;
  }

  .score-card {
    min-width: 94px !important;
    padding: 10px 12px !important;
  }

  .score-card strong,
  .status-box strong {
    font-size: 24px !important;
  }

  .status-strip {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(150px, 42vw) !important;
    gap: 10px !important;
    align-items: center !important;
  }

  .status-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 7px !important;
    width: auto !important;
  }

  .status-actions button {
    min-height: 38px !important;
    padding: 7px 8px !important;
    font-size: 14px !important;
  }

  .opponents-panel {
    background: #fff4bd !important;
  }

  .opponents-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 7px !important;
  }

  .opponent-card {
    min-height: 108px !important;
    padding: 8px !important;
    background: linear-gradient(160deg, #ffd843, #f4bf22) !important;
  }

  .opponent-score {
    font-size: 20px !important;
  }

  .opponent-tokens {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .layout {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
  }

  .market-panel {
    order: 1 !important;
  }

  .market-head {
    display: flex !important;
    align-items: flex-end !important;
    justify-content: space-between !important;
    gap: 8px !important;
    margin-bottom: 8px !important;
  }

  .market-head p {
    display: block !important;
    max-height: none !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
  }

  .market {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    padding: 0 !important;
  }

  .card {
    min-height: 0 !important;
    padding: 8px !important;
    gap: 6px !important;
    border-radius: 12px !important;
  }

  .card-name {
    font-size: 14px !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    min-height: 104px !important;
  }

  .cost-item .gem-label {
    display: none !important;
  }

  .card-actions button {
    min-height: 34px !important;
    font-size: 14px !important;
  }

  .player-panel {
    order: 2 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .bank,
  .token-grid,
  .token-grid.compact {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .reserved-cost {
    display: grid !important;
  }
}

@media (max-width: 430px) {
  .market {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .player-panel {
    grid-template-columns: 1fr !important;
  }

  .status-strip {
    grid-template-columns: 1fr !important;
  }

  .opponents-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

/* Compact status board: keep player gems and discounts in the action strip. */
.status-strip {
  display: grid !important;
  grid-template-columns: minmax(210px, 0.8fr) minmax(360px, 1.25fr) auto !important;
  align-items: center !important;
}

.player-quick {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
  min-width: 0 !important;
}

.quick-token-row {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 5px !important;
}

.quick-token .gem img {
  width: 18px !important;
  height: 18px !important;
}

.player-stats-panel {
  display: none !important;
}

.player-panel {
  grid-template-rows: auto auto minmax(0, 1fr) !important;
}

.cost {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 5px !important;
}

.cost-item {
  justify-content: center !important;
  min-height: 27px !important;
  padding: 3px 5px !important;
}

.cost-item .gem img {
  width: 21px !important;
  height: 21px !important;
}

@media (max-width: 980px) {
  .status-strip {
    grid-template-columns: 1fr !important;
  }

  .status-actions {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    width: 100% !important;
  }
}

@media (max-width: 640px) {
  .player-quick {
    grid-template-columns: 1fr !important;
  }

  .status-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* AI rivals live in the left utility rail, not above the market. */
.player-panel .opponents-panel {
  display: grid !important;
  margin: 0 !important;
  padding: 14px !important;
  border-radius: 8px !important;
  background: rgba(255, 255, 255, 0.94) !important;
}

.player-panel .opponents-head {
  display: block !important;
}

.player-panel .opponents-head p {
  display: none !important;
}

.player-panel .opponents-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 8px !important;
}

.player-panel .opponent-card {
  min-height: 0 !important;
  padding: 9px !important;
  gap: 6px !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(240, 248, 247, 0.84)),
    repeating-linear-gradient(45deg, rgba(15, 118, 110, 0.04) 0 8px, transparent 8px 16px) !important;
}

.player-panel .opponent-avatar {
  width: 30px !important;
  height: 30px !important;
}

.player-panel .opponent-score {
  font-size: 18px !important;
}

.player-panel .opponent-tokens {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
}

.player-panel .opponent-meta {
  gap: 4px !important;
}

.player-panel .opponent-meta span {
  padding: 3px 6px !important;
  font-size: 11px !important;
}

@media (max-width: 980px) {
  .player-panel .opponents-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 520px) {
  .player-panel .opponents-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Phone game table: optimized after all earlier compatibility rules. */
@media (max-width: 640px) {
  html,
  body {
    height: auto !important;
    min-height: 100% !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  body {
    background: #fff1bf !important;
  }

  .game-shell {
    width: min(100%, 430px) !important;
    min-height: 100vh !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 7px !important;
    padding: 7px !important;
    margin: 0 auto !important;
    overflow: visible !important;
  }

  .topbar,
  .status-strip,
  .panel,
  .market-panel,
  .opponents-panel {
    border-radius: 10px !important;
    padding: 9px !important;
    box-shadow: 0 7px 14px rgba(67, 49, 12, 0.08) !important;
  }

  .topbar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 8px !important;
  }

  .topbar p {
    display: none !important;
  }

  .back-link {
    margin: 0 0 3px !important;
    font-size: 12px !important;
  }

  h1 {
    font-size: 24px !important;
    line-height: 1.05 !important;
  }

  .score-card {
    min-width: 88px !important;
    padding: 8px 10px !important;
  }

  .score-card span,
  .status-box span,
  .quick-stat > span {
    font-size: 11px !important;
  }

  .score-card strong,
  .status-box strong {
    font-size: 22px !important;
  }

  .status-strip {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 7px !important;
  }

  .status-box {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    align-items: baseline !important;
    column-gap: 8px !important;
  }

  .status-box span {
    margin: 0 !important;
  }

  .status-box strong {
    font-size: 19px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .player-quick {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  .quick-stat {
    gap: 4px !important;
    padding: 6px !important;
    border-radius: 8px !important;
  }

  .quick-token-row {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    gap: 3px !important;
  }

  .quick-token {
    min-height: 22px !important;
    gap: 2px !important;
  }

  .quick-token .gem img {
    width: 15px !important;
    height: 15px !important;
  }

  .quick-token strong {
    font-size: 11px !important;
  }

  .status-actions {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    width: 100% !important;
    gap: 5px !important;
  }

  .status-actions button {
    min-height: 34px !important;
    padding: 5px 3px !important;
    font-size: 12px !important;
    border-radius: 8px !important;
  }

  .layout {
    display: flex !important;
    flex-direction: column !important;
    gap: 7px !important;
    overflow: visible !important;
  }

  .player-panel {
    display: contents !important;
  }

  .player-panel > .panel:nth-of-type(1) {
    order: 2 !important;
  }

  .player-panel > .panel:nth-of-type(2),
  .player-panel > .panel:nth-of-type(3) {
    display: none !important;
  }

  .player-panel > .panel:nth-of-type(4) {
    order: 5 !important;
  }

  .player-panel .opponents-panel {
    order: 1 !important;
    background: #ffd430 !important;
    padding: 8px !important;
  }

  .player-panel .opponents-head {
    display: none !important;
  }

  .player-panel .opponents-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  .player-panel .opponent-card {
    min-height: 86px !important;
    padding: 7px !important;
    gap: 4px !important;
    border-color: rgba(136, 89, 0, 0.18) !important;
    background: linear-gradient(160deg, #ffe06a, #f7bf22) !important;
  }

  .player-panel .opponent-top {
    gap: 5px !important;
  }

  .player-panel .opponent-avatar {
    width: 22px !important;
    height: 22px !important;
    font-size: 11px !important;
  }

  .player-panel .opponent-top strong {
    font-size: 13px !important;
  }

  .player-panel .opponent-top span {
    display: none !important;
  }

  .player-panel .opponent-score {
    font-size: 20px !important;
    line-height: 1 !important;
  }

  .player-panel .opponent-tokens {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 3px !important;
  }

  .player-panel .opponent-token {
    min-height: 21px !important;
    padding: 1px 3px !important;
    background: rgba(255, 255, 255, 0.48) !important;
  }

  .player-panel .opponent-token .gem img {
    width: 14px !important;
    height: 14px !important;
  }

  .player-panel .opponent-meta {
    display: none !important;
  }

  .bank {
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    gap: 5px !important;
    margin-top: 7px !important;
  }

  .panel h2 {
    font-size: 16px !important;
  }

  .chip-button {
    display: grid !important;
    place-items: center !important;
    gap: 1px !important;
    min-height: 52px !important;
    padding: 4px 2px !important;
    border-radius: 9px !important;
  }

  .chip-button .gem-label {
    display: none !important;
  }

  .chip-button .gem img {
    width: 26px !important;
    height: 26px !important;
  }

  .chip-button strong {
    font-size: 13px !important;
  }

  .market-panel {
    order: 3 !important;
    padding: 9px !important;
    overflow: visible !important;
  }

  .market-head {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    align-items: baseline !important;
    gap: 8px !important;
    margin-bottom: 8px !important;
  }

  .market-head h2 {
    font-size: 19px !important;
  }

  .market-head p {
    display: block !important;
    max-height: 18px !important;
    overflow: hidden !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
  }

  .market {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 7px !important;
    overflow: visible !important;
    padding: 0 !important;
  }

  .card {
    min-height: 0 !important;
    padding: 6px !important;
    gap: 5px !important;
    border-radius: 10px !important;
  }

  .card-top {
    min-height: 30px !important;
  }

  .card-name {
    font-size: 12px !important;
    line-height: 1.15 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  .points {
    min-width: 24px !important;
    height: 24px !important;
    font-size: 13px !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    min-height: 80px !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 64px !important;
    height: 62px !important;
    transform: scale(0.86) translateY(0) !important;
  }

  .xiaobo-card-img {
    width: 76px !important;
    height: 76px !important;
  }

  .xiaobo-collar {
    width: 38px !important;
    height: 15px !important;
  }

  .xiaobo-collar img,
  .xiaobo-jewel img {
    width: 14px !important;
    height: 14px !important;
  }

  .art-label {
    margin-bottom: 4px !important;
    padding: 2px 7px !important;
    font-size: 10px !important;
  }

  .art-stars,
  .art-crown,
  .motif-left,
  .motif-right {
    display: none !important;
  }

  .cost {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 4px !important;
  }

  .cost-item {
    min-height: 23px !important;
    padding: 2px 3px !important;
    gap: 2px !important;
    font-size: 11px !important;
  }

  .cost-item .gem img {
    width: 15px !important;
    height: 15px !important;
  }

  .cost-item strong {
    font-size: 10px !important;
  }

  .card-actions {
    grid-template-columns: 1fr 1fr !important;
    gap: 4px !important;
  }

  .card-actions button {
    min-height: 30px !important;
    padding: 4px 2px !important;
    font-size: 12px !important;
    border-radius: 8px !important;
  }

  .reserved-list {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    margin-top: 7px !important;
    max-height: none !important;
    overflow: visible !important;
  }

  .reserved-card {
    padding: 6px !important;
    gap: 4px !important;
  }

  .reserved-main {
    display: grid !important;
    gap: 5px !important;
  }

  .reserved-main span {
    font-size: 12px !important;
  }

  .reserved-cost {
    display: none !important;
  }

  .reserved-card button {
    width: 100% !important;
    min-height: 28px !important;
    padding: 4px !important;
  }
}

@media (max-width: 380px) {
  .market {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .status-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* Phone board layout: compact table view inspired by the mobile reference. */
@media (max-width: 640px) {
  html,
  body {
    width: 100% !important;
    height: 100% !important;
    overflow: hidden !important;
    background: #fff0bd !important;
  }

  body {
    margin: 0 !important;
  }

  .game-shell {
    width: min(100vw, 430px) !important;
    height: 100dvh !important;
    min-height: 0 !important;
    display: grid !important;
    grid-template-rows: 46px 82px minmax(0, 1fr) !important;
    gap: 5px !important;
    padding: 5px !important;
    overflow: hidden !important;
    background: #fff0bd !important;
  }

  .topbar {
    min-height: 0 !important;
    height: 46px !important;
    padding: 6px 8px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 74px !important;
    align-items: center !important;
    border-radius: 10px !important;
    box-shadow: 0 2px 0 rgba(163, 138, 57, 0.12) !important;
  }

  .topbar p {
    display: none !important;
  }

  .back-link {
    margin: 0 !important;
    font-size: 11px !important;
    line-height: 1 !important;
  }

  .topbar h1 {
    margin: 2px 0 0 !important;
    font-size: 19px !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
  }

  .score-card {
    min-height: 0 !important;
    width: 70px !important;
    padding: 5px !important;
    border-radius: 8px !important;
    justify-self: end !important;
  }

  .score-card span {
    font-size: 10px !important;
  }

  .score-card strong {
    font-size: 19px !important;
    line-height: 1 !important;
  }

  .status-strip {
    min-height: 0 !important;
    height: 82px !important;
    padding: 6px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 116px !important;
    grid-template-rows: 1fr !important;
    gap: 6px !important;
    background: linear-gradient(135deg, #ffd941, #ffc42d) !important;
    border: 1px solid rgba(191, 144, 24, 0.18) !important;
    border-radius: 10px !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.28) !important;
  }

  .status-box {
    display: none !important;
  }

  .player-quick {
    grid-column: 1 !important;
    display: grid !important;
    grid-template-rows: repeat(2, minmax(0, 1fr)) !important;
    gap: 5px !important;
    min-width: 0 !important;
  }

  .quick-stat {
    height: 32px !important;
    padding: 3px 5px !important;
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 4px !important;
    border: 0 !important;
    border-radius: 8px !important;
    background: rgba(255, 255, 255, 0.22) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.23) !important;
  }

  .quick-stat > span {
    color: rgba(24, 34, 46, 0.78) !important;
    font-size: 10px !important;
    line-height: 1.05 !important;
    white-space: normal !important;
  }

  .quick-token-row {
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    gap: 2px !important;
    align-items: center !important;
  }

  .quick-token,
  .opponent-marker,
  .cost-item {
    display: grid !important;
    place-items: center !important;
    color: #ffffff !important;
    border: 2px solid rgba(255, 255, 255, 0.5) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.34), 0 1px 2px rgba(17, 24, 39, 0.18) !important;
  }

  .quick-token {
    width: 22px !important;
    height: 22px !important;
    margin: auto !important;
  }

  .quick-token img,
  .opponent-marker img,
  .cost-item .gem {
    display: none !important;
  }

  .quick-token strong,
  .opponent-marker strong,
  .cost-item strong {
    color: #ffffff !important;
    font-size: 11px !important;
    line-height: 1 !important;
    text-shadow: 0 1px 1px rgba(0, 0, 0, 0.28) !important;
  }

  .token-circle {
    border-radius: 999px !important;
  }

  .bonus-square {
    border-radius: 5px !important;
  }

  .quick-token.red,
  .opponent-marker.red,
  .cost-item.red,
  .cost-red {
    background: linear-gradient(145deg, #ff6a78, #c91f36) !important;
  }

  .quick-token.green,
  .opponent-marker.green,
  .cost-item.green,
  .cost-green {
    background: linear-gradient(145deg, #48d69a, #07824f) !important;
  }

  .quick-token.blue,
  .opponent-marker.blue,
  .cost-item.blue,
  .cost-blue {
    background: linear-gradient(145deg, #56b7ff, #1264b4) !important;
  }

  .quick-token.white,
  .opponent-marker.white,
  .cost-item.white,
  .cost-white {
    background: linear-gradient(145deg, #ffffff, #cfd8e3) !important;
    color: #2d3748 !important;
  }

  .quick-token.white strong,
  .opponent-marker.white strong,
  .cost-item.white strong,
  .cost-white strong {
    color: #2d3748 !important;
    text-shadow: none !important;
  }

  .quick-token.black,
  .opponent-marker.black,
  .cost-item.black,
  .cost-black {
    background: linear-gradient(145deg, #5d6672, #111827) !important;
  }

  .quick-token.gold,
  .opponent-marker.gold,
  .cost-item.gold {
    background: linear-gradient(145deg, #ffd978, #c58b12) !important;
  }

  .status-actions {
    grid-column: 2 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 5px !important;
    align-content: center !important;
  }

  .status-actions button {
    min-height: 31px !important;
    padding: 0 2px !important;
    border-radius: 8px !important;
    font-size: 11px !important;
    line-height: 1.05 !important;
  }

  .layout {
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 5px !important;
    overflow: hidden !important;
  }

  .player-panel {
    display: contents !important;
  }

  .player-panel > .panel:nth-of-type(2),
  .player-panel > .panel:nth-of-type(3) {
    display: none !important;
  }

  .opponents-panel {
    order: 1 !important;
    height: 85px !important;
    min-height: 0 !important;
    padding: 5px !important;
    border-radius: 10px !important;
    background: rgba(255, 255, 255, 0.88) !important;
    overflow: hidden !important;
  }

  .opponents-head {
    display: none !important;
  }

  .opponents-grid {
    height: 100% !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 5px !important;
  }

  .opponent-card {
    position: relative !important;
    min-height: 0 !important;
    padding: 7px 5px 5px !important;
    border: 0 !important;
    border-radius: 8px !important;
    background: linear-gradient(145deg, #ffd83e, #f5ba20) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.24), 0 1px 2px rgba(76, 51, 9, 0.18) !important;
  }

  .opponent-score {
    position: absolute !important;
    top: -5px !important;
    left: -4px !important;
    width: 22px !important;
    height: 22px !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 999px !important;
    background: #0b2239 !important;
    color: #ffffff !important;
    border: 2px solid #ffffff !important;
    font-size: 0 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.24) !important;
  }

  .opponent-score::after {
    content: attr(data-score);
    font-size: 13px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
  }

  .opponent-top {
    display: grid !important;
    grid-template-columns: 24px minmax(0, 1fr) !important;
    gap: 4px !important;
    align-items: center !important;
    margin: 0 0 4px !important;
  }

  .opponent-avatar {
    width: 24px !important;
    height: 24px !important;
    font-size: 0 !important;
    background: rgba(255, 255, 255, 0.72) !important;
  }

  .opponent-top strong {
    display: block !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    font-size: 12px !important;
    line-height: 1 !important;
    color: #233044 !important;
  }

  .opponent-top span:not(.opponent-avatar),
  .opponent-meta {
    display: none !important;
  }

  .opponent-holdings {
    display: grid !important;
    grid-template-rows: repeat(2, 18px) !important;
    gap: 4px !important;
  }

  .opponent-bonuses,
  .opponent-tokens {
    display: grid !important;
    gap: 2px !important;
    align-items: center !important;
  }

  .opponent-bonuses {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  }

  .opponent-tokens {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  }

  .opponent-marker {
    width: 17px !important;
    height: 17px !important;
    margin: auto !important;
  }

  .opponent-marker strong {
    font-size: 10px !important;
  }

  .player-panel > .panel:nth-of-type(1) {
    order: 2 !important;
    height: 47px !important;
    min-height: 0 !important;
    padding: 5px !important;
    border-radius: 10px !important;
    overflow: hidden !important;
  }

  .player-panel > .panel:nth-of-type(1) h2 {
    display: none !important;
  }

  .bank {
    height: 100% !important;
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    gap: 4px !important;
    margin: 0 !important;
  }

  .chip-button {
    position: relative !important;
    min-height: 0 !important;
    height: 37px !important;
    padding: 3px !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 8px !important;
    background: rgba(255, 255, 255, 0.86) !important;
  }

  .chip-button.selected {
    outline: 2px solid #0f8a78 !important;
    outline-offset: -2px !important;
  }

  .chip-button .gem-label {
    display: none !important;
  }

  .chip-button .gem img {
    width: 25px !important;
    height: 25px !important;
  }

  .chip-button strong {
    position: absolute !important;
    top: 1px !important;
    right: 3px !important;
    min-width: 15px !important;
    height: 15px !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 999px !important;
    background: #ffffff !important;
    color: #111827 !important;
    font-size: 10px !important;
    line-height: 1 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.16) !important;
  }

  .market-panel {
    order: 3 !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    padding: 6px !important;
    border-radius: 10px !important;
    overflow: hidden !important;
  }

  .market-head {
    display: none !important;
  }

  .market {
    height: 100% !important;
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    grid-template-rows: repeat(2, minmax(0, 1fr)) !important;
    gap: 5px !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  .card {
    position: relative !important;
    min-height: 0 !important;
    height: 100% !important;
    padding: 4px !important;
    gap: 3px !important;
    border-radius: 9px !important;
    overflow: hidden !important;
    box-shadow: 0 2px 5px rgba(56, 39, 11, 0.12) !important;
  }

  .card-top {
    min-height: 0 !important;
    position: absolute !important;
    top: 3px !important;
    right: 3px !important;
    z-index: 5 !important;
  }

  .card-name {
    display: none !important;
  }

  .points {
    min-width: 21px !important;
    width: 21px !important;
    height: 21px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.24) !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    min-height: 0 !important;
    height: 54% !important;
    margin: 18px 0 0 !important;
    border-radius: 7px !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 44px !important;
    height: 42px !important;
    transform: none !important;
  }

  .xiaobo-card-img {
    width: 54px !important;
    height: 54px !important;
    left: 50% !important;
  }

  .xiaobo-collar {
    width: 27px !important;
    height: 11px !important;
    bottom: 1px !important;
  }

  .xiaobo-collar img,
  .xiaobo-jewel img {
    width: 10px !important;
    height: 10px !important;
  }

  .art-label,
  .art-stars,
  .art-crown,
  .art-motif,
  .art-orbit,
  .art-rays {
    display: none !important;
  }

  .cost {
    min-height: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(3, 20px) !important;
    justify-content: center !important;
    gap: 3px !important;
    margin: 1px 0 !important;
  }

  .cost-item {
    width: 20px !important;
    height: 20px !important;
    min-height: 0 !important;
    padding: 0 !important;
    border-radius: 999px !important;
  }

  .cost-item strong {
    font-size: 10px !important;
  }

  .card-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 3px !important;
    margin-top: auto !important;
  }

  .card-actions button {
    min-height: 21px !important;
    height: 21px !important;
    padding: 0 !important;
    border-radius: 6px !important;
    font-size: 10px !important;
    line-height: 1 !important;
  }

  .player-panel > .panel:nth-of-type(4) {
    order: 4 !important;
    height: 48px !important;
    min-height: 0 !important;
    padding: 5px !important;
    border-radius: 10px !important;
    background: linear-gradient(135deg, #ffd941, #ffc42d) !important;
    overflow: hidden !important;
  }

  .player-panel > .panel:nth-of-type(4) h2 {
    display: none !important;
  }

  .reserved-list {
    height: 100% !important;
    margin: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 5px !important;
    overflow: hidden !important;
  }

  .reserved-list .hint {
    grid-column: 1 / -1 !important;
    margin: 0 !important;
    align-self: center !important;
    text-align: center !important;
    font-size: 11px !important;
    color: rgba(43, 50, 64, 0.7) !important;
  }

  .reserved-card {
    min-height: 0 !important;
    padding: 4px !important;
    border-radius: 8px !important;
    gap: 2px !important;
    background: rgba(255, 255, 255, 0.44) !important;
  }

  .reserved-main {
    gap: 2px !important;
  }

  .reserved-main span {
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    font-size: 10px !important;
  }

  .reserved-main button {
    min-height: 20px !important;
    height: 20px !important;
    padding: 0 !important;
    font-size: 10px !important;
    border-radius: 6px !important;
  }
}

/* Mobile refinement: clearer spacing, white background, readable cards. */
@media (max-width: 640px) {
  html,
  body {
    overflow-x: hidden !important;
    overflow-y: auto !important;
    background: #ffffff !important;
  }

  .game-shell {
    height: auto !important;
    min-height: 100dvh !important;
    grid-template-rows: 58px 116px auto !important;
    gap: 6px !important;
    padding: 6px !important;
    overflow: visible !important;
    background: #ffffff !important;
  }

  .topbar {
    height: 58px !important;
    grid-template-columns: minmax(0, 1fr) 90px !important;
    padding: 8px 10px !important;
    background: #ffffff !important;
  }

  .topbar h1 {
    font-size: 24px !important;
  }

  .back-link {
    font-size: 13px !important;
  }

  .score-card {
    width: 86px !important;
    min-height: 44px !important;
    padding: 6px !important;
  }

  .score-card strong {
    font-size: 24px !important;
  }

  .status-strip {
    height: 116px !important;
    grid-template-columns: minmax(0, 1fr) 142px !important;
    padding: 8px !important;
    background: #ffffff !important;
    border: 1px solid #d7e1ea !important;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06) !important;
  }

  .player-quick {
    gap: 7px !important;
  }

  .quick-stat {
    height: 45px !important;
    grid-template-columns: 62px minmax(0, 1fr) !important;
    padding: 5px 7px !important;
    background: #f8fafc !important;
    border: 1px solid #dfe8f0 !important;
  }

  .quick-stat > span {
    font-size: 13px !important;
    font-weight: 800 !important;
    color: #243043 !important;
  }

  .quick-token-row {
    gap: 4px !important;
  }

  .quick-token {
    width: 26px !important;
    height: 26px !important;
  }

  .quick-token strong {
    font-size: 12px !important;
  }

  .status-actions {
    gap: 7px !important;
  }

  .status-actions button {
    min-height: 44px !important;
    font-size: 14px !important;
    border-radius: 10px !important;
  }

  .layout {
    overflow: visible !important;
    gap: 6px !important;
  }

  .opponents-panel {
    height: 108px !important;
    padding: 6px !important;
    background: #ffffff !important;
    overflow: visible !important;
  }

  .opponents-grid {
    gap: 6px !important;
  }

  .opponent-card {
    padding: 10px 6px 7px !important;
    background: linear-gradient(145deg, #fff6c6, #ffd94c) !important;
    border: 1px solid rgba(210, 170, 42, 0.35) !important;
  }

  .opponent-score {
    top: -6px !important;
    left: -3px !important;
    width: 24px !important;
    height: 24px !important;
  }

  .opponent-score .score-current,
  .opponent-score .score-limit {
    display: none !important;
  }

  .opponent-score::after {
    font-size: 14px !important;
  }

  .opponent-top {
    grid-template-columns: 22px minmax(0, 1fr) !important;
    margin-bottom: 6px !important;
  }

  .opponent-avatar {
    width: 22px !important;
    height: 22px !important;
  }

  .opponent-top strong {
    font-size: 13px !important;
  }

  .opponent-holdings {
    grid-template-rows: repeat(2, 22px) !important;
    gap: 5px !important;
  }

  .opponent-marker {
    width: 20px !important;
    height: 20px !important;
  }

  .opponent-marker strong {
    font-size: 11px !important;
  }

  .player-panel > .panel:nth-of-type(1) {
    height: 58px !important;
    padding: 7px !important;
    background: #ffffff !important;
    overflow: visible !important;
  }

  .chip-button {
    height: 44px !important;
    background: #ffffff !important;
  }

  .chip-button .gem img {
    width: 31px !important;
    height: 31px !important;
  }

  .chip-button strong {
    top: 2px !important;
    right: 4px !important;
    min-width: 18px !important;
    height: 18px !important;
    font-size: 12px !important;
  }

  .market-panel {
    padding: 8px !important;
    background: #ffffff !important;
    overflow: visible !important;
  }

  .market {
    height: auto !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    grid-auto-rows: 174px !important;
    grid-template-rows: none !important;
    gap: 7px !important;
    overflow: visible !important;
  }

  .card {
    height: 174px !important;
    padding: 6px !important;
    gap: 5px !important;
    border-radius: 11px !important;
    overflow: hidden !important;
  }

  .points {
    width: 25px !important;
    height: 25px !important;
    font-size: 14px !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    height: 82px !important;
    margin-top: 20px !important;
    border-radius: 9px !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 66px !important;
    height: 66px !important;
  }

  .xiaobo-card-img {
    width: 78px !important;
    height: 78px !important;
  }

  .xiaobo-collar {
    width: 36px !important;
    height: 14px !important;
  }

  .xiaobo-collar img,
  .xiaobo-jewel img {
    width: 13px !important;
    height: 13px !important;
  }

  .art-label {
    display: inline-grid !important;
    position: absolute !important;
    left: 50% !important;
    bottom: 5px !important;
    transform: translateX(-50%) !important;
    min-width: 46px !important;
    padding: 2px 7px !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.92) !important;
    color: #17202e !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    text-align: center !important;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.12) !important;
  }

  .cost {
    grid-template-columns: repeat(3, 25px) !important;
    gap: 5px !important;
    margin-top: 2px !important;
  }

  .cost-item {
    width: 25px !important;
    height: 25px !important;
    border-width: 2px !important;
  }

  .cost-item strong {
    font-size: 12px !important;
    font-weight: 900 !important;
  }

  .card-actions {
    gap: 5px !important;
  }

  .card-actions button {
    height: 30px !important;
    min-height: 30px !important;
    border-radius: 8px !important;
    font-size: 13px !important;
  }

  .player-panel > .panel:nth-of-type(4) {
    height: auto !important;
    min-height: 64px !important;
    padding: 8px !important;
    background: #ffffff !important;
    overflow: visible !important;
  }

  .reserved-list {
    min-height: 48px !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 7px !important;
    overflow: visible !important;
  }

  .reserved-card {
    min-height: 86px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    align-items: stretch !important;
    gap: 5px !important;
    padding: 6px !important;
    background: #fff8d9 !important;
    border: 1px solid rgba(212, 173, 61, 0.35) !important;
  }

  .reserved-main {
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 54px !important;
    align-items: center !important;
    gap: 5px !important;
  }

  .reserved-main span {
    display: block !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
  }

  .reserved-main button {
    width: 54px !important;
    height: 28px !important;
    min-height: 28px !important;
    font-size: 12px !important;
  }

  .reserved-cost {
    display: grid !important;
    gap: 3px !important;
  }

  .reserved-cost .cost-label {
    display: none !important;
  }

  .reserved-cost .cost {
    display: grid !important;
    grid-template-columns: repeat(3, 23px) !important;
    justify-content: start !important;
    gap: 4px !important;
    margin: 0 !important;
  }

  .reserved-cost .cost-item {
    width: 23px !important;
    height: 23px !important;
  }
}

@media (max-width: 390px) {
  .game-shell {
    padding: 5px !important;
  }

  .status-strip {
    grid-template-columns: minmax(0, 1fr) 124px !important;
  }

  .quick-stat {
    grid-template-columns: 56px minmax(0, 1fr) !important;
  }

  .quick-token {
    width: 23px !important;
    height: 23px !important;
  }

  .market {
    grid-auto-rows: 160px !important;
    gap: 6px !important;
  }

  .card {
    height: 160px !important;
    padding: 5px !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    height: 74px !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 58px !important;
    height: 58px !important;
  }

  .xiaobo-card-img {
    width: 70px !important;
    height: 70px !important;
  }

  .cost {
    grid-template-columns: repeat(3, 23px) !important;
    gap: 4px !important;
  }

  .cost-item {
    width: 23px !important;
    height: 23px !important;
  }
}

/* Phone polish: remove unused action buttons and make every counter readable. */
@media (max-width: 640px) {
  html,
  body {
    background: #ffffff !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  .game-shell {
    width: min(100vw, 430px) !important;
    min-height: 100dvh !important;
    height: auto !important;
    display: grid !important;
    grid-template-rows: 64px 116px auto !important;
    gap: 6px !important;
    padding: 6px !important;
    background: #ffffff !important;
    overflow: visible !important;
  }

  .topbar {
    height: 64px !important;
    background: #ffffff !important;
  }

  .status-strip {
    height: 116px !important;
    grid-template-columns: 1fr !important;
    padding: 8px !important;
    background: #ffffff !important;
    border: 1px solid #d7e1ea !important;
    overflow: visible !important;
  }

  .status-actions {
    display: none !important;
  }

  .player-quick {
    grid-column: 1 !important;
    width: 100% !important;
    display: grid !important;
    grid-template-rows: repeat(2, 48px) !important;
    gap: 7px !important;
    min-width: 0 !important;
  }

  .quick-stat {
    height: 48px !important;
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 76px minmax(0, 1fr) !important;
    gap: 7px !important;
    align-items: center !important;
    padding: 6px 8px !important;
    background: #f8fafc !important;
    border: 1px solid #dfe8f0 !important;
    border-radius: 12px !important;
    overflow: visible !important;
  }

  .quick-stat > span {
    font-size: 15px !important;
    font-weight: 900 !important;
    color: #172033 !important;
    white-space: nowrap !important;
  }

  .quick-token-row {
    display: grid !important;
    grid-template-columns: repeat(6, 28px) !important;
    justify-content: start !important;
    gap: 4px !important;
    min-width: 0 !important;
  }

  .quick-token {
    width: 28px !important;
    height: 28px !important;
    margin: 0 !important;
  }

  .quick-token strong {
    font-size: 13px !important;
    font-weight: 900 !important;
  }

  .layout {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    overflow: visible !important;
  }

  .player-panel {
    display: contents !important;
  }

  .player-panel > .panel:nth-of-type(2),
  .player-panel > .panel:nth-of-type(3) {
    display: none !important;
  }

  .player-panel > .panel:nth-of-type(4) {
    order: 1 !important;
    min-height: 74px !important;
    height: auto !important;
    padding: 7px !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    border: 1px solid #d7e1ea !important;
    overflow: visible !important;
  }

  .player-panel > .panel:nth-of-type(4) h2 {
    display: none !important;
  }

  .reserved-list {
    min-height: 60px !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    margin: 0 !important;
    overflow: visible !important;
  }

  .reserved-list .hint {
    align-self: center !important;
    margin: 0 !important;
    text-align: center !important;
    font-size: 13px !important;
  }

  .reserved-card {
    min-height: 74px !important;
    padding: 6px !important;
    display: grid !important;
    grid-template-rows: auto auto !important;
    grid-template-columns: 1fr !important;
    gap: 5px !important;
    background: #fff8dc !important;
    border: 1px solid rgba(199, 164, 58, 0.42) !important;
    border-radius: 12px !important;
  }

  .reserved-main {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 48px !important;
    gap: 5px !important;
    align-items: center !important;
  }

  .reserved-main span {
    min-width: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    font-size: 12px !important;
    font-weight: 800 !important;
  }

  .reserved-main button {
    width: 48px !important;
    height: 26px !important;
    min-height: 26px !important;
    padding: 0 !important;
    font-size: 12px !important;
    border-radius: 8px !important;
  }

  .reserved-cost {
    display: block !important;
  }

  .reserved-cost .cost {
    display: grid !important;
    grid-template-columns: repeat(3, 22px) !important;
    justify-content: start !important;
    gap: 4px !important;
    margin: 0 !important;
  }

  .reserved-cost .cost-item {
    width: 22px !important;
    height: 22px !important;
  }

  .opponents-panel {
    order: 2 !important;
    height: 102px !important;
    padding: 6px !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    border: 1px solid #d7e1ea !important;
    overflow: visible !important;
  }

  .opponents-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    height: 100% !important;
  }

  .opponent-card {
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 9px 5px 5px !important;
    border-radius: 10px !important;
    background: linear-gradient(145deg, #fff5be, #ffd438) !important;
    overflow: visible !important;
  }

  .opponent-score {
    width: 23px !important;
    height: 23px !important;
    top: -6px !important;
    left: -4px !important;
  }

  .opponent-score .score-current,
  .opponent-score .score-limit {
    display: none !important;
  }

  .opponent-score::after {
    content: attr(data-score) !important;
    font-size: 14px !important;
  }

  .opponent-top {
    grid-template-columns: 18px minmax(0, 1fr) !important;
    gap: 4px !important;
    margin: 0 0 5px !important;
  }

  .opponent-avatar {
    width: 18px !important;
    height: 18px !important;
  }

  .opponent-top strong {
    font-size: 12px !important;
  }

  .opponent-holdings {
    display: grid !important;
    grid-template-rows: 18px 18px !important;
    gap: 5px !important;
    overflow: visible !important;
  }

  .opponent-bonuses {
    display: grid !important;
    grid-template-columns: repeat(5, 17px) !important;
    justify-content: center !important;
    gap: 2px !important;
  }

  .opponent-tokens {
    display: grid !important;
    grid-template-columns: repeat(6, 15px) !important;
    justify-content: center !important;
    gap: 2px !important;
  }

  .opponent-marker {
    width: 15px !important;
    height: 15px !important;
    margin: 0 !important;
    border-width: 1px !important;
  }

  .opponent-bonuses .opponent-marker {
    width: 17px !important;
    height: 17px !important;
  }

  .opponent-marker strong {
    font-size: 10px !important;
  }

  .player-panel > .panel:nth-of-type(1) {
    order: 3 !important;
    height: 62px !important;
    padding: 7px !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    border: 1px solid #d7e1ea !important;
    overflow: visible !important;
  }

  .bank {
    width: 100% !important;
    height: 100% !important;
    display: grid !important;
    grid-template-columns: repeat(6, 50px) !important;
    justify-content: center !important;
    gap: 6px !important;
    margin: 0 auto !important;
  }

  .chip-button {
    width: 50px !important;
    height: 48px !important;
    border-radius: 11px !important;
  }

  .chip-button .gem img {
    width: 32px !important;
    height: 32px !important;
  }

  .chip-button strong {
    min-width: 19px !important;
    height: 19px !important;
    font-size: 12px !important;
  }

  .market-panel {
    order: 4 !important;
    padding: 8px !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    border: 1px solid #d7e1ea !important;
    overflow: visible !important;
  }

  .market {
    height: auto !important;
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    grid-template-rows: none !important;
    grid-auto-rows: 182px !important;
    gap: 8px !important;
    overflow: visible !important;
  }

  .card {
    height: 182px !important;
    min-height: 0 !important;
    padding: 6px !important;
    display: grid !important;
    grid-template-rows: 24px 86px 28px 30px !important;
    gap: 4px !important;
    border-radius: 12px !important;
    overflow: hidden !important;
  }

  .card-top {
    position: static !important;
    display: flex !important;
    justify-content: flex-end !important;
    min-height: 0 !important;
  }

  .points {
    width: 25px !important;
    height: 25px !important;
    font-size: 14px !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    width: 100% !important;
    height: 86px !important;
    min-height: 0 !important;
    margin: 0 !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 10px !important;
    overflow: hidden !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 76px !important;
    height: 76px !important;
    transform: none !important;
    overflow: visible !important;
  }

  .xiaobo-card-img {
    width: 74px !important;
    height: 74px !important;
    left: auto !important;
    transform: none !important;
    object-fit: contain !important;
    object-position: center center !important;
    border-radius: 18px !important;
  }

  .xiaobo-card-portrait::before {
    width: 64px !important;
    height: 38px !important;
  }

  .xiaobo-collar {
    width: 34px !important;
    height: 14px !important;
    bottom: 3px !important;
  }

  .art-label {
    display: inline-grid !important;
    min-width: 48px !important;
    left: 50% !important;
    bottom: 5px !important;
    transform: translateX(-50%) !important;
    font-size: 10px !important;
  }

  .cost {
    display: grid !important;
    grid-template-columns: repeat(3, 24px) !important;
    justify-content: center !important;
    gap: 5px !important;
    margin: 0 !important;
  }

  .cost-item {
    width: 24px !important;
    height: 24px !important;
  }

  .cost-item strong {
    font-size: 12px !important;
  }

  .card-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 5px !important;
  }

  .card-actions button {
    height: 30px !important;
    min-height: 30px !important;
    font-size: 13px !important;
    border-radius: 8px !important;
  }
}

@media (max-width: 390px) {
  .quick-stat {
    grid-template-columns: 68px minmax(0, 1fr) !important;
  }

  .quick-token-row {
    grid-template-columns: repeat(6, 24px) !important;
    gap: 3px !important;
  }

  .quick-token {
    width: 24px !important;
    height: 24px !important;
  }

  .bank {
    grid-template-columns: repeat(6, 45px) !important;
    gap: 5px !important;
  }

  .chip-button {
    width: 45px !important;
  }

  .market {
    grid-auto-rows: 170px !important;
    gap: 6px !important;
  }

  .card {
    height: 170px !important;
    grid-template-rows: 23px 80px 26px 28px !important;
    padding: 5px !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    height: 80px !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 68px !important;
    height: 68px !important;
  }

  .xiaobo-card-img {
    width: 66px !important;
    height: 66px !important;
  }

  .cost {
    grid-template-columns: repeat(3, 22px) !important;
    gap: 4px !important;
  }

  .cost-item {
    width: 22px !important;
    height: 22px !important;
  }
}

/* Final phone fit: two full player rows, one-line rival gems, roomier card costs. */
@media (max-width: 640px) {
  .game-shell {
    grid-template-rows: 64px 124px auto !important;
  }

  .status-strip {
    height: 124px !important;
    padding: 8px !important;
  }

  .player-quick {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: repeat(2, 52px) !important;
    gap: 6px !important;
  }

  .quick-stat {
    width: 100% !important;
    height: 52px !important;
    grid-template-columns: 82px minmax(0, 1fr) !important;
    padding: 6px 8px !important;
    overflow: visible !important;
  }

  .quick-stat > span {
    font-size: 15px !important;
  }

  .quick-token-row {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 5px !important;
    overflow: visible !important;
  }

  .quick-token {
    flex: 0 0 27px !important;
    width: 27px !important;
    height: 27px !important;
  }

  .opponents-panel {
    height: 92px !important;
    overflow: visible !important;
  }

  .opponent-card {
    padding: 9px 4px 5px !important;
  }

  .opponent-top {
    margin-bottom: 4px !important;
  }

  .opponent-holdings {
    display: grid !important;
    grid-template-rows: 18px 18px !important;
    gap: 5px !important;
    overflow: visible !important;
  }

  .opponent-bonuses {
    display: grid !important;
    grid-template-columns: repeat(5, 18px) !important;
    justify-content: center !important;
    gap: 2px !important;
  }

  .opponent-tokens {
    display: grid !important;
    grid-template-columns: repeat(6, 15px) !important;
    justify-content: center !important;
    gap: 1px !important;
    overflow: visible !important;
  }

  .opponent-bonuses .opponent-marker {
    width: 18px !important;
    height: 18px !important;
  }

  .opponent-tokens .opponent-marker {
    width: 15px !important;
    height: 15px !important;
  }

  .opponent-marker strong {
    font-size: 10px !important;
  }

  .bank {
    grid-template-columns: repeat(6, 48px) !important;
    justify-content: center !important;
    gap: 7px !important;
  }

  .market {
    grid-auto-rows: 190px !important;
  }

  .card {
    height: 190px !important;
    grid-template-rows: 108px 38px 31px !important;
    gap: 5px !important;
    position: relative !important;
  }

  .card-top {
    position: absolute !important;
    top: 6px !important;
    right: 6px !important;
    z-index: 10 !important;
    display: block !important;
  }

  .points {
    width: 24px !important;
    height: 24px !important;
    min-width: 24px !important;
    font-size: 14px !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    height: 108px !important;
    margin: 0 !important;
    padding-top: 6px !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 84px !important;
    height: 84px !important;
  }

  .xiaobo-card-img {
    width: 82px !important;
    height: 82px !important;
    object-fit: contain !important;
    object-position: center center !important;
  }

  .cost {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-content: center !important;
    gap: 4px !important;
    min-height: 38px !important;
    margin: 0 !important;
  }

  .cost-item {
    flex: 0 0 23px !important;
    width: 23px !important;
    height: 23px !important;
  }

  .cost-item strong {
    font-size: 11px !important;
  }

  .card-actions {
    align-self: end !important;
  }

  .card-actions button {
    height: 31px !important;
    min-height: 31px !important;
    font-size: 13px !important;
  }
}

@media (max-width: 390px) {
  .quick-stat {
    grid-template-columns: 76px minmax(0, 1fr) !important;
  }

  .quick-token {
    flex-basis: 24px !important;
    width: 24px !important;
    height: 24px !important;
  }

  .quick-token-row {
    gap: 4px !important;
  }

  .opponent-bonuses {
    grid-template-columns: repeat(5, 16px) !important;
  }

  .opponent-tokens {
    grid-template-columns: repeat(6, 14px) !important;
  }

  .opponent-bonuses .opponent-marker {
    width: 16px !important;
    height: 16px !important;
  }

  .opponent-tokens .opponent-marker {
    width: 14px !important;
    height: 14px !important;
  }

  .bank {
    grid-template-columns: repeat(6, 43px) !important;
    gap: 6px !important;
  }

  .market {
    grid-auto-rows: 180px !important;
  }

  .card {
    height: 180px !important;
    grid-template-rows: 100px 37px 30px !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    height: 100px !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 76px !important;
    height: 76px !important;
  }

  .xiaobo-card-img {
    width: 74px !important;
    height: 74px !important;
  }

  .cost-item {
    flex-basis: 22px !important;
    width: 22px !important;
    height: 22px !important;
  }
}

/* Mobile final pass: compact rivals, bottom reservations, cleaner Xiaobo cards. */
@media (max-width: 640px) {
  body {
    background: #f8faf9 !important;
  }

  .game-shell {
    grid-template-rows: 64px auto !important;
    gap: 6px !important;
    padding: 6px !important;
  }

  .status-strip {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 8px !important;
    background: #ffffff !important;
    overflow: visible !important;
  }

  .status-box,
  .status-actions {
    display: none !important;
  }

  .player-quick {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: repeat(2, 48px) !important;
    gap: 7px !important;
  }

  .quick-stat {
    display: grid !important;
    grid-template-columns: 92px minmax(0, 1fr) !important;
    height: 48px !important;
    min-height: 48px !important;
    padding: 5px 8px !important;
    border-radius: 12px !important;
    background: #fbfcfd !important;
    overflow: hidden !important;
  }

  .quick-stat > span {
    font-size: 16px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  .quick-token-row {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 4px !important;
    min-width: 0 !important;
    overflow: visible !important;
  }

  .quick-token {
    flex: 0 0 25px !important;
    width: 25px !important;
    height: 25px !important;
    min-width: 25px !important;
    margin: 0 !important;
    transform: none !important;
  }

  .quick-token img,
  .quick-token .gem img {
    width: 18px !important;
    height: 18px !important;
  }

  .quick-token strong {
    font-size: 12px !important;
  }

  .layout {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 6px !important;
  }

  .player-panel {
    display: contents !important;
  }

  .opponents-panel {
    order: 1 !important;
    display: block !important;
    height: 86px !important;
    min-height: 86px !important;
    padding: 5px !important;
    border-radius: 10px !important;
    background: #ffd533 !important;
    overflow: hidden !important;
  }

  .opponents-panel .panel-head {
    display: none !important;
  }

  .opponents {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 4px !important;
    height: 100% !important;
  }

  .opponent-card {
    display: grid !important;
    grid-template-rows: 18px 22px 18px !important;
    gap: 3px !important;
    min-width: 0 !important;
    height: 76px !important;
    padding: 6px 4px 4px !important;
    border-radius: 9px !important;
    background: rgba(255, 255, 255, 0.2) !important;
    border-color: rgba(255, 255, 255, 0.38) !important;
    overflow: hidden !important;
  }

  .opponent-top {
    display: grid !important;
    grid-template-columns: 18px minmax(0, 1fr) !important;
    gap: 3px !important;
    margin: 0 !important;
    min-width: 0 !important;
  }

  .opponent-avatar {
    width: 18px !important;
    height: 18px !important;
  }

  .opponent-name {
    font-size: 12px !important;
    line-height: 18px !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .opponent-last,
  .score-limit,
  .opponent-meta {
    display: none !important;
  }

  .opponent-score {
    position: absolute !important;
    top: 2px !important;
    left: 2px !important;
    z-index: 3 !important;
    width: 23px !important;
    height: 23px !important;
    border-radius: 999px !important;
    background: #0f1f31 !important;
    color: #ffffff !important;
    display: grid !important;
    place-items: center !important;
    border: 2px solid #ffffff !important;
    box-shadow: 0 2px 5px rgba(15, 31, 49, 0.18) !important;
  }

  .score-current {
    font-size: 14px !important;
    line-height: 1 !important;
  }

  .opponent-holdings {
    display: grid !important;
    grid-template-rows: 19px 18px !important;
    gap: 3px !important;
    overflow: hidden !important;
    min-width: 0 !important;
  }

  .opponent-bonuses,
  .opponent-tokens {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  .opponent-bonuses {
    gap: 2px !important;
  }

  .opponent-tokens {
    gap: 1px !important;
  }

  .opponent-bonuses .opponent-marker {
    flex: 0 0 16px !important;
    width: 16px !important;
    min-width: 16px !important;
    height: 16px !important;
    margin: 0 !important;
    border-radius: 4px !important;
  }

  .opponent-tokens .opponent-marker {
    flex: 0 0 13px !important;
    width: 13px !important;
    min-width: 13px !important;
    height: 13px !important;
    margin: 0 !important;
    border-radius: 999px !important;
  }

  .opponent-marker img,
  .opponent-marker .gem {
    display: none !important;
  }

  .opponent-marker strong {
    display: block !important;
    font-size: 9px !important;
    line-height: 1 !important;
  }

  .player-panel > .panel:nth-of-type(1) {
    order: 2 !important;
  }

  .market-panel {
    order: 3 !important;
  }

  .player-panel > .panel:nth-of-type(4) {
    order: 4 !important;
  }

  .player-panel > .panel:nth-of-type(2),
  .player-panel > .panel:nth-of-type(3) {
    display: none !important;
  }

  .market {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    grid-auto-rows: 174px !important;
    gap: 7px !important;
  }

  .card {
    height: 174px !important;
    min-width: 0 !important;
    grid-template-rows: 92px 42px 28px !important;
    gap: 4px !important;
    padding: 7px 5px 5px !important;
    border-radius: 10px !important;
    overflow: hidden !important;
  }

  .card-top {
    position: absolute !important;
    top: 10px !important;
    right: 7px !important;
    z-index: 8 !important;
    display: block !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
  }

  .card-name {
    display: none !important;
  }

  .points {
    width: 22px !important;
    min-width: 22px !important;
    height: 22px !important;
    border-radius: 999px !important;
    font-size: 13px !important;
    box-shadow: 0 3px 7px rgba(15, 31, 49, 0.2) !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    height: 92px !important;
    margin: 0 !important;
    padding: 3px 0 0 !important;
    display: grid !important;
    place-items: center !important;
    overflow: hidden !important;
  }

  .art-frame,
  .art-glow,
  .art-rays,
  .art-orbit,
  .art-motif,
  .art-crown,
  .art-label,
  .art-stars,
  .xiaobo-jewel.side-jewel {
    display: none !important;
  }

  .card-art.red {
    --crown-color: #ef4561;
  }

  .card-art.green {
    --crown-color: #21b889;
  }

  .card-art.blue {
    --crown-color: #2f94df;
  }

  .card-art.white {
    --crown-color: #d9e3eb;
  }

  .card-art.black {
    --crown-color: #182434;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    position: relative !important;
    width: 78px !important;
    height: 78px !important;
    border-radius: 18px !important;
    background: #fffaf1 !important;
    overflow: visible !important;
  }

  .xiaobo-card-portrait::after {
    content: "" !important;
    position: absolute !important;
    top: -7px !important;
    left: 50% !important;
    z-index: 4 !important;
    width: 36px !important;
    height: 18px !important;
    transform: translateX(-50%) !important;
    background: linear-gradient(135deg, #fff7c8, var(--crown-color, #d6a323)) !important;
    clip-path: polygon(0 100%, 14% 40%, 28% 78%, 50% 0, 72% 78%, 86% 40%, 100% 100%) !important;
    filter: drop-shadow(0 2px 3px rgba(15, 31, 49, 0.22)) !important;
  }

  .xiaobo-jewel.crown-jewel {
    display: block !important;
    position: absolute !important;
    top: -2px !important;
    left: 50% !important;
    z-index: 5 !important;
    width: 15px !important;
    height: 15px !important;
    transform: translateX(-50%) !important;
  }

  .xiaobo-jewel.crown-jewel img {
    width: 15px !important;
    height: 15px !important;
  }

  .xiaobo-card-img {
    position: relative !important;
    z-index: 2 !important;
    width: 76px !important;
    height: 76px !important;
    max-width: 76px !important;
    max-height: 76px !important;
    object-fit: contain !important;
    object-position: center bottom !important;
    transform: none !important;
  }

  .xiaobo-collar {
    bottom: 2px !important;
    width: 44px !important;
    height: 18px !important;
  }

  .cost {
    display: grid !important;
    grid-template-columns: repeat(4, 21px) !important;
    justify-content: center !important;
    align-content: center !important;
    gap: 3px !important;
    min-height: 42px !important;
    margin: 0 !important;
    overflow: visible !important;
  }

  .cost-item {
    width: 21px !important;
    min-width: 21px !important;
    height: 21px !important;
    min-height: 21px !important;
    margin: 0 !important;
  }

  .cost-item .gem,
  .cost-item img {
    display: none !important;
  }

  .cost-item strong {
    font-size: 11px !important;
    line-height: 1 !important;
  }

  .card-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 3px !important;
    height: 28px !important;
  }

  .card-actions button {
    height: 28px !important;
    min-height: 28px !important;
    padding: 0 !important;
    font-size: 12px !important;
    border-radius: 7px !important;
  }

  .reserved-list {
    max-height: none !important;
    overflow: visible !important;
  }
}

@media (max-width: 390px) {
  .quick-stat {
    grid-template-columns: 86px minmax(0, 1fr) !important;
  }

  .quick-token {
    flex-basis: 23px !important;
    width: 23px !important;
    min-width: 23px !important;
    height: 23px !important;
  }

  .opponent-bonuses .opponent-marker {
    flex-basis: 15px !important;
    width: 15px !important;
    min-width: 15px !important;
    height: 15px !important;
  }

  .opponent-tokens .opponent-marker {
    flex-basis: 12px !important;
    width: 12px !important;
    min-width: 12px !important;
    height: 12px !important;
  }

  .market {
    grid-auto-rows: 168px !important;
    gap: 6px !important;
  }

  .card {
    height: 168px !important;
    grid-template-rows: 88px 40px 27px !important;
    padding-inline: 4px !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    height: 88px !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 72px !important;
    height: 72px !important;
  }

  .xiaobo-card-img {
    width: 70px !important;
    height: 70px !important;
  }

  .cost {
    grid-template-columns: repeat(4, 20px) !important;
    min-height: 40px !important;
    gap: 2px !important;
  }

  .cost-item {
    width: 20px !important;
    min-width: 20px !important;
    height: 20px !important;
    min-height: 20px !important;
  }
}

/* Mobile detail fix: visible rival tokens, centered cards, score away from Xiaobo crown. */
@media (max-width: 640px) {
  .opponents-panel {
    height: 98px !important;
    min-height: 98px !important;
    padding: 6px !important;
  }

  .opponent-card {
    height: 86px !important;
    grid-template-rows: 18px 20px 18px !important;
    gap: 4px !important;
    padding: 7px 4px 5px !important;
    position: relative !important;
  }

  .opponent-score {
    top: 3px !important;
    left: 3px !important;
    width: 22px !important;
    height: 22px !important;
  }

  .opponent-top {
    padding-left: 20px !important;
  }

  .opponent-holdings {
    grid-row: 2 / 4 !important;
    display: grid !important;
    grid-template-rows: 20px 18px !important;
    gap: 4px !important;
    width: 100% !important;
    overflow: visible !important;
  }

  .opponent-bonuses,
  .opponent-tokens {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  .opponent-bonuses {
    gap: 2px !important;
  }

  .opponent-tokens {
    gap: 2px !important;
  }

  .opponent-bonuses .opponent-marker {
    flex: 0 0 17px !important;
    width: 17px !important;
    min-width: 17px !important;
    height: 17px !important;
  }

  .opponent-tokens .opponent-marker {
    display: grid !important;
    place-items: center !important;
    flex: 0 0 14px !important;
    width: 14px !important;
    min-width: 14px !important;
    height: 14px !important;
    border-radius: 999px !important;
  }

  .opponent-token strong,
  .opponent-tokens .opponent-marker strong {
    display: block !important;
    color: inherit !important;
    font-size: 9px !important;
    line-height: 1 !important;
  }

  .market-panel {
    padding: 7px !important;
    overflow: hidden !important;
  }

  .market {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 5px !important;
    justify-items: stretch !important;
  }

  .card {
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    justify-items: center !important;
    align-items: center !important;
    padding: 7px 4px 5px !important;
    grid-template-rows: 91px 46px 28px !important;
    overflow: hidden !important;
  }

  .card-top {
    top: 9px !important;
    left: 8px !important;
    right: auto !important;
    z-index: 12 !important;
  }

  .points {
    width: 21px !important;
    min-width: 21px !important;
    height: 21px !important;
    font-size: 12px !important;
    color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.86) !important;
    box-shadow: 0 2px 6px rgba(15, 31, 49, 0.24) !important;
  }

  .card.red .points {
    background: linear-gradient(145deg, #ff6b80, #c61f3b) !important;
  }

  .card.green .points {
    background: linear-gradient(145deg, #4bd8a7, #158b68) !important;
  }

  .card.blue .points {
    background: linear-gradient(145deg, #5db8ff, #176eac) !important;
  }

  .card.white .points {
    background: linear-gradient(145deg, #ffffff, #aab6c4) !important;
    color: #152233 !important;
  }

  .card.black .points {
    background: linear-gradient(145deg, #52606f, #0b1725) !important;
  }

  .score-3 .points,
  .score-4 .points {
    border-color: rgba(255, 237, 174, 0.96) !important;
    box-shadow:
      0 0 0 1px rgba(201, 149, 33, 0.38),
      0 3px 9px rgba(201, 149, 33, 0.34) !important;
  }

  .score-4 .points {
    background: linear-gradient(145deg, #ffe680, #c58a0b 55%, #8a5a04) !important;
    color: #142033 !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    width: 100% !important;
    height: 91px !important;
    justify-self: center !important;
    place-items: center !important;
    padding-top: 2px !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 72px !important;
    height: 72px !important;
    margin: 0 auto !important;
    transform: translateX(0) !important;
  }

  .xiaobo-card-img {
    width: 70px !important;
    height: 70px !important;
    margin: 0 auto !important;
  }

  .cost {
    width: 52px !important;
    min-height: 46px !important;
    grid-template-columns: repeat(2, 22px) !important;
    grid-auto-rows: 22px !important;
    justify-content: center !important;
    align-content: center !important;
    gap: 3px 4px !important;
    overflow: visible !important;
  }

  .cost-item {
    width: 22px !important;
    min-width: 22px !important;
    height: 22px !important;
    min-height: 22px !important;
  }

  .cost-item strong {
    font-size: 11px !important;
  }

  .card-actions {
    width: 100% !important;
    min-width: 0 !important;
    gap: 2px !important;
  }

  .card-actions button {
    min-width: 0 !important;
    font-size: 12px !important;
  }
}

@media (max-width: 390px) {
  .opponent-bonuses .opponent-marker {
    flex-basis: 16px !important;
    width: 16px !important;
    min-width: 16px !important;
    height: 16px !important;
  }

  .opponent-tokens .opponent-marker {
    flex-basis: 13px !important;
    width: 13px !important;
    min-width: 13px !important;
    height: 13px !important;
  }

  .market-panel {
    padding: 6px !important;
  }

  .market {
    gap: 4px !important;
  }

  .card {
    grid-template-rows: 88px 45px 27px !important;
    padding-inline: 3px !important;
  }

  .card-art,
  .art-score-0,
  .art-score-1,
  .art-score-2,
  .art-score-3,
  .art-score-4 {
    height: 88px !important;
  }

  .xiaobo-card-portrait,
  .art-score-3 .xiaobo-card-portrait,
  .art-score-4 .xiaobo-card-portrait {
    width: 68px !important;
    height: 68px !important;
  }

  .xiaobo-card-img {
    width: 66px !important;
    height: 66px !important;
  }

  .cost {
    width: 48px !important;
    grid-template-columns: repeat(2, 21px) !important;
    grid-auto-rows: 21px !important;
    gap: 3px !important;
  }

  .cost-item {
    width: 21px !important;
    min-width: 21px !important;
    height: 21px !important;
    min-height: 21px !important;
  }
}
