:root {
  --pink-50: #fff7fc;
  --pink-100: #ffe8f4;
  --pink-200: #ffcde6;
  --pink-300: #ffacd2;
  --pink-400: #ff7eb6;
  --pink-500: #f65d9d;
  --rose: #ff8fab;
  --lavender: #c9b6ff;
  --violet: #a890ff;
  --lilac: #f1eaff;
  --mint: #ddfbf3;
  --cream: #fffaf1;
  --ink: #463347;
  --muted: #8b6f8c;
  --card: rgba(255, 255, 255, 0.84);
  --line: rgba(255, 126, 182, 0.24);
  --shadow: 0 22px 60px rgba(148, 77, 132, 0.18);
  --soft-shadow: 0 12px 28px rgba(247, 93, 157, 0.13);
  --cell: 32px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Inter", "PingFang SC", "Microsoft YaHei", system-ui, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 8% 8%, rgba(255, 201, 227, 0.98), transparent 26rem),
    radial-gradient(circle at 88% 4%, rgba(201, 182, 255, 0.78), transparent 25rem),
    radial-gradient(circle at 72% 88%, rgba(223, 251, 243, 0.72), transparent 22rem),
    linear-gradient(135deg, var(--pink-50), #fff, var(--lilac));
  overflow-x: hidden;
}

button, input { font: inherit; }
button { cursor: pointer; }

.bg-decor {
  position: fixed;
  z-index: 0;
  color: rgba(255, 126, 182, 0.28);
  font-size: 9rem;
  pointer-events: none;
  filter: blur(0.2px);
}
.decor-1 { top: 6rem; right: 7vw; }
.decor-2 { bottom: 8vh; left: 4vw; transform: rotate(-15deg); }
.decor-3 { bottom: 18vh; right: 12vw; font-size: 6rem; }

.app-shell {
  position: relative;
  z-index: 1;
  width: min(1480px, calc(100% - 32px));
  margin: 0 auto;
  padding: 28px 0 42px;
}

.hero-card,
.dashboard,
.main-layout,
.panel-card,
.game-card,
.modal-card {
  border: 1px solid rgba(255, 255, 255, 0.7);
  box-shadow: var(--shadow);
}

.hero-card {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
  padding: 28px;
  border-radius: 34px;
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(255, 232, 244, 0.78)),
    radial-gradient(circle at 92% 24%, rgba(255, 126, 182, 0.22), transparent 11rem);
  backdrop-filter: blur(18px);
}


.hero-card::before,
.hero-card::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}
.hero-card::before {
  width: 180px;
  height: 180px;
  right: -48px;
  top: -70px;
  background: rgba(255, 172, 210, 0.32);
}
.hero-card::after {
  width: 120px;
  height: 120px;
  right: 210px;
  bottom: -72px;
  background: rgba(201, 182, 255, 0.28);
}

.eyebrow {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--pink-500);
  font-size: 12px;
  font-weight: 800;
}

h1, h2, p { margin-top: 0; }
h1 {
  margin-bottom: 10px;
  font-size: clamp(32px, 5vw, 62px);
  letter-spacing: -0.06em;
  line-height: 1;
}
h2 { font-size: 20px; margin-bottom: 12px; }
.hero-copy { color: var(--muted); margin-bottom: 0; font-size: 16px; }

.profile-card {
  width: min(320px, 100%);
  padding: 18px;
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid var(--line);
}
.profile-card label,
.range-label {
  display: block;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 8px;
}
.profile-card input {
  width: 100%;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  border-radius: 16px;
  padding: 12px 14px;
  outline: none;
}
.profile-card input:focus { border-color: var(--pink-400); box-shadow: 0 0 0 4px rgba(255, 126, 182, 0.16); }
.level-pill {
  margin-top: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--mint), var(--lilac));
  font-weight: 800;
}
.level-pill strong { color: var(--pink-500); }

.mode-switch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 12px;
  padding: 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid var(--line);
}
.mode-btn {
  border: 0;
  border-radius: 999px;
  padding: 10px 12px;
  color: var(--muted);
  background: transparent;
  font-size: 13px;
  font-weight: 900;
  transition: transform 0.16s ease, background 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}
.mode-btn:hover { transform: translateY(-1px); color: var(--pink-500); }
.mode-btn.active {
  color: #fff;
  background: linear-gradient(135deg, var(--pink-500), var(--lavender));
  box-shadow: 0 8px 18px rgba(247, 93, 157, 0.22);
}


.dashboard {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin: 18px 0;
  padding: 14px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.56);
  backdrop-filter: blur(16px);
}
.stat-card {
  padding: 18px;
  min-height: 122px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid var(--line);
  box-shadow: var(--soft-shadow);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.stat-card:hover { transform: translateY(-2px); box-shadow: 0 16px 34px rgba(247, 93, 157, 0.17); }
.stat-card.accent { background: linear-gradient(135deg, var(--pink-100), var(--cream)); }
.stat-card span, .stat-card small { color: var(--muted); display: block; }
.stat-card strong {
  display: block;
  margin: 8px 0 4px;
  font-size: 34px;
  line-height: 1;
  letter-spacing: -0.04em;
}

.main-layout {
  display: grid;
  grid-template-columns: 330px minmax(0, 1fr);
  gap: 18px;
  padding: 14px;
  border-radius: 32px;
  background: rgba(255, 255, 255, 0.42);
  backdrop-filter: blur(20px);
}
.side-panel { display: grid; gap: 14px; align-content: start; }
.panel-card, .game-card {
  border-radius: 28px;
  background: var(--card);
  backdrop-filter: blur(16px);
  padding: 18px;
  box-shadow: var(--soft-shadow);
}
.panel-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.panel-title-row h2 { margin-bottom: 0; }
.hint { color: var(--muted); font-size: 14px; line-height: 1.6; }

.target-list {
  display: grid;
  gap: 10px;
  max-height: 410px;
  overflow: auto;
  padding-right: 4px;
}
.target-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border-radius: 18px;
  background: rgba(255, 245, 251, 0.86);
  border: 1px solid var(--line);
  transition: transform 0.16s ease, background 0.16s ease;
}
.target-item .word { font-weight: 900; letter-spacing: 0.03em; text-transform: uppercase; }
.target-item .tag { color: var(--muted); font-size: 12px; }
.target-item.found {
  background: linear-gradient(135deg, var(--mint), #fff);
  text-decoration: line-through;
  opacity: 0.74;
}
.target-item.pending { transform: scale(1.02); border-color: var(--pink-400); }

.controls { display: grid; gap: 12px; }
.control-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.primary-btn,
.ghost-btn,
.mini-btn {
  border: 0;
  border-radius: 999px;
  padding: 11px 14px;
  font-weight: 800;
  transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
}
.primary-btn {
  color: #fff;
  background: linear-gradient(135deg, var(--pink-500), var(--lavender));
  box-shadow: 0 10px 24px rgba(247, 93, 157, 0.28);
}
.ghost-btn, .mini-btn {
  color: var(--pink-500);
  background: #fff;
  border: 1px solid var(--line);
}
.mini-btn { padding: 8px 10px; font-size: 12px; }
.primary-btn:hover, .ghost-btn:hover, .mini-btn:hover { transform: translateY(-1px); }
button:disabled { opacity: 0.45; cursor: not-allowed; transform: none !important; }
input[type="range"] { width: 100%; accent-color: var(--pink-500); }

.level-map {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 6px;
}
.level-dot {
  aspect-ratio: 1;
  border: 0;
  border-radius: 12px;
  color: var(--muted);
  background: rgba(255,255,255,0.8);
  border: 1px solid var(--line);
  font-size: 12px;
  font-weight: 800;
}
.level-dot.active { color: #fff; background: linear-gradient(135deg, var(--pink-500), var(--lavender)); }
.level-dot.done { color: var(--ink); background: var(--mint); }
.level-dot.locked { opacity: 0.38; }

.leaderboard {
  display: grid;
  gap: 8px;
  padding-left: 22px;
  margin: 12px 0 0;
  max-height: 260px;
  overflow: auto;
}
.leaderboard li {
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255, 245, 251, 0.8);
  line-height: 1.45;
}
.leaderboard small { display: block; color: var(--muted); }

.game-card { min-width: 0; }
.game-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  margin-bottom: 14px;
}
.game-toolbar h2 { margin-bottom: 4px; }
.game-toolbar p { margin-bottom: 0; color: var(--muted); }
.toolbar-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: end; }

.grid-scroller {
  height: min(74vh, 760px);
  overflow: auto;
  border-radius: 30px;
  border: 1px solid rgba(255, 255, 255, 0.82);
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.9), transparent 13rem),
    linear-gradient(135deg, rgba(255,255,255,0.86), rgba(255,232,244,0.50)),
    repeating-linear-gradient(45deg, rgba(255, 201, 227, 0.16) 0 12px, transparent 12px 24px);
  padding: 18px;
  touch-action: none;
  box-shadow: inset 0 0 0 1px rgba(255, 126, 182, 0.10), inset 0 20px 40px rgba(255,255,255,0.35);
}
.letter-grid {
  display: grid;
  grid-template-columns: repeat(var(--letter-size, 12), var(--cell));
  grid-auto-rows: var(--cell);
  gap: 2px;
  width: max-content;
  margin: 0 auto;
  padding: 12px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.46);
  box-shadow: inset 0 0 0 1px rgba(255, 126, 182, 0.12), 0 18px 40px rgba(148, 77, 132, 0.12);
  user-select: none;
}
.cell {
  width: var(--cell);
  height: var(--cell);
  display: grid;
  place-items: center;
  border-radius: 8px;
  border: 1px solid rgba(255, 126, 182, 0.10);
  background: rgba(255, 255, 255, 0.64);
  font-size: calc(var(--cell) * 0.55);
  font-weight: 900;
  color: rgba(70, 51, 71, 0.78);
  text-transform: uppercase;
  box-shadow: 0 4px 9px rgba(148, 77, 132, 0.06);
  transition: background 0.08s ease, color 0.08s ease, transform 0.08s ease, box-shadow 0.08s ease;
}
.cell:hover { background: #fff; transform: translateY(-1px); }
.cell.heart-cell {
  color: rgba(247, 93, 157, 0.56);
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 255, 255, 0.92), transparent 46%),
    linear-gradient(135deg, rgba(255, 232, 244, 0.70), rgba(241, 234, 255, 0.56));
  border-style: dashed;
  font-size: calc(var(--cell) * 0.50);
  text-transform: none;
  box-shadow: inset 0 0 0 1px rgba(255, 126, 182, 0.10), 0 3px 8px rgba(148, 77, 132, 0.04);
}
.cell.heart-cell:hover {
  background: linear-gradient(135deg, rgba(255, 232, 244, 0.95), rgba(241, 234, 255, 0.86));
}
.cell.heart-cell.selected {
  color: #fff;
  background: linear-gradient(135deg, var(--lavender), var(--pink-400));
  border-style: solid;
}
.cell.selected {
  color: #fff;
  background: linear-gradient(135deg, var(--pink-500), var(--rose));
  transform: scale(1.16);
  box-shadow: 0 7px 16px rgba(247, 93, 157, 0.35);
  border-color: rgba(255, 255, 255, 0.5);
}
.cell.solved {
  color: #357568;
  background: linear-gradient(135deg, var(--mint), #fff);
  box-shadow: inset 0 0 0 1px rgba(93, 191, 166, 0.24), 0 4px 10px rgba(93, 191, 166, 0.12);
}
.cell.pending-answer {
  color: #fff;
  background: linear-gradient(135deg, var(--violet), var(--pink-400));
  box-shadow: 0 6px 14px rgba(168, 144, 255, 0.28);
}

.grid-scroller.match-mode {
  touch-action: auto;
}
.grid-scroller.letter-mode {
  touch-action: none;
}
.match-grid {
  --match-columns: 5;
  --match-size: 20;
  display: grid;
  grid-template-columns: repeat(var(--match-columns), minmax(0, 1fr));
  gap: 8px;
  width: min(100%, 650px);
  margin: 0 auto;
  padding: 12px;
  border-radius: 24px;
  border: 2px solid rgba(255, 126, 182, 0.28);
  background:
    radial-gradient(circle at 10% 10%, rgba(255,255,255,0.94), transparent 14rem),
    linear-gradient(135deg, rgba(255, 247, 252, 0.90), rgba(241, 234, 255, 0.74));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.72), 0 18px 40px rgba(148, 77, 132, 0.12);
}
.match-card {
  aspect-ratio: 1 / 1;
  min-height: 78px;
  border: 2px solid rgba(255, 126, 182, 0.26);
  border-radius: 17px;
  padding: 7px;
  display: grid;
  place-items: center;
  text-align: center;
  background: rgba(255,255,255,0.86);
  color: var(--ink);
  box-shadow: 0 7px 15px rgba(148, 77, 132, 0.08);
  transition: transform 0.14s ease, box-shadow 0.14s ease, background 0.14s ease, border-color 0.14s ease, opacity 0.14s ease;
  overflow: hidden;
}
.match-card strong {
  display: block;
  width: 100%;
  max-width: 100%;
  line-height: 1.16;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: normal;
}
.match-card.word {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(241, 234, 255, 0.78));
}
.match-card.word strong {
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: clamp(13px, 1.9vw, 18px);
  font-weight: 950;
}
.match-card.meaning {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(255, 232, 244, 0.62));
}
.match-card.meaning strong {
  font-size: clamp(10px, 1.18vw, 13px);
  font-weight: 850;
}
.match-card:hover:not(:disabled) {
  transform: translateY(-2px) scale(1.01);
  border-color: var(--pink-400);
  box-shadow: 0 13px 28px rgba(247, 93, 157, 0.18);
}
.match-card.active {
  color: #fff;
  background: linear-gradient(135deg, var(--pink-500), var(--violet));
  border-color: rgba(255,255,255,0.72);
  box-shadow: 0 15px 34px rgba(247, 93, 157, 0.30);
}
.match-card.matched {
  opacity: 0.28;
  color: transparent;
  background: linear-gradient(135deg, var(--mint), #fff);
  transform: scale(0.94);
  pointer-events: none;
}
.match-card.matched strong { visibility: hidden; }
.match-card.wrong {
  animation: shake 0.28s ease;
  border-color: #ff6b6b;
  background: #fff0f0;
}


.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 20;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgba(73, 56, 75, 0.28);
  backdrop-filter: blur(10px);
}
.hidden { display: none !important; }
.modal-card {
  position: relative;
  width: min(480px, 100%);
  padding: 28px;
  border-radius: 34px;
  background: linear-gradient(135deg, #fff, var(--pink-100));
  text-align: center;
}
.modal-sparkle {
  width: 54px;
  height: 54px;
  margin: -4px auto 12px;
  display: grid;
  place-items: center;
  color: #fff;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--pink-500), var(--lavender));
  font-size: 26px;
}
.modal-card h2 { font-size: 42px; letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: 4px; }
.modal-card p { color: var(--muted); }
.meaning-options { display: grid; gap: 10px; margin-top: 18px; }
.meaning-option {
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: #fff;
  color: var(--ink);
  font-weight: 800;
}
.meaning-option:hover { border-color: var(--pink-400); background: var(--pink-50); }
.meaning-option.wrong {
  animation: shake 0.28s ease;
  border-color: #ff6b6b;
  background: #fff0f0;
}
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-5px); }
  75% { transform: translateX(5px); }
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 26px;
  z-index: 30;
  transform: translateX(-50%);
  color: #fff;
  background: rgba(73, 56, 75, 0.9);
  border-radius: 999px;
  padding: 12px 18px;
  box-shadow: var(--shadow);
  font-weight: 800;
}

@media (max-width: 1120px) {
  .dashboard { grid-template-columns: repeat(2, 1fr); }
  .main-layout { grid-template-columns: 1fr; }
  .side-panel { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 980px) {
  .match-grid { width: min(100%, 610px); }
}
@media (max-width: 760px) {
  .hero-card, .game-toolbar { flex-direction: column; align-items: stretch; }
  .dashboard, .side-panel { grid-template-columns: 1fr; }
  .app-shell { width: min(100% - 18px, 1480px); padding-top: 10px; }
  .hero-card, .panel-card, .game-card { border-radius: 24px; padding: 16px; }
  .stat-card strong { font-size: 28px; }
  .grid-scroller { height: 70vh; padding: 10px; }
  .match-grid { gap: 6px; padding: 8px; }
  .match-card { min-height: 58px; border-radius: 13px; padding: 5px; }
  .match-card.word strong { font-size: clamp(10px, 2.9vw, 14px); }
  .match-card.meaning strong { font-size: clamp(9px, 2.45vw, 11px); }
  .mode-switch { grid-template-columns: 1fr; border-radius: 22px; }
}


/* 单屏布局优化：尽量让标题、状态、控制区、关卡、排行和游戏区全部留在一个窗口内 */
html, body {
  width: 100%;
  height: 100%;
}

body {
  height: 100vh;
  min-height: 100vh;
  overflow: hidden;
}

.bg-decor {
  opacity: 0.46;
  font-size: 5.8rem;
}
.decor-1 { top: 1.2rem; right: 4vw; }
.decor-2 { bottom: 2vh; left: 2vw; }
.decor-3 { bottom: 8vh; right: 6vw; font-size: 4rem; }

.app-shell {
  width: min(1540px, calc(100% - 18px));
  height: 100vh;
  padding: 8px 0;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 8px;
}

.hero-card {
  min-height: 0;
  padding: 10px 14px;
  border-radius: 22px;
  gap: 12px;
}
.hero-card::before,
.hero-card::after { transform: scale(0.62); opacity: 0.55; }
.hero-card .eyebrow {
  margin-bottom: 3px;
  font-size: 10px;
}
h1 {
  margin-bottom: 4px;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 0.98;
}
h2 {
  font-size: 15px;
  margin-bottom: 6px;
}
.hero-copy {
  max-width: 720px;
  font-size: 12px;
  line-height: 1.25;
}

.profile-card {
  width: min(410px, 42vw);
  padding: 8px;
  border-radius: 18px;
  display: grid;
  grid-template-columns: 0.95fr 1fr;
  gap: 6px 8px;
  align-items: center;
}
.profile-card label {
  margin: 0;
  font-size: 11px;
}
.profile-card input {
  padding: 7px 10px;
  border-radius: 12px;
  min-width: 0;
}
.level-pill {
  margin: 0;
  padding: 7px 9px;
  font-size: 12px;
}
.mode-switch {
  grid-column: 1 / -1;
  margin-top: 0;
  padding: 4px;
  gap: 5px;
}
.mode-btn {
  padding: 7px 9px;
  font-size: 12px;
}

.dashboard {
  margin: 0;
  padding: 6px;
  gap: 8px;
  border-radius: 18px;
}
.stat-card {
  min-height: 0;
  padding: 7px 10px;
  border-radius: 16px;
}
.stat-card span,
.stat-card small {
  font-size: 10px;
  line-height: 1.1;
}
.stat-card strong {
  margin: 2px 0;
  font-size: clamp(19px, 2.2vw, 25px);
}

.main-layout {
  min-height: 0;
  height: 100%;
  grid-template-columns: minmax(380px, 430px) minmax(0, 1fr);
  gap: 8px;
  padding: 8px;
  border-radius: 20px;
  overflow: hidden;
}
.side-panel {
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: minmax(0, auto) auto minmax(0, auto);
  gap: 8px;
  overflow: hidden;
}
.side-panel .panel-card:nth-child(1),
.side-panel .panel-card:nth-child(4) {
  grid-column: 1 / -1;
}
.panel-card,
.game-card {
  min-height: 0;
  border-radius: 18px;
  padding: 8px;
  overflow: hidden;
}
.panel-title-row {
  min-height: 20px;
}
.panel-title-row h2 {
  font-size: 14px;
  line-height: 1.1;
}
.panel-title-row span {
  font-size: 12px;
}
.hint {
  margin-bottom: 5px;
  font-size: 10.5px;
  line-height: 1.22;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.target-list {
  gap: 3px;
  max-height: none;
  overflow: hidden;
  padding-right: 0;
}
.target-item {
  min-height: 22px;
  padding: 3px 6px;
  border-radius: 10px;
  gap: 6px;
  grid-template-columns: minmax(0, 1fr) auto;
}
.target-item .word {
  display: inline;
  margin-right: 5px;
  font-size: 11px;
  line-height: 1;
}
.target-item .tag {
  display: inline;
  font-size: 9px;
  line-height: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.target-item > div:first-child {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.controls {
  gap: 6px;
}
.control-row {
  gap: 5px;
}
.primary-btn,
.ghost-btn,
.mini-btn {
  padding: 7px 9px;
  font-size: 12px;
}
.range-label,
.profile-card label {
  font-size: 10.5px;
}
.range-label {
  margin-bottom: 2px;
}
input[type="range"] {
  height: 18px;
}

.level-map {
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 3px;
}
.level-dot {
  min-width: 0;
  border-radius: 7px;
  font-size: 9px;
}

.leaderboard {
  margin: 5px 0 0;
  padding-left: 0;
  list-style-position: inside;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
  max-height: none;
  overflow: hidden;
}
.leaderboard li {
  padding: 4px 6px;
  border-radius: 10px;
  font-size: 10px;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.leaderboard small {
  display: inline;
  margin-left: 4px;
  font-size: 9px;
}

.game-card {
  display: flex;
  flex-direction: column;
}
.game-toolbar {
  flex: 0 0 auto;
  gap: 8px;
  margin-bottom: 8px;
}
.game-toolbar h2 {
  margin-bottom: 2px;
  font-size: 16px;
}
.game-toolbar p {
  font-size: 12px;
  line-height: 1.2;
}
.toolbar-actions {
  gap: 6px;
}

.grid-scroller {
  flex: 1 1 auto;
  min-height: 0;
  height: auto;
  overflow: hidden;
  display: grid;
  place-items: center;
  border-radius: 18px;
  padding: 8px;
}
.letter-grid {
  padding: 7px;
  border-radius: 16px;
}
.cell {
  border-radius: 7px;
}

.match-grid {
  grid-template-columns: repeat(var(--match-columns), minmax(66px, 78px));
  gap: 6px;
  padding: 8px;
  border-radius: 18px;
  width: max-content;
}
.match-card,
.matrix-cell,
.matrix-corner {
  min-height: 66px;
  border-radius: 12px;
  padding: 5px;
}
.match-card.random-card {
  width: 78px;
  min-height: 78px;
}
.match-card span,
.matrix-cell span {
  font-size: 9px;
}
.match-card strong,
.matrix-cell strong {
  font-size: 10.5px;
  line-height: 1.16;
}
.match-card.word strong,
.matrix-side strong,
.match-card.random-card.word strong {
  font-size: 11px;
}
.match-card.random-card.meaning strong {
  font-size: 9.8px;
  line-height: 1.18;
  max-height: 5.9em;
}

.toast {
  bottom: 10px;
  padding: 8px 12px;
  font-size: 12px;
}

.modal-card {
  padding: 18px;
  border-radius: 24px;
}
.modal-card h2 {
  font-size: 32px;
}
.meaning-options {
  gap: 8px;
  margin-top: 12px;
}
.meaning-option {
  padding: 10px 12px;
  border-radius: 16px;
}

@media (max-height: 740px) {
  .hero-copy { display: none; }
  .hero-card .eyebrow { display: none; }
  h1 { font-size: clamp(22px, 2.7vw, 31px); }
  .hero-card { padding: 8px 12px; }
  .stat-card small { display: none; }
  .target-item { min-height: 20px; padding-top: 2px; padding-bottom: 2px; }
  .hint { -webkit-line-clamp: 1; }
  .match-card.random-card { width: 72px; min-height: 72px; }
  .match-grid { grid-template-columns: repeat(var(--match-columns), minmax(62px, 72px)); }
}

@media (max-width: 1180px) {
  .main-layout { grid-template-columns: 360px minmax(0, 1fr); }
  .side-panel { grid-template-columns: 1fr; }
  .side-panel .panel-card:nth-child(1),
  .side-panel .panel-card:nth-child(4) { grid-column: auto; }
  .target-item .tag { display: none; }
  .leaderboard { grid-template-columns: 1fr; }
}

@media (max-width: 860px) {
  body { overflow: auto; }
  .app-shell {
    height: auto;
    min-height: 100vh;
  }
  .hero-card,
  .game-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .profile-card { width: 100%; }
  .dashboard { grid-template-columns: repeat(2, 1fr); }
  .main-layout {
    height: auto;
    grid-template-columns: 1fr;
    overflow: visible;
  }
  .side-panel { height: auto; overflow: visible; }
  .grid-scroller { min-height: 420px; }
}

/* 本次布局优化：左侧更窄、游戏区更大、本关单词两列展示、窗口边距进一步缩小 */
.app-shell {
  width: min(1620px, calc(100% - 8px));
  padding: 4px 0;
  gap: 5px;
}

.hero-card {
  padding: 7px 10px;
  border-radius: 18px;
}
.dashboard {
  padding: 4px;
  gap: 5px;
  border-radius: 15px;
}
.stat-card {
  padding: 5px 8px;
  border-radius: 13px;
}

.main-layout {
  grid-template-columns: minmax(300px, 340px) minmax(0, 1fr);
  gap: 5px;
  padding: 5px;
  border-radius: 16px;
}
.side-panel {
  gap: 5px;
}
.panel-card,
.game-card {
  padding: 6px;
  border-radius: 15px;
}

/* 本关单词：两列显示，节省左侧高度 */
.target-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
}
.target-item {
  min-width: 0;
  min-height: 24px;
  padding: 4px 5px;
  border-radius: 9px;
  grid-template-columns: minmax(0, 1fr);
}
.target-item .word {
  display: block;
  margin-right: 0;
  font-size: 10.5px;
  line-height: 1.05;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.target-item .tag {
  display: block;
  margin-top: 1px;
  font-size: 8px;
  line-height: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.target-item > div:first-child {
  min-width: 0;
}

.game-toolbar {
  margin-bottom: 5px;
}
.grid-scroller {
  padding: 4px;
  border-radius: 15px;
}
.letter-grid {
  padding: 5px;
  border-radius: 13px;
}
.cell {
  border-radius: 6px;
}

/* 初级模式 4×5：在不滚动的前提下稍微放大 */
.match-grid {
  gap: 7px;
  padding: 7px;
  border-radius: 16px;
  grid-template-columns: repeat(var(--match-columns), minmax(76px, 88px));
}
.match-card.random-card {
  width: 88px;
  min-height: 88px;
}
.match-card,
.matrix-cell,
.matrix-corner {
  border-radius: 13px;
}
.match-card.random-card.word strong {
  font-size: 12px;
}
.match-card.random-card.meaning strong {
  font-size: 10px;
  line-height: 1.18;
  max-height: 6em;
}

@media (max-height: 740px) {
  .app-shell { padding: 3px 0; gap: 4px; }
  .main-layout { gap: 4px; padding: 4px; }
  .panel-card, .game-card { padding: 5px; }
  .match-grid { grid-template-columns: repeat(var(--match-columns), minmax(70px, 80px)); gap: 5px; padding: 6px; }
  .match-card.random-card { width: 80px; min-height: 80px; }
  .target-list { gap: 3px; }
  .target-item { min-height: 21px; padding: 3px 4px; }
  .target-item .word { font-size: 9.8px; }
  .target-item .tag { display: none; }
}

@media (max-width: 1180px) {
  .main-layout { grid-template-columns: 310px minmax(0, 1fr); }
  .target-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 860px) {
  .app-shell { width: min(100% - 8px, 1620px); }
  .target-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .match-grid { grid-template-columns: repeat(var(--match-columns), minmax(58px, 1fr)); width: min(100%, 520px); }
  .match-card.random-card { width: auto; min-height: 68px; }
}


/* 三列控制区 + 更大游戏正方形布局优化 */
:root {
  --panel-height: clamp(134px, 17.5vh, 190px);
  --match-card-size: 118px;
}

body {
  overflow: hidden;
}

.app-shell {
  width: min(1760px, calc(100% - 6px));
  height: 100vh;
  min-height: 620px;
  padding: 3px 0;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 4px;
}

.hero-card {
  padding: 6px 10px;
  min-height: 0;
}

.hero-copy {
  font-size: 11px;
  line-height: 1.18;
  max-width: 860px;
}

.profile-card {
  width: min(430px, 36vw);
}

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

.main-layout {
  height: 100%;
  min-height: 0;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: var(--panel-height) minmax(0, 1fr);
  gap: 4px;
  padding: 4px;
  overflow: hidden;
}

.side-panel {
  height: var(--panel-height);
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(220px, 1.08fr) minmax(250px, 1.18fr) minmax(210px, 0.94fr);
  grid-template-rows: 1fr;
  gap: 5px;
  overflow: hidden;
}

.side-panel .panel-card:nth-child(1) {
  grid-column: 1;
  grid-row: 1;
}

.side-panel .panel-card:nth-child(2) {
  grid-column: 2;
  grid-row: 1;
}

.side-panel .panel-card:nth-child(3) {
  grid-column: 2;
  grid-row: 1;
  align-self: end;
  height: calc((var(--panel-height) - 14px) * 0.55);
  margin-top: calc((var(--panel-height) - 14px) * 0.45 + 8px);
}

.side-panel .panel-card:nth-child(4) {
  grid-column: 3;
  grid-row: 1;
}

.panel-card,
.game-card {
  padding: 6px;
  border-radius: 14px;
}

.side-panel .panel-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.side-panel .panel-card:nth-child(2) {
  height: calc((var(--panel-height) - 14px) * 0.45);
  min-height: 70px;
}

.side-panel .panel-card:nth-child(2) h2,
.side-panel .panel-card:nth-child(3) .panel-title-row,
.side-panel .panel-card:nth-child(4) .panel-title-row,
.side-panel .panel-card:nth-child(1) .panel-title-row {
  flex: 0 0 auto;
}

.hint {
  display: none;
}

.target-list {
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-rows: minmax(0, 1fr);
  gap: 3px;
}

.target-item {
  min-height: 0;
  padding: 3px 6px;
  border-radius: 8px;
  display: grid;
  align-content: center;
}

.target-item .word {
  font-size: clamp(10px, 0.78vw, 12px);
  line-height: 1.05;
}

.target-item .tag {
  display: block;
  font-size: clamp(8px, 0.62vw, 10px);
  line-height: 1.05;
}

.controls {
  gap: 4px;
}

.control-row {
  gap: 5px;
}

.primary-btn,
.ghost-btn,
.mini-btn {
  padding: 6px 9px;
  font-size: clamp(11px, 0.82vw, 13px);
}

.range-label {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  font-size: clamp(10px, 0.75vw, 12px);
}

input[type="range"] {
  height: 16px;
}

.level-map {
  flex: 1 1 auto;
  min-height: 0;
  grid-template-columns: repeat(15, minmax(0, 1fr));
  gap: 3px;
  align-content: stretch;
}

.level-dot {
  aspect-ratio: auto;
  min-height: 0;
  height: 100%;
  border-radius: 6px;
  font-size: clamp(8px, 0.6vw, 10px);
}

.leaderboard {
  flex: 1 1 auto;
  min-height: 0;
  margin: 5px 0 0;
  padding-left: 0;
  list-style-position: inside;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-rows: minmax(0, 1fr);
  gap: 3px;
}

.leaderboard li {
  min-height: 0;
  padding: 4px 7px;
  border-radius: 8px;
  font-size: clamp(9px, 0.72vw, 11px);
  line-height: 1.12;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.leaderboard small {
  display: inline;
  margin-left: 4px;
  font-size: clamp(8px, 0.62vw, 9px);
}

.game-card {
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.game-toolbar {
  min-height: 0;
  margin-bottom: 4px;
  gap: 8px;
}

.game-toolbar h2 {
  font-size: clamp(15px, 1.15vw, 19px);
}

.game-toolbar p {
  font-size: clamp(11px, 0.82vw, 13px);
}

.toolbar-actions {
  gap: 5px;
}

.grid-scroller {
  flex: 1 1 auto;
  min-height: 0;
  height: auto;
  padding: 4px;
  border-radius: 14px;
  overflow: hidden;
  display: grid;
  place-items: center;
}

.letter-grid {
  max-width: 100%;
  max-height: 100%;
}

.match-grid {
  width: max-content;
  max-width: 100%;
  grid-template-columns: repeat(var(--match-columns), var(--match-card-size));
  grid-auto-rows: var(--match-card-size);
  gap: 10px;
  padding: 8px;
  border-radius: 18px;
}

.match-card.random-card,
.match-card,
.matrix-cell,
.matrix-corner {
  width: var(--match-card-size);
  min-height: var(--match-card-size);
  height: var(--match-card-size);
  border-radius: clamp(12px, calc(var(--match-card-size) * 0.12), 20px);
  padding: clamp(5px, calc(var(--match-card-size) * 0.08), 11px);
}

.match-card.random-card.word strong,
.match-card.word strong {
  font-size: clamp(13px, calc(var(--match-card-size) * 0.16), 21px);
  line-height: 1.08;
}

.match-card.random-card.meaning strong,
.match-card.meaning strong {
  font-size: clamp(10px, calc(var(--match-card-size) * 0.105), 15px);
  line-height: 1.18;
  max-height: calc(var(--match-card-size) - 16px);
}

@media (max-height: 760px) {
  :root { --panel-height: clamp(112px, 16vh, 150px); }
  .hero-copy { display: none; }
  .dashboard { display: none; }
  .app-shell { grid-template-rows: auto minmax(0, 1fr); }
  .main-layout { grid-row: 2; }
  .profile-card { width: min(430px, 42vw); }
  .target-item .tag { display: none; }
  .level-map { grid-template-columns: repeat(20, minmax(0, 1fr)); }
}

@media (max-width: 1120px) {
  .app-shell {
    height: auto;
    min-height: 100vh;
    overflow: visible;
  }
  body { overflow: auto; }
  .main-layout {
    grid-template-rows: auto minmax(480px, 1fr);
    overflow: visible;
  }
  .side-panel {
    height: auto;
    grid-template-columns: 1fr;
    grid-template-rows: none;
    overflow: visible;
  }
  .side-panel .panel-card:nth-child(n) {
    grid-column: auto;
    grid-row: auto;
    height: auto;
    margin-top: 0;
  }
  .target-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: auto;
  }
  .leaderboard {
    grid-auto-rows: auto;
  }
  .grid-scroller {
    min-height: 480px;
  }
}

@media (max-width: 720px) {
  .hero-card,
  .game-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .profile-card { width: 100%; }
  .dashboard { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .match-grid { gap: 6px; }
}

/* 四列并排布局修正：本关单词 | 关卡玩法地图 | 游戏界面 | 排行榜 */
:root {
  --compact-gap: clamp(3px, 0.35vw, 7px);
  --side-radius: clamp(10px, 0.9vw, 16px);
}

html,
body {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

body {
  min-height: 100dvh;
}

.app-shell {
  width: calc(100vw - 4px);
  height: 100dvh;
  min-height: 560px;
  padding: 2px;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: var(--compact-gap);
  overflow: hidden;
}

.hero-card {
  padding: clamp(4px, 0.45vw, 8px) clamp(7px, 0.7vw, 12px);
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  align-items: center;
  gap: clamp(8px, 1vw, 16px);
}

.hero-card h1 {
  margin: 1px 0 2px;
  font-size: clamp(18px, 1.8vw, 28px);
  line-height: 1;
}

.eyebrow {
  margin-bottom: 1px;
  font-size: clamp(8px, 0.7vw, 11px);
}

.hero-copy {
  max-width: none;
  font-size: clamp(9px, 0.72vw, 12px);
  line-height: 1.15;
  margin: 0;
}

.profile-card {
  width: 100%;
  padding: clamp(5px, 0.55vw, 9px);
  gap: 4px;
  border-radius: var(--side-radius);
}

.profile-card label {
  font-size: clamp(9px, 0.7vw, 11px);
}

.profile-card input {
  height: clamp(26px, 2.2vw, 34px);
  padding: 4px 8px;
  font-size: clamp(11px, 0.82vw, 13px);
}

.level-pill,
.mode-switch {
  gap: 4px;
}

.mode-btn {
  padding: clamp(4px, 0.45vw, 7px) clamp(6px, 0.7vw, 10px);
  font-size: clamp(10px, 0.75vw, 12px);
}

.dashboard {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--compact-gap);
}

.stat-card {
  min-height: clamp(38px, 5.1vh, 58px);
  padding: clamp(4px, 0.45vw, 8px) clamp(7px, 0.7vw, 12px);
  border-radius: var(--side-radius);
}

.stat-card span,
.stat-card small {
  font-size: clamp(8px, 0.65vw, 11px);
  line-height: 1.08;
}

.stat-card strong {
  font-size: clamp(15px, 1.5vw, 24px);
  line-height: 1;
}

.main-layout {
  min-height: 0;
  height: 100%;
  padding: var(--compact-gap);
  overflow: hidden;
  display: grid;
  grid-template-columns:
    minmax(128px, clamp(150px, 12vw, 220px))
    minmax(170px, clamp(205px, 16vw, 285px))
    minmax(380px, 1fr)
    minmax(150px, clamp(180px, 14vw, 250px));
  grid-template-rows: minmax(100px, 0.42fr) minmax(0, 1fr);
  gap: var(--compact-gap);
  align-items: stretch;
}

.side-panel {
  display: contents !important;
  height: auto !important;
  min-height: 0 !important;
  overflow: visible !important;
}

.side-panel .panel-card:nth-child(1) {
  grid-column: 1 !important;
  grid-row: 1 / 3 !important;
}

.side-panel .panel-card:nth-child(2) {
  grid-column: 2 !important;
  grid-row: 1 !important;
}

.side-panel .panel-card:nth-child(3) {
  grid-column: 2 !important;
  grid-row: 2 !important;
}

.side-panel .panel-card:nth-child(4) {
  grid-column: 4 !important;
  grid-row: 1 / 3 !important;
}

.game-card {
  grid-column: 3 !important;
  grid-row: 1 / 3 !important;
  min-width: 0;
  min-height: 0;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.side-panel .panel-card,
.panel-card,
.game-card {
  min-width: 0;
  min-height: 0;
  padding: clamp(5px, 0.55vw, 9px);
  border-radius: var(--side-radius);
  overflow: hidden;
}

.side-panel .panel-card:nth-child(n) {
  height: auto !important;
  margin-top: 0 !important;
  align-self: stretch !important;
  display: flex;
  flex-direction: column;
}

.panel-title-row,
.game-toolbar {
  min-height: 0;
  margin-bottom: clamp(3px, 0.35vw, 6px);
  gap: 5px;
}

.panel-title-row h2,
.controls h2,
.game-toolbar h2 {
  font-size: clamp(12px, 1vw, 17px);
  line-height: 1.05;
}

.game-toolbar {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 2px;
}

.game-toolbar p {
  font-size: clamp(10px, 0.78vw, 13px);
  line-height: 1.12;
}

.toolbar-actions,
.control-row {
  gap: 4px;
}

.primary-btn,
.ghost-btn,
.mini-btn {
  min-height: 0;
  padding: clamp(4px, 0.5vw, 8px) clamp(6px, 0.65vw, 10px);
  font-size: clamp(10px, 0.76vw, 12px);
  line-height: 1.05;
}

.hint {
  display: none !important;
}

.target-list {
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr !important;
  grid-template-rows: repeat(10, minmax(0, 1fr));
  gap: 3px;
}

.target-item {
  min-height: 0;
  padding: clamp(3px, 0.4vw, 6px);
  border-radius: clamp(7px, 0.65vw, 11px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 3px;
}

.target-item .word {
  font-size: clamp(10px, 0.82vw, 13px);
  line-height: 1.02;
}

.target-item .tag {
  font-size: clamp(8px, 0.62vw, 10px);
  line-height: 1.02;
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.controls {
  gap: clamp(3px, 0.4vw, 6px);
}

.range-label {
  font-size: clamp(9px, 0.68vw, 11px);
  line-height: 1;
}

input[type="range"] {
  height: 14px;
}

.level-map {
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  grid-auto-rows: minmax(0, 1fr);
  gap: 3px;
  align-content: stretch;
}

.level-dot {
  height: auto;
  min-height: 0;
  aspect-ratio: auto;
  border-radius: clamp(5px, 0.45vw, 8px);
  font-size: clamp(8px, 0.62vw, 10px);
  padding: 0;
}

.leaderboard {
  flex: 1 1 auto;
  min-height: 0;
  margin: 3px 0 0;
  padding-left: 0;
  list-style-position: inside;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-rows: minmax(0, 1fr);
  gap: 3px;
}

.leaderboard li {
  min-height: 0;
  padding: clamp(4px, 0.45vw, 7px);
  border-radius: clamp(7px, 0.65vw, 11px);
  font-size: clamp(9px, 0.72vw, 11px);
  line-height: 1.1;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.leaderboard small {
  display: block;
  margin-left: 0;
  font-size: clamp(8px, 0.62vw, 9px);
  opacity: 0.72;
}

.grid-scroller {
  flex: 1 1 auto;
  min-height: 0;
  height: auto;
  padding: clamp(3px, 0.35vw, 7px);
  border-radius: var(--side-radius);
  overflow: hidden;
  display: grid;
  place-items: center;
}

.letter-grid {
  max-width: 100%;
  max-height: 100%;
  gap: 2px;
}

.cell {
  min-width: 0;
  min-height: 0;
}

.match-grid {
  width: max-content;
  max-width: 100%;
  max-height: 100%;
  grid-template-columns: repeat(var(--match-columns), var(--match-card-size));
  grid-auto-rows: var(--match-card-size);
  gap: 8px;
  padding: 7px;
  border-radius: clamp(12px, 1vw, 18px);
  overflow: hidden;
}

.match-card.random-card,
.match-card {
  width: var(--match-card-size);
  min-width: 0;
  min-height: var(--match-card-size);
  height: var(--match-card-size);
  padding: clamp(5px, calc(var(--match-card-size) * 0.07), 12px);
  border-radius: clamp(11px, calc(var(--match-card-size) * 0.12), 22px);
}

.match-card.random-card.word strong,
.match-card.word strong {
  font-size: clamp(14px, calc(var(--match-card-size) * 0.17), 25px);
  line-height: 1.05;
}

.match-card.random-card.meaning strong,
.match-card.meaning strong {
  font-size: clamp(11px, calc(var(--match-card-size) * 0.105), 17px);
  line-height: 1.16;
  max-height: calc(var(--match-card-size) - 12px);
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-height: 720px) {
  .hero-copy { display: none; }
  .stat-card { min-height: 34px; }
  .target-item .tag { display: none; }
  .dashboard { gap: 3px; }
  .main-layout { gap: 3px; padding: 3px; }
  .panel-card, .game-card { padding: 5px; }
  .game-toolbar p { display: none; }
}

@media (max-height: 635px) {
  .dashboard { display: none; }
  .app-shell { grid-template-rows: auto minmax(0, 1fr); }
  .main-layout { grid-row: 2; }
}

@media (max-width: 1180px) {
  .hero-card {
    grid-template-columns: minmax(0, 1fr) minmax(245px, 330px);
  }
  .main-layout {
    grid-template-columns:
      minmax(108px, 0.62fr)
      minmax(140px, 0.82fr)
      minmax(300px, 1.55fr)
      minmax(125px, 0.72fr);
  }
  .profile-card { width: 100%; }
  .target-item .tag { display: none; }
  .level-map { grid-template-columns: repeat(5, minmax(0, 1fr)); }
}

@media (max-width: 900px) {
  .app-shell { min-width: 820px; }
  body { overflow: auto hidden; }
}

/* 2026-05 布局精修：最终覆盖，确保“本关单词”两列显示，并提升游戏区占比 */
.main-layout {
  grid-template-columns:
    minmax(240px, clamp(260px, 20vw, 350px))
    minmax(145px, clamp(170px, 12vw, 230px))
    minmax(420px, 1fr)
    minmax(145px, clamp(165px, 12vw, 220px)) !important;
  grid-template-rows: minmax(96px, 0.38fr) minmax(0, 1fr) !important;
  gap: clamp(4px, 0.35vw, 7px) !important;
  padding: clamp(4px, 0.35vw, 7px) !important;
}

.side-panel .panel-card:nth-child(1) {
  grid-column: 1 !important;
  grid-row: 1 / 3 !important;
}

.side-panel .panel-card:nth-child(2) {
  grid-column: 2 !important;
  grid-row: 1 !important;
}

.side-panel .panel-card:nth-child(3) {
  grid-column: 2 !important;
  grid-row: 2 !important;
}

.game-card {
  grid-column: 3 !important;
  grid-row: 1 / 3 !important;
}

.side-panel .panel-card:nth-child(4) {
  grid-column: 4 !important;
  grid-row: 1 / 3 !important;
}

/* 本关单词固定两列：10 个词时呈 2 × 5，减少左侧纵向拥挤 */
.target-list {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  grid-template-rows: repeat(5, minmax(0, 1fr)) !important;
  grid-auto-flow: row !important;
  gap: clamp(4px, 0.4vw, 7px) !important;
  overflow: hidden !important;
}

.target-item {
  min-width: 0 !important;
  min-height: 0 !important;
  padding: clamp(4px, 0.45vw, 7px) !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 3px !important;
}

.target-item .word,
.target-item .tag {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.target-item .word {
  font-size: clamp(11px, 0.85vw, 14px) !important;
  line-height: 1.05 !important;
}

.target-item .tag {
  font-size: clamp(8px, 0.62vw, 10px) !important;
  line-height: 1.05 !important;
}

.panel-card,
.game-card {
  box-shadow: 0 10px 24px rgba(91, 74, 112, 0.11);
}

.grid-scroller {
  padding: clamp(4px, 0.35vw, 8px) !important;
}

@media (max-width: 1180px) {
  .app-shell { min-width: 980px; }
  .main-layout {
    grid-template-columns:
      minmax(220px, 0.95fr)
      minmax(140px, 0.62fr)
      minmax(360px, 1.65fr)
      minmax(135px, 0.58fr) !important;
  }
  .target-list {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: repeat(5, minmax(0, 1fr)) !important;
  }
  .target-item .tag { display: block !important; }
}

@media (max-height: 700px) {
  .target-list { gap: 3px !important; }
  .target-item { padding: 3px 5px !important; }
  .target-item .tag { display: none !important; }
}

/* 2026-05 底部状态栏调整：当前关卡、计时、得分、经验固定放在最底下 */
.app-shell {
  grid-template-rows: auto minmax(0, 1fr) auto !important;
  gap: clamp(4px, 0.45vw, 8px) !important;
}

.main-layout {
  grid-row: 2 !important;
  min-height: 0 !important;
}

.dashboard {
  grid-row: 3 !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  margin: 0 !important;
  padding: clamp(4px, 0.45vw, 7px) !important;
  gap: clamp(4px, 0.45vw, 7px) !important;
  border-radius: clamp(14px, 1.2vw, 20px) !important;
}

.stat-card {
  min-height: 0 !important;
  padding: clamp(5px, 0.55vw, 9px) clamp(8px, 0.75vw, 12px) !important;
  border-radius: clamp(12px, 1vw, 17px) !important;
}

.stat-card span,
.stat-card small {
  font-size: clamp(9px, 0.68vw, 11px) !important;
  line-height: 1.08 !important;
}

.stat-card strong {
  margin: 1px 0 !important;
  font-size: clamp(19px, 1.75vw, 27px) !important;
  line-height: 1 !important;
}

/* 初级模式支持任意第一张卡片起手：高亮不再限定英文卡 */
.match-card.active {
  outline: 3px solid rgba(246, 93, 157, 0.26);
}

@media (max-height: 720px) {
  .dashboard {
    display: grid !important;
    padding: 3px !important;
    gap: 3px !important;
  }
  .stat-card {
    padding: 4px 7px !important;
  }
  .stat-card small {
    display: block !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

@media (max-height: 635px) {
  .dashboard {
    display: grid !important;
  }
  .app-shell {
    grid-template-rows: auto minmax(0, 1fr) auto !important;
  }
  .main-layout {
    grid-row: 2 !important;
  }
}

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


/* 2026-05 header typography refresh and lowercase word display */
.app-hero {
  grid-template-columns: minmax(0, 1.25fr) minmax(260px, 390px) !important;
  align-items: stretch !important;
  padding: clamp(9px, 0.85vw, 15px) clamp(12px, 1.1vw, 20px) !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(255, 232, 244, 0.78)),
    radial-gradient(circle at 10% 10%, rgba(255, 172, 210, 0.34), transparent 11rem),
    radial-gradient(circle at 90% 24%, rgba(201, 182, 255, 0.28), transparent 10rem) !important;
}

.hero-content {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-template-rows: auto auto;
  align-items: center;
  gap: clamp(5px, 0.55vw, 9px) clamp(12px, 1vw, 18px);
  min-width: 0;
}

.game-kicker {
  grid-column: 1;
  grid-row: 1 / span 2;
  align-self: stretch;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 !important;
  padding: 7px 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(255, 126, 182, 0.22);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.64);
  color: var(--pink-500);
  letter-spacing: 0.14em;
}

.hero-content h1 {
  grid-column: 2;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.2em 0.38em;
  margin: 0 !important;
  font-size: clamp(24px, 2.4vw, 42px) !important;
  line-height: 0.95 !important;
  letter-spacing: -0.045em !important;
}

.hero-content h1 span:first-child {
  color: var(--ink);
}

.hero-content h1 span:last-child {
  color: var(--pink-500);
  text-shadow: 0 8px 22px rgba(246, 93, 157, 0.18);
}

.hero-description {
  grid-column: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(0, 1fr);
  gap: clamp(5px, 0.55vw, 9px);
  max-width: 100% !important;
  margin: 0 !important;
  color: var(--muted);
  font-size: clamp(10px, 0.78vw, 13px) !important;
  line-height: 1.35 !important;
}

.hero-description span {
  min-width: 0;
  padding: clamp(6px, 0.6vw, 10px) clamp(8px, 0.75vw, 12px);
  border-radius: clamp(12px, 1vw, 18px);
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(255, 126, 182, 0.16);
  box-shadow: 0 8px 18px rgba(148, 77, 132, 0.06);
}

.target-item .word,
.match-card.word strong,
.cell,
.modal-card h2 {
  text-transform: lowercase !important;
}

.match-card.word strong {
  letter-spacing: 0.02em !important;
}

@media (max-width: 980px) {
  .app-hero {
    grid-template-columns: 1fr !important;
  }
  .hero-content {
    grid-template-columns: 1fr;
  }
  .game-kicker {
    grid-column: 1;
    grid-row: auto;
    writing-mode: horizontal-tb;
    transform: none;
    justify-self: start;
  }
  .hero-content h1,
  .hero-description {
    grid-column: 1;
  }
  .hero-description {
    grid-template-columns: 1fr;
  }
}

@media (max-height: 720px) {
  .hero-description span {
    padding: 5px 8px;
  }
}

/* 2026-05 keep English title horizontal */
.hero-content {
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-rows: auto auto auto !important;
}

.game-kicker {
  grid-column: 1 !important;
  grid-row: auto !important;
  align-self: auto !important;
  justify-self: start !important;
  writing-mode: horizontal-tb !important;
  transform: none !important;
  display: inline-flex !important;
  width: fit-content;
  max-width: 100%;
  padding: 6px 12px !important;
  white-space: nowrap;
  line-height: 1.1;
  letter-spacing: 0.08em !important;
}

.hero-content h1,
.hero-description {
  grid-column: 1 !important;
}

@media (max-width: 520px) {
  .game-kicker {
    white-space: normal;
  }
}


/* 2026-05 三列最终布局：左列单词+玩法，中间游戏窗口，右列地图+排行 */
.main-layout {
  grid-template-columns:
    minmax(260px, clamp(280px, 23vw, 390px))
    minmax(430px, 1fr)
    minmax(250px, clamp(270px, 22vw, 360px)) !important;
  grid-template-rows: minmax(240px, 1.15fr) minmax(150px, 0.85fr) !important;
  gap: clamp(5px, 0.5vw, 10px) !important;
  align-items: stretch !important;
}

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

.side-panel .panel-card:nth-child(1) {
  grid-column: 1 !important;
  grid-row: 1 !important;
}

.side-panel .panel-card:nth-child(2) {
  grid-column: 1 !important;
  grid-row: 2 !important;
}

.game-card {
  grid-column: 2 !important;
  grid-row: 1 / 3 !important;
}

.side-panel .panel-card:nth-child(3) {
  grid-column: 3 !important;
  grid-row: 1 !important;
}

.side-panel .panel-card:nth-child(4) {
  grid-column: 3 !important;
  grid-row: 2 !important;
}

.side-panel .panel-card:nth-child(n) {
  height: auto !important;
  margin-top: 0 !important;
  align-self: stretch !important;
}

.game-toolbar {
  justify-content: center !important;
  text-align: center;
}

.game-toolbar > div:first-child {
  width: 100%;
}

.target-list {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  grid-template-rows: repeat(5, minmax(0, 1fr)) !important;
}

.controls {
  justify-content: start;
}

.level-map {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  grid-auto-rows: minmax(0, 1fr) !important;
}

.leaderboard {
  grid-template-columns: 1fr !important;
  grid-template-rows: repeat(10, minmax(0, 1fr)) !important;
  grid-auto-rows: minmax(0, 1fr) !important;
}

@media (max-width: 1180px) {
  .app-shell { min-width: 980px; }
  .main-layout {
    grid-template-columns:
      minmax(245px, 0.95fr)
      minmax(390px, 1.45fr)
      minmax(245px, 0.95fr) !important;
  }
}

/* 2026-05 位置互换：左列玩法在上、单词在下；右列排行在上、地图在下 */
.main-layout {
  grid-template-rows: minmax(180px, 0.9fr) minmax(230px, 1.1fr) !important;
}

.side-panel .panel-card:nth-child(1) {
  grid-column: 1 !important;
  grid-row: 2 !important;
}

.side-panel .panel-card:nth-child(2) {
  grid-column: 1 !important;
  grid-row: 1 !important;
}

.side-panel .panel-card:nth-child(3) {
  grid-column: 3 !important;
  grid-row: 2 !important;
}

.side-panel .panel-card:nth-child(4) {
  grid-column: 3 !important;
  grid-row: 1 !important;
}

.leaderboard {
  grid-template-rows: repeat(10, minmax(0, 1fr)) !important;
}


/* 2026-05 进阶连线与三列比例最终优化 */
.main-layout {
  grid-template-rows: minmax(130px, 3fr) minmax(290px, 7fr) !important;
}

.side-panel .panel-card:nth-child(2) {
  grid-column: 1 !important;
  grid-row: 1 !important;
}

.side-panel .panel-card:nth-child(1) {
  grid-column: 1 !important;
  grid-row: 2 !important;
}

.side-panel .panel-card:nth-child(4) {
  grid-column: 3 !important;
  grid-row: 1 !important;
}

.side-panel .panel-card:nth-child(3) {
  grid-column: 3 !important;
  grid-row: 2 !important;
}

.side-panel .panel-card:nth-child(n) {
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

.side-panel .controls {
  gap: clamp(5px, 0.55vw, 9px) !important;
}

.side-panel .controls .primary-btn {
  margin-top: auto !important;
}

.target-list,
.leaderboard,
.level-map {
  flex: 1 1 auto !important;
  min-height: 0 !important;
}

.grid-scroller.letter-mode {
  display: grid !important;
  place-items: center !important;
  overflow: hidden !important;
  padding: clamp(8px, 0.8vw, 14px) !important;
  touch-action: none !important;
}

.letter-grid {
  width: max-content !important;
  max-width: 100% !important;
  max-height: 100% !important;
  grid-auto-rows: var(--cell) !important;
  gap: var(--letter-gap, 4px) !important;
  padding: clamp(8px, 0.8vw, 14px) !important;
  border-radius: clamp(18px, 1.6vw, 28px) !important;
  border: 2px solid rgba(255, 126, 182, 0.24) !important;
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 255, 255, 0.96), transparent 13rem),
    linear-gradient(135deg, rgba(255, 247, 252, 0.92), rgba(241, 234, 255, 0.76)) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.68), 0 18px 40px rgba(148, 77, 132, 0.12) !important;
}

.cell {
  width: var(--cell) !important;
  height: var(--cell) !important;
  min-width: 0 !important;
  min-height: 0 !important;
  border-radius: clamp(9px, calc(var(--cell) * 0.18), 16px) !important;
  font-size: clamp(16px, calc(var(--cell) * 0.52), 38px) !important;
  line-height: 1 !important;
  display: grid !important;
  place-items: center !important;
}

.cell.heart-cell {
  font-size: clamp(15px, calc(var(--cell) * 0.48), 34px) !important;
}

@media (max-height: 720px) {
  .main-layout {
    grid-template-rows: minmax(108px, 3fr) minmax(240px, 7fr) !important;
  }
  .grid-scroller.letter-mode {
    padding: 6px !important;
  }
  .letter-grid {
    padding: 7px !important;
  }
}

@media (max-width: 1180px) {
  .main-layout {
    grid-template-rows: minmax(124px, 3fr) minmax(270px, 7fr) !important;
  }
}


/* 2026-05 final right column ratio and infinite level window */
.main-layout {
  --panel-stack-gap: clamp(5px, 0.5vw, 10px);
  --panel-stack-half-gap: clamp(2.5px, 0.25vw, 5px);
  grid-template-rows: minmax(130px, 3fr) minmax(290px, 7fr) !important;
}

/* Keep left column as 3/7: controls above, current words below. */
.side-panel .panel-card:nth-child(2) {
  grid-column: 1 !important;
  grid-row: 1 !important;
}

.side-panel .panel-card:nth-child(1) {
  grid-column: 1 !important;
  grid-row: 2 !important;
}

/* Right column keeps leaderboard above map, but uses its own 7/3 height ratio. */
.side-panel .panel-card:nth-child(4) {
  grid-column: 3 !important;
  grid-row: 1 / 3 !important;
  align-self: start !important;
  height: calc(70% - var(--panel-stack-half-gap)) !important;
}

.side-panel .panel-card:nth-child(3) {
  grid-column: 3 !important;
  grid-row: 1 / 3 !important;
  align-self: end !important;
  height: calc(30% - var(--panel-stack-half-gap)) !important;
}

.level-map {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  grid-template-rows: repeat(5, minmax(0, 1fr)) !important;
}

.leaderboard li strong {
  display: inline-block;
  font-size: clamp(14px, 1.05vw, 17px) !important;
  line-height: 1.15;
}

.leaderboard li {
  font-size: clamp(13px, 1.05vw, 16px) !important;
}

.leaderboard small {
  font-size: clamp(11px, 0.92vw, 13px) !important;
}

@media (max-height: 720px) {
  .side-panel .panel-card:nth-child(4) { height: calc(70% - 3px) !important; }
  .side-panel .panel-card:nth-child(3) { height: calc(30% - 3px) !important; }
}

/* 2026-05 词库选择按钮：CET4 / CET6 / 混合 */
.word-source-switch {
  display: inline-grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(4px, 0.45vw, 8px);
  width: min(100%, 560px);
  margin: clamp(4px, 0.45vw, 7px) auto clamp(5px, 0.55vw, 9px);
  padding: clamp(3px, 0.32vw, 5px);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid var(--line);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.46);
}

.source-btn {
  border: 0;
  border-radius: 999px;
  padding: clamp(6px, 0.62vw, 10px) clamp(7px, 0.8vw, 14px);
  color: var(--muted);
  background: transparent;
  font-size: clamp(11px, 0.82vw, 14px);
  font-weight: 950;
  line-height: 1.05;
  white-space: nowrap;
  transition: transform 0.14s ease, color 0.14s ease, background 0.14s ease, box-shadow 0.14s ease;
}

.source-btn:hover {
  color: var(--pink-500);
  transform: translateY(-1px);
}

.source-btn.active {
  color: #fff;
  background: linear-gradient(135deg, var(--pink-500), var(--lavender));
  box-shadow: 0 8px 18px rgba(247, 93, 157, 0.24);
}

.game-toolbar p#selectionPreview {
  display: block;
}

@media (max-width: 760px) {
  .word-source-switch {
    grid-template-columns: 1fr;
    border-radius: 22px;
  }
}


/* 2026-05 用户编号昵称 */
.profile-card .user-code {
  display: block;
  margin: 6px 2px 0;
  color: var(--muted);
  font-size: clamp(11px, 0.82vw, 13px);
  font-weight: 800;
  letter-spacing: 0.02em;
}

/* 2026-05 进阶首字母爱心提示 */
.cell.first-letter-cell {
  position: relative !important;
  overflow: visible !important;
}

.first-letter-heart {
  position: absolute;
  top: clamp(2px, calc(var(--cell) * 0.06), 5px);
  left: clamp(2px, calc(var(--cell) * 0.06), 5px);
  z-index: 3;
  display: grid;
  place-items: center;
  width: clamp(10px, calc(var(--cell) * 0.28), 18px);
  height: clamp(10px, calc(var(--cell) * 0.28), 18px);
  border-radius: 999px;
  color: #ff5fa2;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(255, 126, 182, 0.34);
  box-shadow: 0 3px 8px rgba(247, 93, 157, 0.18);
  font-size: clamp(8px, calc(var(--cell) * 0.18), 13px);
  line-height: 1;
  pointer-events: none;
  text-transform: none;
}

.cell.selected .first-letter-heart,
.cell.pending-answer .first-letter-heart {
  color: #fff;
  background: rgba(255, 255, 255, 0.24);
  border-color: rgba(255, 255, 255, 0.48);
}

.cell.solved .first-letter-heart {
  display: none;
}

/* 2026-05 手机端专项优化：取消小屏横向画布，改为真正单列布局；电脑端三列保持不变 */
@media (max-width: 900px) {
  html,
  body {
    width: 100%;
    min-height: 100dvh;
  }

  body {
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  .bg-decor {
    display: none !important;
  }

  .app-shell {
    width: min(100% - 12px, 560px) !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 100dvh !important;
    padding: 6px 0 12px !important;
    display: grid !important;
    grid-template-rows: auto auto auto !important;
    gap: 8px !important;
    overflow: visible !important;
  }

  .app-hero,
  .hero-card {
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
    gap: 10px !important;
    padding: 12px !important;
    border-radius: 22px !important;
    overflow: visible !important;
  }

  .hero-content {
    grid-template-columns: 1fr !important;
    gap: 7px !important;
  }

  .game-kicker {
    max-width: 100% !important;
    padding: 5px 10px !important;
    font-size: 10px !important;
    letter-spacing: 0.05em !important;
    white-space: normal !important;
  }

  .hero-content h1 {
    font-size: clamp(24px, 8vw, 34px) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.04em !important;
  }

  .hero-description {
    grid-template-columns: 1fr !important;
    gap: 6px !important;
    font-size: 12px !important;
    line-height: 1.42 !important;
  }

  .hero-description span {
    padding: 7px 9px !important;
    border-radius: 14px !important;
  }

  .profile-card {
    width: 100% !important;
    padding: 10px !important;
    border-radius: 18px !important;
  }

  .profile-card input {
    width: 100% !important;
    height: 38px !important;
    font-size: 14px !important;
  }

  .profile-card .user-code {
    font-size: 12px !important;
  }

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

  .mode-btn {
    padding: 9px 6px !important;
    font-size: 13px !important;
  }

  .main-layout {
    grid-row: 2 !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    min-width: 0 !important;
    padding: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    gap: 8px !important;
    overflow: visible !important;
  }

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

  .game-card {
    grid-column: 1 !important;
    grid-row: 1 !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 8px !important;
    border-radius: 22px !important;
    overflow: visible !important;
  }

  .side-panel .panel-card:nth-child(2) {
    grid-column: 1 !important;
    grid-row: 2 !important;
  }

  .side-panel .panel-card:nth-child(1) {
    grid-column: 1 !important;
    grid-row: 3 !important;
  }

  .side-panel .panel-card:nth-child(4) {
    grid-column: 1 !important;
    grid-row: 4 !important;
    align-self: stretch !important;
    height: auto !important;
  }

  .side-panel .panel-card:nth-child(3) {
    grid-column: 1 !important;
    grid-row: 5 !important;
    align-self: stretch !important;
    height: auto !important;
  }

  .side-panel .panel-card,
  .panel-card {
    width: 100% !important;
    min-height: 0 !important;
    padding: 10px !important;
    border-radius: 20px !important;
    overflow: visible !important;
  }

  .panel-title-row {
    margin-bottom: 8px !important;
  }

  .panel-title-row h2,
  .controls h2 {
    font-size: 17px !important;
  }

  .game-toolbar {
    display: block !important;
    padding-bottom: 6px !important;
    margin-bottom: 4px !important;
    text-align: center !important;
  }

  .game-toolbar > div:first-child {
    width: 100% !important;
  }

  .game-toolbar p#selectionPreview {
    display: block !important;
    margin: 5px 0 0 !important;
    font-size: 12px !important;
    line-height: 1.32 !important;
  }

  .word-source-switch {
    width: 100% !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 4px !important;
    margin: 0 auto 5px !important;
    padding: 4px !important;
    border-radius: 18px !important;
  }

  .source-btn {
    padding: 7px 3px !important;
    font-size: 11px !important;
    line-height: 1.12 !important;
    white-space: normal !important;
  }

  .grid-scroller {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 6px !important;
    border-radius: 18px !important;
    overflow: hidden !important;
  }

  .grid-scroller.match-mode {
    min-height: 360px !important;
  }

  .grid-scroller.letter-mode {
    min-height: min(88vw, 520px) !important;
    padding: 6px !important;
  }

  .match-grid {
    width: 100% !important;
    max-width: 100% !important;
    max-height: none !important;
    grid-template-columns: repeat(var(--match-columns), minmax(0, 1fr)) !important;
    grid-auto-rows: minmax(58px, auto) !important;
    gap: 5px !important;
    padding: 6px !important;
    border-radius: 16px !important;
    overflow: visible !important;
  }

  .match-card,
  .match-card.random-card {
    width: auto !important;
    height: auto !important;
    min-height: clamp(58px, 16vw, 78px) !important;
    padding: 5px !important;
    border-radius: 14px !important;
  }

  .match-card.random-card.word strong,
  .match-card.word strong {
    font-size: clamp(12px, 3.35vw, 17px) !important;
    line-height: 1.06 !important;
  }

  .match-card.random-card.meaning strong,
  .match-card.meaning strong {
    font-size: clamp(10px, 2.9vw, 14px) !important;
    line-height: 1.18 !important;
  }

  .letter-grid {
    max-width: 100% !important;
    max-height: none !important;
    padding: 6px !important;
    gap: var(--letter-gap, 3px) !important;
    border-radius: 18px !important;
  }

  .cell {
    border-radius: clamp(8px, calc(var(--cell) * 0.16), 13px) !important;
  }

  .first-letter-heart {
    top: clamp(1px, calc(var(--cell) * 0.04), 4px) !important;
    left: clamp(1px, calc(var(--cell) * 0.04), 4px) !important;
  }

  .controls {
    gap: 8px !important;
  }

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

  .primary-btn,
  .ghost-btn,
  .mini-btn {
    min-height: 36px !important;
    padding: 8px 10px !important;
    font-size: 13px !important;
  }

  .range-label {
    font-size: 12px !important;
  }

  input[type="range"] {
    width: 100% !important;
    height: 26px !important;
  }

  .target-list {
    height: auto !important;
    min-height: 0 !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: none !important;
    grid-auto-rows: auto !important;
    gap: 6px !important;
    overflow: visible !important;
  }

  .target-item {
    min-height: 44px !important;
    padding: 7px !important;
    border-radius: 14px !important;
  }

  .target-item .word {
    font-size: 13px !important;
  }

  .target-item .tag {
    display: block !important;
    font-size: 10px !important;
  }

  .leaderboard {
    max-height: 300px !important;
    overflow-y: auto !important;
    grid-template-rows: none !important;
    grid-auto-rows: auto !important;
    gap: 6px !important;
    padding-right: 2px !important;
  }

  .leaderboard li {
    min-height: 48px !important;
    padding: 8px 9px !important;
    font-size: 14px !important;
    white-space: normal !important;
  }

  .leaderboard li strong {
    font-size: 18px !important;
  }

  .leaderboard small {
    font-size: 12px !important;
  }

  .level-map {
    height: auto !important;
    min-height: 0 !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    grid-template-rows: none !important;
    grid-auto-rows: 36px !important;
    gap: 5px !important;
    overflow: visible !important;
  }

  .level-dot {
    height: 36px !important;
    border-radius: 12px !important;
    font-size: 12px !important;
  }

  .dashboard {
    grid-row: 3 !important;
    width: 100% !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
    padding: 7px !important;
    border-radius: 20px !important;
  }

  .stat-card {
    min-height: 58px !important;
    padding: 8px !important;
    border-radius: 16px !important;
  }

  .stat-card span,
  .stat-card small {
    font-size: 11px !important;
  }

  .stat-card strong {
    font-size: 22px !important;
  }
}

@media (max-width: 420px) {
  .app-shell {
    width: calc(100% - 8px) !important;
    gap: 6px !important;
  }

  .hero-description {
    display: none !important;
  }

  .word-source-switch {
    gap: 3px !important;
  }

  .source-btn {
    font-size: 10px !important;
    padding: 6px 2px !important;
  }

  .grid-scroller.match-mode {
    min-height: 330px !important;
  }

  .match-grid {
    gap: 4px !important;
    padding: 5px !important;
  }

  .match-card,
  .match-card.random-card {
    min-height: 54px !important;
    padding: 4px !important;
  }

  .match-card.random-card.word strong,
  .match-card.word strong {
    font-size: 11px !important;
  }

  .match-card.random-card.meaning strong,
  .match-card.meaning strong {
    font-size: 9.5px !important;
  }

  .target-list {
    gap: 5px !important;
  }

  .target-item {
    min-height: 40px !important;
    padding: 6px !important;
  }

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


/* 2026-05 leaderboard columns and 100-level title system polish */
.leaderboard li.leaderboard-head,
.leaderboard li.leader-entry {
  display: grid !important;
  grid-template-columns: minmax(76px, 0.95fr) minmax(58px, 0.72fr) minmax(58px, 0.66fr) !important;
  align-items: center !important;
  column-gap: 7px !important;
}

.leaderboard li.leaderboard-head {
  min-height: 28px !important;
  padding: 4px 9px !important;
  font-size: clamp(11px, 0.82vw, 13px) !important;
  font-weight: 900 !important;
  letter-spacing: 0.06em !important;
  color: var(--muted) !important;
  background: rgba(255, 255, 255, 0.58) !important;
  border-style: dashed !important;
}

.leaderboard li.leader-entry {
  min-height: 44px !important;
  padding: 8px 9px !important;
}

.leaderboard .leader-rank,
.leaderboard .leader-score {
  font-size: clamp(12px, 0.94vw, 14px) !important;
  font-weight: 850 !important;
  white-space: nowrap !important;
}

.leaderboard .leader-time {
  display: inline-block !important;
  font-size: clamp(13px, 0.98vw, 15px) !important;
  line-height: 1.1 !important;
  color: var(--pink-500) !important;
  white-space: nowrap !important;
}

.leaderboard .rank-medal {
  display: inline-block !important;
  margin-right: 2px !important;
  font-size: 1.08em !important;
  transform: translateY(-1px) !important;
}

.leaderboard .leader-empty {
  display: block !important;
}

.level-pill span {
  letter-spacing: 0.01em;
}

@media (max-width: 900px) {
  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(84px, 1fr) minmax(66px, 0.75fr) minmax(64px, 0.7fr) !important;
    column-gap: 8px !important;
  }

  .leaderboard li.leader-entry {
    min-height: 46px !important;
  }

  .leaderboard .leader-rank,
  .leaderboard .leader-score {
    font-size: 14px !important;
  }

  .leaderboard .leader-time {
    font-size: 16px !important;
  }
}

/* 2026-05 用户信息标签优化 */
.profile-card label[for="playerName"] {
  font-size: clamp(14px, 1vw, 16px) !important;
  font-weight: 950 !important;
  color: var(--ink) !important;
  letter-spacing: 0.03em !important;
  line-height: 1.15 !important;
}

@media (max-width: 760px) {
  .profile-card label[for="playerName"] {
    font-size: 14px !important;
  }
}

/* 2026-05 MarLous title link button */
.marlous-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  align-self: center !important;
  min-height: 32px !important;
  padding: 7px 14px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 126, 182, 0.32) !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(255, 205, 230, 0.88)) !important;
  color: var(--pink-500) !important;
  box-shadow: 0 10px 22px rgba(246, 93, 157, 0.16), inset 0 0 0 1px rgba(255, 255, 255, 0.65) !important;
  font-size: clamp(12px, 0.95vw, 15px) !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  letter-spacing: 0.03em !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease !important;
}

.marlous-link:hover,
.marlous-link:focus-visible {
  transform: translateY(-1px) !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, 1), rgba(255, 172, 210, 0.94)) !important;
  box-shadow: 0 14px 28px rgba(246, 93, 157, 0.22), inset 0 0 0 1px rgba(255, 255, 255, 0.75) !important;
  outline: none !important;
}

@media (max-width: 760px) {
  .marlous-link {
    min-height: 30px !important;
    padding: 7px 12px !important;
    font-size: 12px !important;
  }
}


/* 2026-05 MarLous button size alignment refinement */
.marlous-link {
  align-self: flex-end !important;
  min-height: 21px !important;
  padding: 4px 9px !important;
  font-size: clamp(8px, 0.62vw, 10px) !important;
  line-height: 1 !important;
  border-radius: 999px !important;
  box-shadow: 0 7px 14px rgba(246, 93, 157, 0.14), inset 0 0 0 1px rgba(255, 255, 255, 0.65) !important;
}

.marlous-link:hover,
.marlous-link:focus-visible {
  transform: translateY(-1px) !important;
  box-shadow: 0 9px 18px rgba(246, 93, 157, 0.2), inset 0 0 0 1px rgba(255, 255, 255, 0.75) !important;
}

@media (max-width: 760px) {
  .marlous-link {
    align-self: flex-end !important;
    min-height: 20px !important;
    padding: 4px 8px !important;
    font-size: 8px !important;
  }
}

/* 2026-05 level tier colors and lollipop title badge */
.level-pill {
  --level-color: #9D9D9D;
  --level-soft-bg: rgba(157, 157, 157, 0.16);
  --level-border: rgba(157, 157, 157, 0.18);
  position: relative !important;
  overflow: hidden !important;
  border: 1px solid var(--level-border) !important;
  background: linear-gradient(135deg, rgba(255, 232, 244, 0.96), rgba(245, 229, 255, 0.92) 48%, var(--level-soft-bg)) !important;
  box-shadow: 0 8px 20px rgba(148, 77, 132, 0.10), inset 0 0 0 1px rgba(233, 170, 208, 0.18) !important;
}

.level-pill::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 18% 22%, var(--level-soft-bg), transparent 52%);
  opacity: 0.85;
}

.level-pill > span,
.level-pill > strong {
  position: relative;
  z-index: 1;
}

.level-pill.level-tier-1, #playerName.level-tier-1 { --level-color: #9D9D9D; --level-soft-bg: rgba(157, 157, 157, 0.14); --level-border: rgba(157, 157, 157, 0.18); }
.level-pill.level-tier-2, #playerName.level-tier-2 { --level-color: #CD7F32; --level-soft-bg: rgba(205, 127, 50, 0.14); --level-border: rgba(205, 127, 50, 0.20); }
.level-pill.level-tier-3, #playerName.level-tier-3 { --level-color: #C0C0C0; --level-soft-bg: rgba(192, 192, 192, 0.16); --level-border: rgba(160, 160, 160, 0.20); }
.level-pill.level-tier-4, #playerName.level-tier-4 { --level-color: #FFD700; --level-soft-bg: rgba(255, 215, 0, 0.15); --level-border: rgba(255, 199, 0, 0.22); }
.level-pill.level-tier-5, #playerName.level-tier-5 { --level-color: #00BFFF; --level-soft-bg: rgba(0, 191, 255, 0.12); --level-border: rgba(0, 191, 255, 0.19); }
.level-pill.level-tier-6, #playerName.level-tier-6 { --level-color: #50C878; --level-soft-bg: rgba(80, 200, 120, 0.14); --level-border: rgba(80, 200, 120, 0.20); }
.level-pill.level-tier-7, #playerName.level-tier-7 { --level-color: #E0115F; --level-soft-bg: rgba(224, 17, 95, 0.12); --level-border: rgba(224, 17, 95, 0.19); }
.level-pill.level-tier-8, #playerName.level-tier-8 { --level-color: #9966CC; --level-soft-bg: rgba(153, 102, 204, 0.14); --level-border: rgba(153, 102, 204, 0.20); }
.level-pill.level-tier-9, #playerName.level-tier-9 { --level-color: #B8860B; --level-soft-bg: rgba(184, 134, 11, 0.14); --level-border: rgba(184, 134, 11, 0.22); }
.level-pill.level-tier-10, #playerName.level-tier-10 { --level-color: #FFFFFF; --level-soft-bg: rgba(255, 145, 196, 0.16); --level-border: rgba(170, 116, 217, 0.24); }

.level-pill.level-tier-rainbow {
  background:
    linear-gradient(135deg, rgba(255, 232, 244, 0.95), rgba(239, 226, 255, 0.78)),
    conic-gradient(from 160deg, #ff7eb6, #ffd700, #50c878, #00bfff, #9966cc, #ff7eb6) !important;
  box-shadow: 0 10px 24px rgba(153, 102, 204, 0.16), 0 0 12px rgba(255, 215, 0, 0.12), inset 0 0 0 1px rgba(231, 165, 205, 0.22) !important;
}

.level-pill strong {
  color: var(--level-color) !important;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.82) !important;
}

.level-pill.level-tier-10 strong {
  color: #7b4df7 !important;
}

#playerTitle {
  display: inline-flex !important;
  align-items: center !important;
  min-width: 0 !important;
  gap: 7px !important;
  color: var(--ink) !important;
  font-weight: 900 !important;
}

#playerTitle .title-name {
  color: var(--level-color) !important;
  font-weight: 950 !important;
  white-space: nowrap !important;
  -webkit-text-stroke: 0 transparent !important;
  text-shadow:
    0.45px 0 rgba(75, 23, 110, 0.18),
    -0.45px 0 rgba(75, 23, 110, 0.18),
    0 0.45px rgba(75, 23, 110, 0.16),
    0 -0.45px rgba(255, 255, 255, 0.28),
    0 1px 1.4px rgba(255, 255, 255, 0.24) !important;
}

.level-pill.level-tier-10 #playerTitle .title-name {
  color: #7b4df7 !important;
  background: linear-gradient(90deg, #ff5fa2, #ffd700, #50c878, #00bfff, #9966cc, #ff5fa2);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 0 transparent !important;
  text-shadow:
    0.55px 0 rgba(75, 23, 110, 0.16),
    -0.55px 0 rgba(75, 23, 110, 0.16),
    0 0.55px rgba(75, 23, 110, 0.14),
    0 1px 2px rgba(123, 77, 247, 0.12),
    0 0 3px rgba(255, 95, 162, 0.08) !important;
}

#playerTitle .title-stars {
  color: var(--level-color) !important;
  font-size: 0.9em !important;
  white-space: nowrap !important;
  letter-spacing: 0.02em !important;
}

.level-pill.level-tier-10 #playerTitle .title-stars {
  color: #ffb703 !important;
}

.title-lollipop {
  position: relative !important;
  display: inline-flex !important;
  flex: 0 0 auto !important;
  width: 15px !important;
  height: 15px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle at 34% 30%, rgba(255, 255, 255, 0.95) 0 17%, var(--level-color) 18% 100%) !important;
  box-shadow: 0 2px 6px rgba(70, 51, 71, 0.18), inset 0 0 0 1px rgba(255, 255, 255, 0.58) !important;
  transform: translateY(-1px) rotate(-12deg) !important;
}

.title-lollipop::after {
  content: "";
  position: absolute;
  width: 3px;
  height: 12px;
  left: 10px;
  top: 12px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(180, 155, 120, 0.72));
  transform: rotate(-28deg);
  transform-origin: top center;
  box-shadow: 0 1px 2px rgba(70, 51, 71, 0.12);
}

.title-lollipop.rainbow {
  background: conic-gradient(from 45deg, #ff5fa2, #ffd700, #50c878, #00bfff, #9966cc, #ff5fa2) !important;
  box-shadow: 0 2px 8px rgba(153, 102, 204, 0.26), 0 0 10px rgba(255, 215, 0, 0.22), inset 0 0 0 1px rgba(255, 255, 255, 0.66) !important;
}

@media (max-width: 760px) {
  #playerTitle {
    gap: 6px !important;
  }

  .title-lollipop {
    width: 14px !important;
    height: 14px !important;
  }

  .title-lollipop::after {
    height: 11px !important;
    left: 9px !important;
    top: 11px !important;
  }
}

/* 2026-05 manually entered star-wish user code and leaderboard detail modal */
.profile-card .user-code-btn {
  width: fit-content !important;
  max-width: 100% !important;
  border: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  cursor: pointer !important;
  text-align: left !important;
}

.profile-card .user-code-btn:hover,
.profile-card .user-code-btn:focus-visible {
  color: var(--pink-500) !important;
  text-decoration: underline !important;
  outline: none !important;
}

.user-code-modal-card,
.rank-detail-card {
  width: min(430px, calc(100vw - 32px)) !important;
  padding: clamp(22px, 5vw, 30px) !important;
}

.user-code-modal-card h2,
.rank-detail-card h2 {
  margin-bottom: 10px !important;
  font-size: clamp(24px, 5vw, 34px) !important;
  letter-spacing: -0.02em !important;
  line-height: 1.12 !important;
  text-transform: none !important;
}

.modal-copy {
  max-width: 34em;
  margin: 0 auto 14px !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
  color: var(--muted) !important;
}

.modal-input {
  width: 100% !important;
  margin-top: 4px !important;
  border: 1px solid rgba(255, 126, 182, 0.34) !important;
  background: rgba(255, 255, 255, 0.94) !important;
  color: var(--ink) !important;
  border-radius: 18px !important;
  padding: 13px 15px !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  letter-spacing: 0.08em !important;
  text-align: center !important;
  outline: none !important;
}

.modal-input:focus {
  border-color: var(--pink-400) !important;
  box-shadow: 0 0 0 4px rgba(255, 126, 182, 0.18) !important;
}

.modal-error {
  margin-top: 9px !important;
  color: #e25284 !important;
  font-size: 13px !important;
  font-weight: 850 !important;
}

.modal-action {
  width: 100% !important;
  margin-top: 16px !important;
}

.leaderboard .rank-detail-trigger {
  appearance: none !important;
  border: 0 !important;
  padding: 0 2px !important;
  margin: 0 3px 0 0 !important;
  background: transparent !important;
  cursor: pointer !important;
  line-height: 1 !important;
  font: inherit !important;
}

.leaderboard .rank-detail-trigger:hover,
.leaderboard .rank-detail-trigger:focus-visible {
  transform: translateY(-2px) scale(1.16) !important;
  filter: drop-shadow(0 3px 5px rgba(246, 93, 157, 0.28));
  outline: none !important;
}

.rank-detail-list {
  display: grid;
  gap: 10px;
  margin: 16px 0 2px;
}

.rank-detail-list p {
  display: grid;
  grid-template-columns: 82px 1fr;
  align-items: center;
  gap: 10px;
  margin: 0 !important;
  padding: 11px 12px;
  border: 1px solid rgba(255, 126, 182, 0.20);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  text-align: left;
}

.rank-detail-list span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}

.rank-detail-list strong {
  min-width: 0;
  color: var(--ink);
  font-size: 15px;
  font-weight: 950;
  word-break: break-word;
}

@media (max-width: 760px) {
  .modal-copy {
    font-size: 13px !important;
  }

  .modal-input {
    font-size: 17px !important;
  }

  .rank-detail-list p {
    grid-template-columns: 76px 1fr;
  }
}


/* 2026-05 lock desktop zoom: grid size stays automatic; no manual page/grid scaling UI. */
html,
body {
  overscroll-behavior: none;
  touch-action: manipulation;
}

.zoom-control {
  display: none !important;
}

/* 2026-05 leaderboard player detail: reuse the same level pill/title badge style as the homepage. */
.title-badge {
  display: inline-flex !important;
  align-items: center !important;
  min-width: 0 !important;
  gap: 7px !important;
  color: var(--ink) !important;
  font-weight: 900 !important;
}

.title-badge .title-name {
  color: var(--level-color) !important;
  font-weight: 950 !important;
  white-space: nowrap !important;
  -webkit-text-stroke: 0 transparent !important;
  text-shadow:
    0.45px 0 rgba(75, 23, 110, 0.18),
    -0.45px 0 rgba(75, 23, 110, 0.18),
    0 0.45px rgba(75, 23, 110, 0.16),
    0 -0.45px rgba(255, 255, 255, 0.28),
    0 1px 1.4px rgba(255, 255, 255, 0.24) !important;
}

.level-pill.level-tier-10 .title-badge .title-name {
  color: #7b4df7 !important;
  background: linear-gradient(90deg, #ff5fa2, #ffd700, #50c878, #00bfff, #9966cc, #ff5fa2);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 0 transparent !important;
  text-shadow:
    0.55px 0 rgba(75, 23, 110, 0.16),
    -0.55px 0 rgba(75, 23, 110, 0.16),
    0 0.55px rgba(75, 23, 110, 0.14),
    0 1px 2px rgba(123, 77, 247, 0.12),
    0 0 3px rgba(255, 95, 162, 0.08) !important;
}

.title-badge .title-stars {
  color: var(--level-color) !important;
  font-size: 0.9em !important;
  white-space: nowrap !important;
  letter-spacing: 0.02em !important;
}

.level-pill.level-tier-10 .title-badge .title-stars {
  color: #ffb703 !important;
}

#rankDetailLevel {
  display: flex !important;
  align-items: center !important;
  min-width: 0 !important;
}

.rank-detail-level-pill {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 9px 12px !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
}

.rank-detail-level-pill .title-badge {
  overflow: hidden !important;
}

.rank-detail-level-pill .title-name {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.rank-detail-level-pill > strong {
  flex: 0 0 auto !important;
}

@media (max-width: 760px) {
  .rank-detail-level-pill {
    gap: 8px !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
  }

  .rank-detail-level-pill .title-badge {
    gap: 5px !important;
  }
}


/* 2026-05 nickname is generated from the starwish code; it is display-only and follows the current title tier style. */
.profile-card input#playerName[readonly] {
  cursor: default !important;
  user-select: none !important;
  background: linear-gradient(135deg, rgba(255, 232, 244, 0.90), rgba(239, 226, 255, 0.82), var(--level-soft-bg, rgba(255, 145, 196, 0.12))) !important;
  border-color: var(--level-border, rgba(255, 126, 182, 0.18)) !important;
  color: var(--level-color, var(--ink)) !important;
  font-weight: 950 !important;
  letter-spacing: 0.02em !important;
  -webkit-text-stroke: 0.12px rgba(75, 23, 110, 0.24) !important;
  text-shadow:
    0 0.45px 0 rgba(255, 255, 255, 0.58),
    0 0 0.6px rgba(75, 23, 110, 0.24) !important;
  box-shadow: inset 0 0 0 1px rgba(231, 165, 205, 0.14) !important;
}

.profile-card input#playerName[readonly].level-tier-10,
.profile-card input#playerName[readonly].level-tier-rainbow {
  color: #7b4df7 !important;
  -webkit-text-stroke: 0.14px rgba(75, 23, 110, 0.28) !important;
  text-shadow:
    0 1px 2px rgba(123, 77, 247, 0.14),
    0 0 3px rgba(255, 95, 162, 0.09) !important;
}

.profile-card input#playerName[readonly]:focus {
  border-color: var(--level-border, rgba(255, 126, 182, 0.18)) !important;
  box-shadow: inset 0 0 0 1px rgba(231, 165, 205, 0.14) !important;
}

/* 2026-05 leaderboard player card: show the full title/level without truncating. */
.rank-detail-card {
  width: min(520px, calc(100vw - 32px)) !important;
}

.rank-detail-level-row {
  grid-template-columns: minmax(0, 1fr) !important;
  align-items: stretch !important;
}

.rank-detail-level-row > span {
  align-self: center !important;
}

#rankDetailLevel {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
}

.rank-detail-level-pill {
  width: 100% !important;
  max-width: none !important;
  height: auto !important;
  min-height: 42px !important;
  align-items: center !important;
  justify-content: flex-start !important;
  flex-wrap: wrap !important;
  row-gap: 7px !important;
  white-space: normal !important;
}

.rank-detail-level-pill .title-badge {
  flex: 1 1 100% !important;
  max-width: 100% !important;
  overflow: visible !important;
  white-space: normal !important;
  flex-wrap: wrap !important;
}

.rank-detail-level-pill .title-name,
.rank-detail-level-pill .title-stars {
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: normal !important;
}

.rank-detail-level-pill > strong {
  flex: 0 0 auto !important;
  margin-left: auto !important;
}

@media (max-width: 760px) {
  .rank-detail-level-row {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}


/* 2026-05 rank detail level row refinement + level complete result modal */
.rank-detail-card {
  width: min(560px, calc(100vw - 32px)) !important;
}

.rank-detail-level-row {
  grid-template-columns: 58px minmax(0, 1fr) !important;
  align-items: center !important;
}

.rank-detail-level-row > span {
  align-self: center !important;
  color: #9a6d97 !important;
  font-weight: 950 !important;
}

#rankDetailLevel {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
}

.rank-detail-level-pill {
  width: 100% !important;
  max-width: 100% !important;
  min-height: 48px !important;
  height: auto !important;
  margin: 0 !important;
  padding: 10px 13px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: nowrap !important;
  gap: 10px !important;
  overflow: visible !important;
  white-space: nowrap !important;
}

.rank-detail-level-pill .title-badge {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  max-width: none !important;
  display: inline-flex !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  gap: 6px !important;
  overflow: visible !important;
  white-space: nowrap !important;
}

.rank-detail-level-pill .title-name,
.rank-detail-level-pill .title-stars {
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
}

.rank-detail-level-pill > strong {
  flex: 0 0 auto !important;
  margin-left: 8px !important;
  font-size: 15px !important;
}

.level-complete-card {
  width: min(520px, calc(100vw - 32px)) !important;
}

.complete-score-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0 4px;
}

.complete-score-grid div {
  padding: 13px 12px;
  border-radius: 18px;
  border: 1px solid rgba(255, 126, 182, 0.18);
  background: linear-gradient(135deg, rgba(255, 232, 244, 0.76), rgba(241, 234, 255, 0.72));
  text-align: left;
}

.complete-score-grid span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  margin-bottom: 6px;
}

.complete-score-grid strong {
  display: block;
  color: var(--ink);
  font-size: 22px;
  font-weight: 950;
  line-height: 1;
}

.complete-action-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1.15fr;
  gap: 10px;
  margin-top: 18px;
}

.complete-action-row button {
  min-height: 44px;
}

.complete-action-row button:disabled {
  cursor: not-allowed;
  opacity: 0.48;
  transform: none !important;
}

@media (max-width: 760px) {
  .rank-detail-card {
    width: min(520px, calc(100vw - 22px)) !important;
  }

  .rank-detail-level-row {
    grid-template-columns: 48px minmax(0, 1fr) !important;
  }

  .rank-detail-level-pill {
    flex-wrap: wrap !important;
    white-space: normal !important;
    row-gap: 6px !important;
  }

  .rank-detail-level-pill .title-badge {
    flex: 1 1 100% !important;
    flex-wrap: wrap !important;
    white-space: normal !important;
  }

  .rank-detail-level-pill .title-name,
  .rank-detail-level-pill .title-stars {
    white-space: normal !important;
  }

  .rank-detail-level-pill > strong {
    margin-left: auto !important;
  }

  .complete-score-grid,
  .complete-action-row {
    grid-template-columns: 1fr;
  }
}


/* 2026-05 homepage title: true outside outline.
   Do not stroke the foreground glyph; draw the outline on a hidden back layer so it cannot eat into the text. */
#playerTitle .title-name {
  position: relative !important;
  display: inline-block !important;
  isolation: isolate !important;
  padding: 0 2px !important;
  -webkit-text-stroke: 0 transparent !important;
  text-shadow: none !important;
  filter:
    drop-shadow(0 0.6px 0 rgba(75, 23, 110, 0.12))
    drop-shadow(0 1px 1.2px rgba(255, 255, 255, 0.20)) !important;
}

#playerTitle .title-name::before {
  content: attr(data-title);
  position: absolute !important;
  left: 2px !important;
  top: 0 !important;
  z-index: -1 !important;
  pointer-events: none !important;
  color: transparent !important;
  -webkit-text-fill-color: transparent !important;
  -webkit-text-stroke: 0.95px rgba(75, 23, 110, 0.18) !important;
  text-shadow: none !important;
}

.level-pill.level-tier-10 #playerTitle .title-name,
.level-pill.level-tier-rainbow #playerTitle .title-name {
  -webkit-text-stroke: 0 transparent !important;
  text-shadow: none !important;
  filter:
    drop-shadow(0 1px 1.3px rgba(123, 77, 247, 0.10))
    drop-shadow(0 0 2.6px rgba(255, 95, 162, 0.06)) !important;
}

.level-pill.level-tier-10 #playerTitle .title-name::before,
.level-pill.level-tier-rainbow #playerTitle .title-name::before {
  -webkit-text-stroke: 0.9px rgba(75, 23, 110, 0.20) !important;
}

#playerTitle .title-stars {
  -webkit-text-stroke: 0 transparent !important;
  text-shadow: none !important;
  filter: drop-shadow(0 0.7px 0.7px rgba(255, 183, 3, 0.16)) !important;
}

/* 2026-05 homepage title outline visibility fix.
   The previous back-layer outline could be hidden by stacking order on some browsers.
   Use directional drop-shadows on the rendered glyph instead: visible outside edge, no text-stroke eating into the fill. */
#playerTitle .title-name {
  -webkit-text-stroke: 0 transparent !important;
  text-shadow: none !important;
  filter:
    drop-shadow(0.5px 0 0 rgba(75, 23, 110, 0.23))
    drop-shadow(-0.5px 0 0 rgba(75, 23, 110, 0.23))
    drop-shadow(0 0.5px 0 rgba(75, 23, 110, 0.21))
    drop-shadow(0 -0.5px 0 rgba(75, 23, 110, 0.17))
    drop-shadow(0.36px 0.36px 0 rgba(75, 23, 110, 0.17))
    drop-shadow(-0.36px 0.36px 0 rgba(75, 23, 110, 0.16))
    drop-shadow(0 0.8px 0.7px rgba(255, 255, 255, 0.13)) !important;
}

#playerTitle .title-name::before {
  display: none !important;
}

.level-pill.level-tier-10 #playerTitle .title-name,
.level-pill.level-tier-rainbow #playerTitle .title-name {
  -webkit-text-stroke: 0 transparent !important;
  text-shadow: none !important;
  filter:
    drop-shadow(0.53px 0 0 rgba(75, 23, 110, 0.26))
    drop-shadow(-0.53px 0 0 rgba(75, 23, 110, 0.26))
    drop-shadow(0 0.53px 0 rgba(75, 23, 110, 0.24))
    drop-shadow(0 -0.53px 0 rgba(75, 23, 110, 0.19))
    drop-shadow(0.38px 0.38px 0 rgba(75, 23, 110, 0.19))
    drop-shadow(-0.38px 0.38px 0 rgba(75, 23, 110, 0.18))
    drop-shadow(0 0 1.5px rgba(255, 95, 162, 0.07)) !important;
}

#playerTitle .title-stars {
  -webkit-text-stroke: 0 transparent !important;
  text-shadow: none !important;
  filter:
    drop-shadow(0.8px 0 0 rgba(75, 23, 110, 0.30))
    drop-shadow(-0.8px 0 0 rgba(75, 23, 110, 0.26))
    drop-shadow(0 0.8px 0 rgba(75, 23, 110, 0.24))
    drop-shadow(0 1.2px 1px rgba(255, 183, 3, 0.20)) !important;
}


/* 2026-05 leaderboard player card: make the level style match the homepage exactly. */
.rank-detail-level-pill .title-badge .title-name {
  position: relative !important;
  display: inline-block !important;
  padding: 0 2px !important;
  -webkit-text-stroke: 0 transparent !important;
  text-shadow: none !important;
  filter:
    drop-shadow(0.5px 0 0 rgba(75, 23, 110, 0.23))
    drop-shadow(-0.5px 0 0 rgba(75, 23, 110, 0.23))
    drop-shadow(0 0.5px 0 rgba(75, 23, 110, 0.21))
    drop-shadow(0 -0.5px 0 rgba(75, 23, 110, 0.17))
    drop-shadow(0.36px 0.36px 0 rgba(75, 23, 110, 0.17))
    drop-shadow(-0.36px 0.36px 0 rgba(75, 23, 110, 0.16))
    drop-shadow(0 0.8px 0.7px rgba(255, 255, 255, 0.13)) !important;
}

.rank-detail-level-pill.level-tier-10 .title-badge .title-name,
.rank-detail-level-pill.level-tier-rainbow .title-badge .title-name {
  -webkit-text-stroke: 0 transparent !important;
  text-shadow: none !important;
  filter:
    drop-shadow(0.53px 0 0 rgba(75, 23, 110, 0.26))
    drop-shadow(-0.53px 0 0 rgba(75, 23, 110, 0.26))
    drop-shadow(0 0.53px 0 rgba(75, 23, 110, 0.24))
    drop-shadow(0 -0.53px 0 rgba(75, 23, 110, 0.19))
    drop-shadow(0.38px 0.38px 0 rgba(75, 23, 110, 0.19))
    drop-shadow(-0.38px 0.38px 0 rgba(75, 23, 110, 0.18))
    drop-shadow(0 0 1.5px rgba(255, 95, 162, 0.07)) !important;
}

.rank-detail-level-pill .title-badge .title-stars {
  -webkit-text-stroke: 0 transparent !important;
  text-shadow: none !important;
  filter: drop-shadow(0 0.7px 0.7px rgba(255, 183, 3, 0.16)) !important;
}


/* 2026-05 mobile polish: fix rank player card level alignment and completion modal layout. */
@media (max-width: 760px) {
  .modal-backdrop {
    padding: 10px !important;
    overflow-y: auto !important;
    align-items: center !important;
  }

  .rank-detail-card,
  .level-complete-card {
    width: min(94vw, 420px) !important;
    max-height: calc(100dvh - 20px) !important;
    overflow-y: auto !important;
    padding: 20px 14px 16px !important;
    border-radius: 26px !important;
  }

  .rank-detail-card .modal-sparkle,
  .level-complete-card .modal-sparkle {
    width: 44px !important;
    height: 44px !important;
    margin: -2px auto 8px !important;
    font-size: 22px !important;
  }

  .rank-detail-card h2,
  .level-complete-card h2 {
    font-size: 28px !important;
    line-height: 1.08 !important;
    margin-bottom: 4px !important;
    letter-spacing: -0.02em !important;
  }

  .rank-detail-card .eyebrow,
  .level-complete-card .eyebrow {
    margin-bottom: 4px !important;
    font-size: 11px !important;
  }

  .level-complete-card .modal-copy {
    margin: 0 auto 10px !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
  }

  .rank-detail-list {
    gap: 8px !important;
    margin: 12px 0 4px !important;
  }

  .rank-detail-list p {
    grid-template-columns: 72px minmax(0, 1fr) !important;
    gap: 8px !important;
    padding: 9px 10px !important;
    border-radius: 16px !important;
  }

  .rank-detail-list span {
    font-size: 12px !important;
    line-height: 1.2 !important;
  }

  .rank-detail-list strong {
    font-size: 14px !important;
    line-height: 1.35 !important;
  }

  .rank-detail-level-row {
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
    gap: 7px !important;
    padding: 10px !important;
  }

  .rank-detail-level-row > span {
    display: inline-flex !important;
    width: fit-content !important;
    justify-self: start !important;
    align-items: center !important;
    padding: 5px 9px !important;
    border-radius: 999px !important;
    background: rgba(255, 126, 182, 0.12) !important;
    color: #9a6d97 !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
  }

  #rankDetailLevel {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .rank-detail-level-pill {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: auto !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: nowrap !important;
    gap: 7px !important;
    padding: 10px 10px !important;
    white-space: normal !important;
    overflow: visible !important;
    text-align: center !important;
  }

  .rank-detail-level-pill .title-badge {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    gap: 5px 6px !important;
    white-space: normal !important;
    overflow: visible !important;
    text-align: center !important;
  }

  .rank-detail-level-pill .title-lollipop {
    flex: 0 0 auto !important;
  }

  .rank-detail-level-pill .title-name {
    flex: 0 1 auto !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
    line-height: 1.25 !important;
    text-align: center !important;
  }

  .rank-detail-level-pill .title-stars {
    width: 100% !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    line-height: 1.15 !important;
    text-align: center !important;
  }

  .rank-detail-level-pill > strong {
    flex: 0 0 auto !important;
    align-self: center !important;
    margin: 0 !important;
    padding: 4px 10px !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.44) !important;
    font-size: 14px !important;
    line-height: 1 !important;
  }

  .complete-score-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin: 12px 0 0 !important;
  }

  .complete-score-grid div {
    padding: 10px 9px !important;
    border-radius: 16px !important;
    text-align: center !important;
  }

  .complete-score-grid span {
    font-size: 11px !important;
    margin-bottom: 5px !important;
  }

  .complete-score-grid strong {
    font-size: 18px !important;
    line-height: 1.08 !important;
    word-break: keep-all !important;
  }

  .complete-action-row {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin-top: 12px !important;
  }

  .complete-action-row button {
    min-height: 42px !important;
    padding: 10px 8px !important;
    border-radius: 16px !important;
    font-size: 14px !important;
    line-height: 1.15 !important;
  }

  #completeNextLevel {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 380px) {
  .rank-detail-card,
  .level-complete-card {
    width: calc(100vw - 16px) !important;
    padding: 18px 12px 14px !important;
    border-radius: 22px !important;
  }

  .rank-detail-list p {
    grid-template-columns: 64px minmax(0, 1fr) !important;
  }

  .complete-score-grid,
  .complete-action-row {
    grid-template-columns: 1fr !important;
  }

  #completeNextLevel {
    grid-column: auto !important;
  }
}


/* 2026-05 mobile leaderboard detail level: one-line compact layout only, homepage unchanged. */
@media (max-width: 760px) {
  .rank-detail-level-row {
    grid-template-columns: 42px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 9px 10px !important;
  }

  .rank-detail-level-row > span {
    display: inline-flex !important;
    width: auto !important;
    justify-self: start !important;
    align-self: center !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: #9a6d97 !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  #rankDetailLevel {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  .rank-detail-level-pill {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 40px !important;
    height: 40px !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
    padding: 7px 9px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-align: left !important;
    border-radius: 999px !important;
  }

  .rank-detail-level-pill .title-badge {
    flex: 1 1 auto !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    flex-wrap: nowrap !important;
    gap: 4px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-align: left !important;
  }

  .rank-detail-level-pill .title-lollipop {
    flex: 0 0 auto !important;
    transform: scale(0.86) !important;
    transform-origin: center !important;
    margin-right: 0 !important;
  }

  .rank-detail-level-pill .title-name {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
    line-height: 1.1 !important;
    text-align: left !important;
    font-size: 12px !important;
  }

  .rank-detail-level-pill .title-stars {
    flex: 0 1 auto !important;
    width: auto !important;
    max-width: 54px !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    line-height: 1 !important;
    text-align: left !important;
    font-size: 10px !important;
    letter-spacing: -0.05em !important;
  }

  .rank-detail-level-pill > strong {
    flex: 0 0 auto !important;
    align-self: center !important;
    margin: 0 0 0 2px !important;
    padding: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    font-size: 12px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }
}

@media (max-width: 380px) {
  .rank-detail-level-row {
    grid-template-columns: 36px minmax(0, 1fr) !important;
    gap: 6px !important;
    padding: 8px 8px !important;
  }

  .rank-detail-level-row > span {
    font-size: 11px !important;
  }

  .rank-detail-level-pill {
    height: 38px !important;
    min-height: 38px !important;
    padding: 6px 7px !important;
    gap: 4px !important;
  }

  .rank-detail-level-pill .title-lollipop {
    transform: scale(0.78) !important;
  }

  .rank-detail-level-pill .title-name {
    font-size: 11px !important;
  }

  .rank-detail-level-pill .title-stars {
    max-width: 44px !important;
    font-size: 9px !important;
  }

  .rank-detail-level-pill > strong {
    font-size: 11px !important;
  }
}



.sound-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(7px, 0.75vw, 12px);
  flex-wrap: wrap;
  margin: 0 auto clamp(5px, 0.55vw, 9px);
}

.sound-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: clamp(6px, 0.62vw, 10px) clamp(12px, 1vw, 18px);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.78);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.46), 0 8px 18px rgba(148, 77, 132, 0.08);
  font-size: clamp(11px, 0.82vw, 14px);
  font-weight: 950;
  line-height: 1;
  white-space: nowrap;
  transition: transform 0.14s ease, color 0.14s ease, background 0.14s ease, box-shadow 0.14s ease;
}

.sound-toggle:hover:not(:disabled) {
  color: var(--pink-500);
  transform: translateY(-1px);
}

.sound-toggle.active {
  color: #fff;
  background: linear-gradient(135deg, var(--pink-500), var(--lavender));
  box-shadow: 0 8px 18px rgba(247, 93, 157, 0.24);
}

.sound-toggle:disabled {
  cursor: not-allowed;
  opacity: 0.62;
}

.sound-volume {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: clamp(5px, 0.55vw, 8px) clamp(10px, 0.9vw, 14px);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.42), 0 8px 18px rgba(148, 77, 132, 0.07);
  font-size: clamp(10px, 0.74vw, 12px);
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.sound-volume input {
  width: clamp(86px, 8vw, 132px);
  accent-color: var(--pink-500);
  cursor: pointer;
}

.sound-volume input:disabled {
  cursor: not-allowed;
  opacity: 0.58;
}

@media (max-width: 760px) {
  .sound-controls {
    width: 100%;
    gap: 5px;
    margin: 0 auto 5px !important;
  }

  .sound-toggle,
  .sound-volume {
    width: 100%;
    justify-content: center;
    padding: 7px 8px !important;
    font-size: 11px !important;
  }

  .sound-volume input {
    flex: 1;
    max-width: 180px;
  }
}


/* 2026-05 音效设置与词库选择同一行 */
.toolbar-controls {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: clamp(6px, 0.8vw, 12px) !important;
  flex-wrap: nowrap !important;
  width: 100% !important;
}

.toolbar-controls .word-source-switch {
  flex: 0 1 500px !important;
  width: auto !important;
  margin: clamp(4px, 0.45vw, 7px) 0 clamp(5px, 0.55vw, 9px) !important;
}

.toolbar-controls .sound-controls {
  flex: 0 0 auto !important;
  margin: clamp(4px, 0.45vw, 7px) 0 clamp(5px, 0.55vw, 9px) !important;
  flex-wrap: nowrap !important;
  justify-content: flex-start !important;
}

.toolbar-controls .sound-toggle,
.toolbar-controls .sound-volume {
  flex: 0 0 auto !important;
}

@media (max-width: 980px) {
  .toolbar-controls {
    flex-wrap: wrap !important;
  }

  .toolbar-controls .word-source-switch {
    flex: 1 1 100% !important;
    width: 100% !important;
    margin-bottom: 4px !important;
  }

  .toolbar-controls .sound-controls {
    flex: 1 1 100% !important;
    justify-content: center !important;
    margin-top: 0 !important;
  }
}

@media (max-width: 760px) {
  .toolbar-controls {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 5px !important;
  }

  .toolbar-controls .word-source-switch,
  .toolbar-controls .sound-controls {
    width: 100% !important;
    margin: 0 auto 5px !important;
  }

  .toolbar-controls .sound-controls {
    display: grid !important;
    grid-template-columns: minmax(96px, 0.8fr) minmax(0, 1.2fr) !important;
    gap: 5px !important;
  }

  .toolbar-controls .sound-toggle,
  .toolbar-controls .sound-volume {
    width: auto !important;
    min-width: 0 !important;
  }
}

/* 2026-05 删除空白引导提示：没有内容时不占位 */
.game-toolbar p#selectionPreview:empty {
  display: none !important;
}


/* Dynamic click/connection text prompts removed; game now uses copied non-voice sound effects instead. */
#selectionPreview,
#modalTip {
  display: none !important;
}

/* 2026-05 cloud account: school, QQ email, password reset and aggregate leaderboards */
.profile-school {
  margin: 7px 2px 0;
  color: var(--muted);
  font-size: clamp(11px, 0.82vw, 13px);
  font-weight: 850;
}

.leaderboard-title-row {
  align-items: center !important;
  gap: 8px !important;
}

.leaderboard-title-row h2 {
  white-space: nowrap !important;
}

.leaderboard-select {
  min-width: 0;
  width: min(100%, 220px);
  border: 1px solid rgba(255, 126, 182, 0.28);
  background: rgba(255, 255, 255, 0.88);
  color: var(--ink);
  border-radius: 999px;
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 900;
  outline: none;
}

.leaderboard-select:focus {
  border-color: var(--pink-400);
  box-shadow: 0 0 0 4px rgba(255, 126, 182, 0.16);
}

.leaderboard li.leader-entry.is-me {
  background: linear-gradient(135deg, rgba(255, 232, 244, 0.96), rgba(241, 234, 255, 0.92)) !important;
  border-color: rgba(246, 93, 157, 0.36) !important;
}

.modal-label {
  display: block;
  margin: 11px 0 6px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
  text-align: left;
}

.modal-input.text-input {
  letter-spacing: 0.02em !important;
  text-align: left !important;
  font-size: 16px !important;
}

.qq-email-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.qq-email-row span {
  border: 1px solid rgba(255, 126, 182, 0.28);
  background: rgba(255, 255, 255, 0.74);
  color: var(--pink-500);
  border-radius: 18px;
  padding: 13px 14px;
  font-size: 16px;
  font-weight: 950;
  white-space: nowrap;
}

.qq-email-input {
  margin-top: 0 !important;
}

.modal-secondary {
  width: 100% !important;
  margin-top: 10px !important;
}

.password-reset-panel {
  margin-top: 14px;
  padding: 14px;
  border: 1px dashed rgba(255, 126, 182, 0.34);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.54);
}

@media (max-width: 760px) {
  .leaderboard-title-row {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
  }

  .leaderboard-title-row h2 {
    grid-column: 1 / -1;
  }

  .leaderboard-select {
    width: 100%;
  }

  .qq-email-row {
    grid-template-columns: 1fr;
  }

  .qq-email-row span {
    text-align: center;
  }
}

/* 2026-05 account card, leaderboard selector and level badge refinements */
.profile-account-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  min-width: 0 !important;
}

.profile-card .user-code-display {
  display: inline-flex !important;
  align-items: center !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 5px 9px !important;
  border: 1px solid rgba(255, 126, 182, 0.22) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  color: var(--ink) !important;
  font-size: clamp(12px, 0.9vw, 14px) !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  letter-spacing: 0.04em !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  cursor: default !important;
  user-select: text !important;
}

.logout-btn {
  flex: 0 0 auto !important;
  border: 1px solid rgba(255, 126, 182, 0.30) !important;
  border-radius: 999px !important;
  padding: 5px 10px !important;
  background: linear-gradient(135deg, rgba(255,255,255,0.92), rgba(255,232,244,0.88)) !important;
  color: var(--pink-500) !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  cursor: pointer !important;
  box-shadow: 0 6px 14px rgba(247, 93, 157, 0.12) !important;
}

.logout-btn:hover,
.logout-btn:focus-visible {
  transform: translateY(-1px) !important;
  box-shadow: 0 10px 18px rgba(247, 93, 157, 0.18) !important;
  outline: none !important;
}

.leaderboard-title-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
}

.leaderboard-select {
  width: 100% !important;
  max-width: none !important;
}

.level-pill {
  grid-column: 1 / -1 !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 6px 10px !important;
  padding: 8px 10px !important;
  border-radius: 20px !important;
}

#playerTitle {
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  grid-template-areas:
    "icon name"
    "stars stars" !important;
  align-items: center !important;
  justify-content: start !important;
  gap: 2px 6px !important;
  overflow: hidden !important;
}

#playerTitle .title-lollipop {
  grid-area: icon !important;
}

#playerTitle .title-name {
  grid-area: name !important;
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

#playerTitle .title-stars {
  grid-area: stars !important;
  display: block !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
  font-size: 0.78em !important;
  line-height: 1 !important;
  letter-spacing: -0.02em !important;
}

#playerRank {
  justify-self: end !important;
  align-self: center !important;
  padding: 5px 9px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.55) !important;
  white-space: nowrap !important;
  line-height: 1 !important;
}

@media (max-width: 760px) {
  .profile-account-row,
  .profile-school {
    grid-column: 1 / -1 !important;
  }

  .profile-card .user-code-display {
    flex: 1 1 auto !important;
    justify-content: center !important;
    min-height: 32px !important;
  }

  .logout-btn {
    min-height: 32px !important;
    padding-inline: 12px !important;
  }

  .level-pill {
    grid-template-columns: minmax(0, 1fr) auto !important;
    padding: 9px 10px !important;
  }

  #playerTitle .title-stars {
    font-size: 0.74em !important;
    letter-spacing: -0.04em !important;
  }
}

@media (max-width: 380px) {
  .level-pill {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    text-align: center !important;
  }

  #playerTitle {
    justify-content: center !important;
  }

  #playerRank {
    justify-self: center !important;
  }
}


/* 2026-05 email edit + one-line account/level polish */
.profile-name-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 8px !important;
  min-width: 0 !important;
}

.profile-card input#playerName[readonly] {
  margin: 0 !important;
  cursor: pointer !important;
}

.profile-card input#playerName[readonly]:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 10px 20px rgba(247, 93, 157, 0.12) !important;
}

.profile-school {
  grid-column: 1 / -1 !important;
}

.compact-account-modal {
  width: min(92vw, 430px) !important;
  max-height: min(90vh, 640px) !important;
  overflow-y: auto !important;
  padding: clamp(18px, 3vw, 24px) !important;
}

.compact-account-modal h2 {
  font-size: clamp(25px, 5vw, 36px) !important;
  line-height: 1.05 !important;
  margin-bottom: 6px !important;
}

.compact-account-modal .modal-copy {
  font-size: 13px !important;
  line-height: 1.55 !important;
  margin-bottom: 8px !important;
}

.compact-account-modal .modal-label {
  margin: 8px 0 4px !important;
  font-size: 12px !important;
}

.compact-account-modal .modal-input {
  padding: 10px 12px !important;
  min-height: 42px !important;
  font-size: 15px !important;
}

.compact-account-modal .qq-email-row span {
  padding: 11px 12px !important;
  font-size: 15px !important;
}

.compact-account-modal .modal-action,
.compact-account-modal .modal-secondary {
  min-height: 42px !important;
  margin-top: 8px !important;
}

.compact-account-modal .password-reset-panel {
  margin-top: 10px !important;
  padding: 10px !important;
  border-radius: 16px !important;
}

.email-change-modal-card .modal-action-row {
  display: grid !important;
  grid-template-columns: 0.82fr 1.18fr !important;
  gap: 8px !important;
  margin-top: 12px !important;
}

.email-change-modal-card .modal-action-row button {
  min-height: 42px !important;
}

.level-pill {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  min-height: 40px !important;
  padding: 7px 9px !important;
  overflow: hidden !important;
}

#playerTitle {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  display: inline-flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 5px !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}

#playerTitle .title-lollipop {
  flex: 0 0 auto !important;
  width: 13px !important;
  height: 13px !important;
  grid-area: auto !important;
}

#playerTitle .title-name {
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: 58% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  grid-area: auto !important;
  font-size: clamp(12px, 0.9vw, 14px) !important;
}

#playerTitle .title-stars {
  flex: 0 0 auto !important;
  display: inline-block !important;
  max-width: 72px !important;
  overflow: hidden !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
  grid-area: auto !important;
  font-size: clamp(10px, 0.78vw, 12px) !important;
  line-height: 1 !important;
  letter-spacing: -0.06em !important;
}

#playerRank {
  flex: 0 0 auto !important;
  justify-self: auto !important;
  align-self: center !important;
  padding: 5px 8px !important;
  font-size: clamp(11px, 0.82vw, 13px) !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

@media (max-width: 760px) {
  .profile-name-row {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }

  .level-pill {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-items: stretch !important;
    text-align: left !important;
  }

  #playerTitle {
    justify-content: flex-start !important;
  }

  #playerTitle .title-name {
    max-width: 52% !important;
  }

  #playerTitle .title-stars {
    max-width: 58px !important;
  }

  #playerRank {
    justify-self: auto !important;
  }
}

@media (max-width: 380px) {
  .level-pill {
    display: flex !important;
    grid-template-columns: none !important;
  }

  #playerTitle .title-name {
    max-width: 46% !important;
  }

  #playerTitle .title-stars {
    max-width: 50px !important;
    font-size: 10px !important;
  }
}


/* 2026-05 profile copy/spacing polish */
.profile-card {
  grid-template-columns: auto minmax(0, 1fr) !important;
  column-gap: 5px !important;
}

.profile-card label[for="playerName"] {
  margin-right: 0 !important;
  white-space: nowrap !important;
}

.profile-name-row {
  gap: 6px !important;
}

.profile-school {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  justify-self: stretch !important;
  min-width: 0 !important;
  margin: 2px 0 0 !important;
  padding: 5px 9px !important;
  border: 1px solid rgba(255, 126, 182, 0.20) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.58) !important;
  color: var(--pink-500) !important;
  font-size: clamp(11px, 0.78vw, 13px) !important;
  font-weight: 950 !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.compact-account-modal .modal-copy:empty,
.hero-description.hidden,
.panel-card .hint.hidden {
  display: none !important;
}

@media (max-width: 760px) {
  .profile-card {
    grid-template-columns: auto minmax(0, 1fr) !important;
    column-gap: 5px !important;
  }
}

/* 2026-05 简洁账号弹窗：登录 / 注册 / 找回密码分离 */
.auth-switch {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
  margin: 8px 0 12px;
  padding: 5px;
  border-radius: 999px;
  background: rgba(255, 232, 244, 0.72);
  border: 1px solid rgba(255, 126, 182, 0.18);
}

.auth-tab {
  border: 0;
  border-radius: 999px;
  padding: 9px 8px;
  background: transparent;
  color: var(--muted);
  font-size: 13px;
  font-weight: 950;
  cursor: pointer;
  transition: transform 0.16s ease, background 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

.auth-tab:hover {
  transform: translateY(-1px);
  color: var(--pink-500);
}

.auth-tab.active {
  background: rgba(255, 255, 255, 0.94);
  color: var(--pink-600);
  box-shadow: 0 8px 18px rgba(247, 93, 157, 0.14);
}

.auth-field {
  margin: 0;
}

.compact-account-modal.auth-mode-login .auth-register-only,
.compact-account-modal.auth-mode-login .auth-register-reset-only,
.compact-account-modal.auth-mode-login .auth-reset-only,
.compact-account-modal.auth-mode-login .auth-reset-action,
.compact-account-modal.auth-mode-register .auth-reset-only,
.compact-account-modal.auth-mode-register .auth-reset-action,
.compact-account-modal.auth-mode-reset .auth-register-only,
.compact-account-modal.auth-mode-reset .auth-login-register-action {
  display: none !important;
}

.compact-account-modal.auth-mode-reset .auth-reset-only,
.compact-account-modal.auth-mode-reset .auth-reset-action,
.compact-account-modal.auth-mode-register .auth-register-only,
.compact-account-modal.auth-mode-register .auth-register-reset-only {
  display: block !important;
}

.compact-account-modal.auth-mode-register .auth-register-reset-only,
.compact-account-modal.auth-mode-reset .auth-register-reset-only {
  display: block !important;
}

.compact-account-modal.auth-mode-login {
  max-height: min(90vh, 470px) !important;
}

.compact-account-modal.auth-mode-register {
  max-height: min(90vh, 610px) !important;
}

.compact-account-modal.auth-mode-reset {
  max-height: min(90vh, 560px) !important;
}

.compact-account-modal.auth-mode-reset .password-reset-panel {
  margin-top: 6px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.compact-account-modal.auth-mode-reset #requestPasswordReset {
  margin-top: 10px !important;
}

.compact-account-modal.auth-mode-reset #confirmPasswordReset {
  margin-top: 8px !important;
}

/* 2026-05 compact reset/register/profile/leaderboard polish */
.profile-card {
  grid-template-columns: auto minmax(0, 1fr) !important;
  column-gap: 4px !important;
  row-gap: 5px !important;
}

.profile-card label#profileSchoolLabel,
.profile-card label[for="playerName"] {
  max-width: 118px !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  margin: 0 !important;
  color: var(--pink-500) !important;
  font-size: clamp(12px, 0.9vw, 14px) !important;
  font-weight: 950 !important;
}

.profile-name-row {
  gap: 5px !important;
}

.profile-school,
#profileSchool {
  display: none !important;
}

.compact-account-modal.auth-mode-register {
  max-height: min(90vh, 650px) !important;
}

.compact-account-modal.auth-mode-reset {
  max-height: min(90vh, 500px) !important;
  padding: clamp(15px, 2.5vw, 20px) !important;
}

.compact-account-modal.auth-mode-reset .auth-switch {
  margin-bottom: 8px !important;
}

.compact-account-modal.auth-mode-reset .modal-label {
  margin: 6px 0 3px !important;
}

.compact-account-modal.auth-mode-reset .modal-input {
  min-height: 38px !important;
  padding: 8px 10px !important;
}

.compact-account-modal.auth-mode-reset .qq-email-row span {
  padding: 9px 10px !important;
}

.compact-account-modal.auth-mode-reset .password-reset-panel {
  margin-top: 8px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.reset-inline-row {
  display: grid !important;
  grid-template-columns: minmax(78px, 0.78fr) minmax(70px, 0.7fr) minmax(78px, 0.82fr) !important;
  align-items: stretch !important;
  gap: 6px !important;
}

.reset-inline-row .modal-input,
.reset-inline-row .modal-action,
.reset-inline-row .modal-secondary {
  width: 100% !important;
  min-height: 38px !important;
  margin: 0 !important;
  padding: 7px 8px !important;
  border-radius: 14px !important;
  font-size: 12px !important;
  line-height: 1.05 !important;
}

.compact-account-modal.auth-mode-reset .auth-reset-action {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.reset-code-input {
  text-align: center !important;
  letter-spacing: 0.04em !important;
}

.compact-account-modal.auth-mode-reset #requestPasswordReset,
.compact-account-modal.auth-mode-reset #confirmPasswordReset {
  margin-top: 0 !important;
}

.leaderboard li.leaderboard-head,
.leaderboard li.leader-entry {
  grid-template-columns: minmax(0, 1fr) minmax(64px, auto) minmax(58px, auto) !important;
  min-width: 0 !important;
}

.leaderboard li.leaderboard-head > span,
.leaderboard .leader-rank,
.leaderboard .leader-time,
.leaderboard .leader-score {
  min-width: 0 !important;
}

.leaderboard .leader-rank {
  display: inline-flex !important;
  align-items: center !important;
  gap: 3px !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}

.leaderboard .leader-rank-text {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.leaderboard .rank-medal {
  flex: 0 0 auto !important;
  margin-right: 1px !important;
}

.leaderboard .leader-time,
.leaderboard .leader-score {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  text-align: right !important;
  justify-self: end !important;
  max-width: 100% !important;
}

@media (max-width: 760px) {
  .profile-card label#profileSchoolLabel,
  .profile-card label[for="playerName"] {
    max-width: 96px !important;
  }

  .reset-inline-row {
    grid-template-columns: minmax(72px, 0.74fr) minmax(68px, 0.7fr) minmax(76px, 0.8fr) !important;
    gap: 5px !important;
  }

  .reset-inline-row .modal-input,
  .reset-inline-row .modal-action,
  .reset-inline-row .modal-secondary {
    font-size: 11px !important;
    padding-inline: 6px !important;
  }

  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1fr) minmax(62px, auto) minmax(56px, auto) !important;
    column-gap: 6px !important;
  }
}

/* 2026-05 account verification/profile edit compact polish */
.profile-card {
  grid-template-columns: minmax(0, 1fr) !important;
  row-gap: 6px !important;
}

.profile-card label#profileSchoolLabel,
.profile-card label[for="playerName"] {
  display: none !important;
}

.profile-name-row {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 6px !important;
  align-items: center !important;
}

.profile-card input#playerName[readonly] {
  min-width: 0 !important;
  width: 100% !important;
  text-align: left !important;
  padding-inline: 13px !important;
  font-size: clamp(12px, 0.92vw, 14px) !important;
  letter-spacing: 0.01em !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.logout-btn {
  min-height: 34px !important;
  padding: 6px 10px !important;
}

.compact-account-modal {
  width: min(92vw, 410px) !important;
  padding: clamp(14px, 2.4vw, 20px) !important;
}

.compact-account-modal h2 {
  font-size: clamp(22px, 4.6vw, 31px) !important;
  margin-bottom: 5px !important;
}

.auth-switch {
  margin: 6px 0 9px !important;
  gap: 5px !important;
  padding: 4px !important;
}

.auth-tab {
  padding: 7px 6px !important;
  font-size: 12px !important;
}

.compact-account-modal .modal-label {
  margin: 5px 0 3px !important;
  font-size: 12px !important;
}

.compact-account-modal .modal-input {
  min-height: 36px !important;
  padding: 8px 10px !important;
  font-size: 14px !important;
}

.compact-account-modal .qq-email-row {
  gap: 6px !important;
}

.compact-account-modal .qq-email-row span {
  min-height: 36px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 8px 10px !important;
  font-size: 13px !important;
}

.compact-account-modal.auth-mode-login .auth-register-only,
.compact-account-modal.auth-mode-login .auth-register-reset-only,
.compact-account-modal.auth-mode-login .auth-register-reset-password-only,
.compact-account-modal.auth-mode-login .auth-register-action,
.compact-account-modal.auth-mode-login .auth-reset-only,
.compact-account-modal.auth-mode-login .auth-reset-action,
.compact-account-modal.auth-mode-register .auth-reset-only,
.compact-account-modal.auth-mode-register .auth-reset-action,
.compact-account-modal.auth-mode-register .auth-login-action,
.compact-account-modal.auth-mode-reset .auth-register-only,
.compact-account-modal.auth-mode-reset .auth-register-action,
.compact-account-modal.auth-mode-reset .auth-login-action {
  display: none !important;
}

.compact-account-modal.auth-mode-register .auth-register-only,
.compact-account-modal.auth-mode-register .auth-register-reset-only,
.compact-account-modal.auth-mode-register .auth-register-reset-password-only,
.compact-account-modal.auth-mode-register .auth-register-action,
.compact-account-modal.auth-mode-reset .auth-register-reset-only,
.compact-account-modal.auth-mode-reset .auth-register-reset-password-only,
.compact-account-modal.auth-mode-reset .auth-reset-only,
.compact-account-modal.auth-mode-reset .auth-reset-action {
  display: block !important;
}

.compact-account-modal.auth-mode-register {
  max-height: min(90vh, 600px) !important;
}

.compact-account-modal.auth-mode-reset {
  max-height: min(90vh, 540px) !important;
}

.register-verify-panel,
.password-reset-panel {
  margin-top: 8px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.verify-inline-row {
  display: grid !important;
  grid-template-columns: minmax(82px, 0.78fr) minmax(76px, 0.72fr) minmax(82px, 0.82fr) !important;
  align-items: stretch !important;
  gap: 6px !important;
}

.verify-inline-row .modal-input,
.verify-inline-row .modal-action,
.verify-inline-row .modal-secondary {
  width: 100% !important;
  min-height: 36px !important;
  margin: 0 !important;
  padding: 7px 8px !important;
  border-radius: 14px !important;
  font-size: 12px !important;
  line-height: 1.05 !important;
}

.verify-code-input {
  text-align: center !important;
  letter-spacing: 0.04em !important;
}

.profile-edit-modal-card {
  width: min(92vw, 440px) !important;
  max-height: min(90vh, 560px) !important;
}

.profile-edit-grid {
  display: grid !important;
  gap: 7px !important;
}

.profile-edit-field .modal-label {
  margin-top: 4px !important;
}

.compact-qq-row {
  grid-template-columns: minmax(0, 1fr) auto !important;
}

.profile-verify-row {
  display: grid !important;
  grid-template-columns: minmax(94px, 1fr) minmax(92px, auto) !important;
  gap: 7px !important;
  margin-top: 9px !important;
}

.profile-verify-row .modal-input,
.profile-verify-row .modal-secondary {
  min-height: 38px !important;
  margin: 0 !important;
  border-radius: 14px !important;
  font-size: 12px !important;
}

.email-change-modal-card .modal-action-row {
  grid-template-columns: 0.8fr 1.2fr !important;
  gap: 7px !important;
  margin-top: 10px !important;
}

.email-change-modal-card .modal-action-row button {
  min-height: 38px !important;
}

@media (max-width: 420px) {
  .verify-inline-row,
  .profile-verify-row {
    grid-template-columns: 1fr !important;
  }

  .compact-account-modal .qq-email-row,
  .compact-qq-row {
    grid-template-columns: 1fr auto !important;
  }
}

/* 本次优化：找回密码底部三项始终保持一行，个人资料窗口更紧凑 */
.password-reset-panel .verify-inline-row,
.reset-inline-row {
  grid-template-columns: minmax(72px, 0.8fr) minmax(72px, 0.76fr) minmax(54px, 0.58fr) !important;
  gap: 5px !important;
}

.reset-inline-row .modal-input,
.reset-inline-row .modal-action,
.reset-inline-row .modal-secondary {
  min-width: 0 !important;
  padding-left: 5px !important;
  padding-right: 5px !important;
  font-size: 11px !important;
  letter-spacing: 0 !important;
}

.reset-inline-row .verify-code-input {
  font-size: 12px !important;
}

.profile-edit-modal-card {
  width: min(92vw, 430px) !important;
  max-height: min(90vh, 600px) !important;
  padding: clamp(14px, 2.4vw, 19px) !important;
}

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

.current-email-display {
  background: rgba(255, 255, 255, 0.58) !important;
  color: var(--muted) !important;
  cursor: default !important;
}

.email-change-modal-card .modal-copy {
  margin: 3px 0 6px !important;
  font-size: 12px !important;
}

.email-change-modal-card .profile-edit-field .modal-label {
  margin: 3px 0 2px !important;
}

.email-change-modal-card .modal-input,
.email-change-modal-card .qq-email-row span {
  min-height: 35px !important;
  padding-top: 7px !important;
  padding-bottom: 7px !important;
}

@media (max-width: 420px) {
  .verify-inline-row,
  .password-reset-panel .verify-inline-row,
  .reset-inline-row,
  .register-inline-row {
    grid-template-columns: minmax(62px, 0.76fr) minmax(62px, 0.76fr) minmax(48px, 0.58fr) !important;
    gap: 4px !important;
  }

  .verify-inline-row .modal-input,
  .verify-inline-row .modal-action,
  .verify-inline-row .modal-secondary {
    font-size: 10.5px !important;
    padding-left: 4px !important;
    padding-right: 4px !important;
  }

  .profile-verify-row {
    grid-template-columns: 1fr !important;
  }
}


/* 2026-05 leaderboard fixed-column alignment + no-link MarLous */
.leaderboard li.leaderboard-head,
.leaderboard li.leader-entry {
  grid-template-columns: minmax(0, 1fr) 82px 70px !important;
  column-gap: 8px !important;
  width: 100% !important;
}

.leaderboard li.leaderboard-head > span,
.leaderboard li.leader-entry > span,
.leaderboard li.leader-entry > strong {
  min-width: 0 !important;
}

.leaderboard .leader-head-rank,
.leaderboard .leader-rank {
  justify-self: stretch !important;
  width: 100% !important;
  text-align: left !important;
}

.leaderboard .leader-head-value,
.leaderboard .leader-head-extra,
.leaderboard .leader-time,
.leaderboard .leader-score {
  justify-self: stretch !important;
  width: 100% !important;
  text-align: right !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
  white-space: nowrap !important;
}

.leaderboard .leader-rank {
  display: inline-flex !important;
  align-items: center !important;
  gap: 3px !important;
  overflow: hidden !important;
}

.leaderboard .leader-rank-text {
  display: block !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.leaderboard .rank-medal {
  flex: 0 0 auto !important;
}

.marlous-link {
  cursor: default !important;
  pointer-events: none !important;
}

@media (max-width: 760px) {
  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1fr) 74px 60px !important;
    column-gap: 6px !important;
  }

  .leaderboard li.leaderboard-head {
    font-size: 11px !important;
  }

  .leaderboard .leader-time,
  .leaderboard .leader-score {
    font-size: 13px !important;
  }
}

/* 2026-05 leaderboard source tabs, two-hour auto refresh and strict column alignment */
.leaderboard-title-row {
  display: grid !important;
  grid-template-columns: minmax(104px, 0.68fr) minmax(0, 1.32fr) !important;
  gap: 8px !important;
  align-items: center !important;
}

.leaderboard-title-row .mini-btn,
#clearRanks {
  display: none !important;
}

.leaderboard-source-select,
.leaderboard-type-select {
  width: 100% !important;
  min-width: 0 !important;
}

.leaderboard li.leaderboard-head,
.leaderboard li.leader-entry {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 9.5ch 7ch !important;
  align-items: center !important;
  column-gap: 10px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.leaderboard li.leaderboard-head > span,
.leaderboard li.leader-entry > span,
.leaderboard li.leader-entry > strong {
  min-width: 0 !important;
  max-width: 100% !important;
}

.leaderboard .leader-head-rank,
.leaderboard .leader-rank {
  justify-self: stretch !important;
  width: 100% !important;
  overflow: hidden !important;
  text-align: left !important;
}

.leaderboard .leader-rank {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  white-space: nowrap !important;
}

.leaderboard .rank-medal {
  flex: 0 0 1.45em !important;
  width: 1.45em !important;
  min-width: 1.45em !important;
  margin: 0 !important;
  text-align: center !important;
}

.leaderboard .leader-rank-text {
  display: block !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.leaderboard .leader-head-value,
.leaderboard .leader-head-extra,
.leaderboard .leader-time,
.leaderboard .leader-score {
  justify-self: stretch !important;
  width: 100% !important;
  overflow: hidden !important;
  text-align: right !important;
  white-space: nowrap !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

.leaderboard .leader-time,
.leaderboard .leader-score {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace !important;
  letter-spacing: -0.02em !important;
  text-overflow: clip !important;
}

@media (max-width: 760px) {
  .leaderboard-title-row {
    grid-template-columns: 1fr !important;
    gap: 6px !important;
  }

  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1fr) 8.5ch 6ch !important;
    column-gap: 7px !important;
  }
}

/* 2026-05 auto CET leaderboard source + safe remembered accounts */
.compact-account-modal.auth-mode-register .auth-login-only,
.compact-account-modal.auth-mode-reset .auth-login-only {
  display: none !important;
}

.compact-account-modal.auth-mode-login .remember-account-row {
  display: inline-flex !important;
}

.remember-account-row {
  align-items: center !important;
  gap: 6px !important;
  width: fit-content !important;
  max-width: 100% !important;
  margin-top: -2px !important;
  color: var(--muted) !important;
  font-size: 12px !important;
  line-height: 1 !important;
  cursor: pointer !important;
  user-select: none !important;
}

.remember-account-row input {
  width: 14px !important;
  height: 14px !important;
  accent-color: var(--pink-500) !important;
}

.leaderboard-title-row {
  display: block !important;
}

.leaderboard-title-row .leaderboard-type-select {
  width: 100% !important;
}

.leaderboard-source-select {
  display: none !important;
}

.leaderboard li.leaderboard-head,
.leaderboard li.leader-entry {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 10ch 7ch !important;
  align-items: center !important;
  column-gap: 10px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.leaderboard li.leaderboard-head > span,
.leaderboard li.leader-entry > span,
.leaderboard li.leader-entry > strong {
  min-width: 0 !important;
  max-width: 100% !important;
}

.leaderboard .leader-head-rank,
.leaderboard .leader-rank {
  grid-column: 1 !important;
  justify-self: stretch !important;
  width: 100% !important;
  min-width: 0 !important;
  text-align: left !important;
  overflow: hidden !important;
}

.leaderboard .leader-head-value,
.leaderboard .leader-time {
  grid-column: 2 !important;
  justify-self: end !important;
  width: 10ch !important;
  min-width: 10ch !important;
  text-align: right !important;
}

.leaderboard .leader-head-extra,
.leaderboard .leader-score {
  grid-column: 3 !important;
  justify-self: end !important;
  width: 7ch !important;
  min-width: 7ch !important;
  text-align: right !important;
}

.leaderboard .leader-time,
.leaderboard .leader-score,
.leaderboard .leader-time-value,
.leaderboard .leader-count-value {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

.leaderboard .leader-time-value {
  display: inline-block !important;
  width: 10ch !important;
  text-align: right !important;
  white-space: nowrap !important;
}

.leaderboard .leader-score {
  display: inline-flex !important;
  justify-content: flex-end !important;
  align-items: baseline !important;
  gap: 1px !important;
  white-space: nowrap !important;
}

.leaderboard .leader-count-value {
  display: inline-block !important;
  min-width: 4ch !important;
  text-align: right !important;
}

.leaderboard .leader-count-unit {
  flex: 0 0 auto !important;
  font-family: inherit !important;
}

.leaderboard .leader-rank {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  white-space: nowrap !important;
}

.leaderboard .rank-medal {
  flex: 0 0 1.45em !important;
  width: 1.45em !important;
  min-width: 1.45em !important;
  margin: 0 !important;
  text-align: center !important;
}

.leaderboard .leader-rank-text {
  display: block !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

@media (max-width: 760px) {
  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1fr) 9ch 6.5ch !important;
    column-gap: 7px !important;
  }

  .leaderboard .leader-head-value,
  .leaderboard .leader-time,
  .leaderboard .leader-time-value {
    width: 9ch !important;
    min-width: 9ch !important;
  }

  .leaderboard .leader-head-extra,
  .leaderboard .leader-score {
    width: 6.5ch !important;
    min-width: 6.5ch !important;
  }

  .leaderboard .leader-count-value {
    min-width: 3.5ch !important;
  }
}

/* 2026-05 final: CET-synced leaderboard columns, live nickname tier styling and feedback panel */
.leaderboard li.leaderboard-head,
.leaderboard li.leader-entry {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 96px 68px !important;
  align-items: center !important;
  column-gap: 10px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.leaderboard .leader-head-rank,
.leaderboard .leader-rank {
  grid-column: 1 !important;
  min-width: 0 !important;
  width: 100% !important;
  justify-self: stretch !important;
  text-align: left !important;
  overflow: hidden !important;
}

.leaderboard .leader-head-value,
.leaderboard .leader-time {
  grid-column: 2 !important;
  justify-self: end !important;
  width: 96px !important;
  min-width: 96px !important;
  max-width: 96px !important;
  text-align: right !important;
}

.leaderboard .leader-head-extra,
.leaderboard .leader-score {
  grid-column: 3 !important;
  justify-self: end !important;
  width: 68px !important;
  min-width: 68px !important;
  max-width: 68px !important;
  text-align: right !important;
}

.leaderboard .leader-time,
.leaderboard .leader-score,
.leaderboard .leader-time-value,
.leaderboard .leader-count-value {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
  letter-spacing: 0 !important;
}

.leaderboard .leader-time-value {
  display: inline-block !important;
  width: 96px !important;
  min-width: 96px !important;
  text-align: right !important;
  white-space: nowrap !important;
}

.leaderboard .leader-score {
  display: inline-flex !important;
  justify-content: flex-end !important;
  align-items: baseline !important;
  white-space: nowrap !important;
  gap: 1px !important;
}

.leaderboard .leader-count-value {
  display: inline-block !important;
  min-width: 42px !important;
  text-align: right !important;
}

.leaderboard .leader-count-unit {
  flex: 0 0 auto !important;
}

.profile-card input#playerName[readonly] {
  color: var(--level-color, var(--ink)) !important;
  font-weight: 950 !important;
  letter-spacing: 0.035em !important;
  text-shadow: 0 2px 10px color-mix(in srgb, var(--level-color, #ff7ab6) 34%, transparent) !important;
  border-color: color-mix(in srgb, var(--level-color, #ff7ab6) 34%, rgba(255, 255, 255, 0.4)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.55), 0 10px 20px color-mix(in srgb, var(--level-color, #ff7ab6) 12%, transparent) !important;
}

.profile-card input#playerName[readonly].level-tier-rainbow {
  color: #ff4fa0 !important;
  text-shadow: 0 0 8px rgba(255, 125, 210, 0.35), 0 0 14px rgba(126, 227, 255, 0.26) !important;
}

.profile-edit-panel.hidden,
.feedback-panel.hidden {
  display: none !important;
}

.profile-action-row {
  grid-template-columns: 0.95fr 0.75fr 1fr !important;
}

.feedback-panel {
  display: grid !important;
  gap: 8px !important;
}

.feedback-textarea {
  height: 115px !important;
  min-height: 115px !important;
  max-height: none !important;
  resize: vertical !important;
  line-height: 1.55 !important;
  font-size: 13px !important;
}

.feedback-action-row {
  grid-template-columns: 0.8fr 1.2fr !important;
  gap: 8px !important;
  margin-top: 4px !important;
}

@media (max-width: 760px) {
  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1fr) 86px 60px !important;
    column-gap: 7px !important;
  }

  .leaderboard .leader-head-value,
  .leaderboard .leader-time,
  .leaderboard .leader-time-value {
    width: 86px !important;
    min-width: 86px !important;
    max-width: 86px !important;
  }

  .leaderboard .leader-head-extra,
  .leaderboard .leader-score {
    width: 60px !important;
    min-width: 60px !important;
    max-width: 60px !important;
  }

  .leaderboard .leader-count-value {
    min-width: 34px !important;
  }

  .profile-action-row {
    grid-template-columns: 1fr !important;
  }
}


/* 2026-05 login row polish + remove special-account layout dependency */
.compact-account-modal.auth-mode-login .auth-login-row {
  display: grid !important;
  grid-template-columns: max-content minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 10px !important;
  margin-top: 8px !important;
}

.compact-account-modal.auth-mode-register .auth-login-row,
.compact-account-modal.auth-mode-reset .auth-login-row {
  display: none !important;
}

.auth-login-row .remember-account-row {
  display: inline-flex !important;
  margin: 0 !important;
  white-space: nowrap !important;
}

.auth-login-row .modal-action {
  width: 100% !important;
  margin: 0 !important;
}

@media (max-width: 420px) {
  .compact-account-modal.auth-mode-login .auth-login-row {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .auth-login-row .remember-account-row {
    justify-self: start !important;
  }
}

/* 2026-05 delayed account login + rounded-rectangle nickname capsule */
.profile-name-row {
  grid-template-columns: minmax(150px, max-content) auto !important;
  justify-content: start !important;
  gap: 8px !important;
}

.profile-card input#playerName[readonly] {
  width: clamp(152px, 24ch, 292px) !important;
  max-width: 100% !important;
  min-height: 34px !important;
  padding: 7px 13px !important;
  border-radius: 16px !important;
  text-align: left !important;
  background: linear-gradient(135deg, rgba(255,255,255,0.94), color-mix(in srgb, var(--level-color, #ff7ab6) 10%, #fff 90%)) !important;
}

.profile-card input#playerName[readonly]::placeholder {
  color: color-mix(in srgb, var(--level-color, #ff7ab6) 72%, var(--muted)) !important;
  opacity: 0.9 !important;
}

@media (max-width: 520px) {
  .profile-name-row {
    grid-template-columns: minmax(0, 1fr) auto !important;
    justify-content: stretch !important;
  }

  .profile-card input#playerName[readonly] {
    width: 100% !important;
  }
}


/* 2026-05 profile row width + per-level best stat polish */
.profile-card {
  align-items: stretch !important;
}

.profile-name-row,
.profile-card > .level-pill,
.profile-card > .mode-switch {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  max-width: 100% !important;
  justify-self: stretch !important;
  box-sizing: border-box !important;
}

.profile-name-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  justify-content: stretch !important;
  align-items: center !important;
  gap: 8px !important;
}

.profile-card input#playerName[readonly] {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  border-radius: 16px !important;
}

.logout-btn.hidden + *,
.profile-name-row .logout-btn.hidden {
  display: none !important;
}

.stat-card small#bestTime,
.stat-card small#mistakes {
  min-height: 1.15em !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.stat-card small#bestTime {
  color: var(--pink-500) !important;
  font-weight: 900 !important;
}

.stat-card small#mistakes {
  color: var(--muted) !important;
}

@media (max-width: 520px) {
  .profile-name-row {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }
}

/* 2026-05 best-stat chips + distinct nickname capsule polish */
.stat-card small.best-stat-chip,
.stat-card small#bestTime,
.stat-card small#mistakes {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  width: fit-content !important;
  max-width: 100% !important;
  min-height: 26px !important;
  margin: 8px auto 0 !important;
  padding: 4px 9px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 126, 182, 0.20) !important;
  background: linear-gradient(135deg, rgba(255,255,255,0.82), rgba(255, 232, 244, 0.72)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.74), 0 6px 14px rgba(255, 126, 182, 0.10) !important;
  color: var(--ink) !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.stat-card small.best-score-chip,
.stat-card small#mistakes {
  border-color: rgba(153, 102, 204, 0.18) !important;
  background: linear-gradient(135deg, rgba(255,255,255,0.84), rgba(242, 235, 255, 0.72)) !important;
}

.best-stat-label {
  flex: 0 0 auto !important;
  color: var(--muted) !important;
  font-size: 10px !important;
  font-weight: 850 !important;
  letter-spacing: 0.02em !important;
}

.best-stat-value {
  flex: 0 0 auto !important;
  color: var(--pink-600, #ef4f9a) !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

.best-score-chip .best-stat-value,
#mistakes .best-stat-value {
  color: #7b4df7 !important;
}

.best-stat-sub {
  flex: 0 0 auto !important;
  color: var(--muted) !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  padding-left: 6px !important;
  border-left: 1px solid rgba(153, 102, 204, 0.16) !important;
}

.profile-card input#playerName[readonly] {
  cursor: pointer !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  height: 38px !important;
  min-height: 38px !important;
  padding: 8px 14px !important;
  border-radius: 14px !important;
  border: 1.5px solid color-mix(in srgb, var(--level-color, #ff7ab6) 42%, rgba(255,255,255,0.75)) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,255,255,0.74)) padding-box,
    linear-gradient(135deg, color-mix(in srgb, var(--level-color, #ff7ab6) 58%, #ffffff 42%), rgba(255,255,255,0.55)) border-box !important;
  color: color-mix(in srgb, var(--level-color, #ff7ab6) 70%, #3d2447 30%) !important;
  -webkit-text-fill-color: color-mix(in srgb, var(--level-color, #ff7ab6) 70%, #3d2447 30%) !important;
  font-weight: 950 !important;
  letter-spacing: 0.015em !important;
  text-shadow: none !important;
  -webkit-text-stroke: 0 transparent !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.88),
    0 9px 18px color-mix(in srgb, var(--level-color, #ff7ab6) 16%, transparent) !important;
}

.profile-card input#playerName[readonly]:hover,
.profile-card input#playerName[readonly]:focus-visible {
  transform: translateY(-1px) !important;
  border-color: color-mix(in srgb, var(--level-color, #ff7ab6) 58%, rgba(255,255,255,0.65)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.9),
    0 12px 22px color-mix(in srgb, var(--level-color, #ff7ab6) 20%, transparent),
    0 0 0 3px color-mix(in srgb, var(--level-color, #ff7ab6) 13%, transparent) !important;
}

.profile-card input#playerName[readonly].level-tier-10,
.profile-card input#playerName[readonly].level-tier-rainbow {
  color: #6d4af7 !important;
  -webkit-text-fill-color: #6d4af7 !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246, 240, 255, 0.78)) padding-box,
    linear-gradient(120deg, #ff7eb6, #ffd76a, #7ee3ff, #a987ff, #ff7eb6) border-box !important;
  border-color: transparent !important;
  text-shadow: none !important;
}

@media (max-width: 520px) {
  .stat-card small.best-stat-chip,
  .stat-card small#bestTime,
  .stat-card small#mistakes {
    gap: 5px !important;
    padding-inline: 7px !important;
  }

  .best-stat-label,
  .best-stat-sub {
    font-size: 9px !important;
  }

  .best-stat-value {
    font-size: 11px !important;
  }
}

/* 2026-05 fixed red-purple nickname capsule: only the nickname text follows the current level style. */
.profile-card input#playerName[readonly] {
  border: 1.5px solid rgba(255, 255, 255, 0.58) !important;
  background: linear-gradient(135deg, #ff5d83 0%, #e14ac4 50%, #7d4cff 100%) !important;
  color: var(--level-color, #ffffff) !important;
  -webkit-text-fill-color: var(--level-color, #ffffff) !important;
  text-shadow:
    0 1px 2px rgba(54, 7, 82, 0.34),
    0 0 7px rgba(255, 255, 255, 0.24) !important;
  -webkit-text-stroke: 0.12px rgba(255, 255, 255, 0.42) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.38),
    inset 0 -1px 0 rgba(88, 20, 125, 0.16),
    0 10px 22px rgba(177, 57, 171, 0.22) !important;
}

.profile-card input#playerName[readonly]:hover,
.profile-card input#playerName[readonly]:focus,
.profile-card input#playerName[readonly]:focus-visible {
  border-color: rgba(255, 255, 255, 0.72) !important;
  background: linear-gradient(135deg, #ff5d83 0%, #e14ac4 50%, #7d4cff 100%) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.44),
    inset 0 -1px 0 rgba(88, 20, 125, 0.18),
    0 12px 25px rgba(177, 57, 171, 0.26),
    0 0 0 3px rgba(255, 126, 182, 0.14) !important;
}

.profile-card input#playerName[readonly].level-tier-10,
.profile-card input#playerName[readonly].level-tier-rainbow {
  border-color: rgba(255, 255, 255, 0.66) !important;
  background: linear-gradient(135deg, #ff5d83 0%, #e14ac4 50%, #7d4cff 100%) !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  text-shadow:
    0 1px 2px rgba(54, 7, 82, 0.34),
    0 0 8px rgba(255, 225, 122, 0.34),
    0 0 14px rgba(126, 227, 255, 0.26) !important;
}

/* 2026-05 request: lighter fixed nickname capsule + inline best stats beside the main numbers. */
.stat-value-line {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: 100% !important;
  min-width: 0 !important;
  margin-top: 2px !important;
}

.stat-value-line strong {
  flex: 0 0 auto !important;
  margin: 0 !important;
}

.stat-value-line .best-stat-chip,
.stat-value-line small#bestTime,
.stat-value-line small#mistakes {
  display: inline-flex !important;
  flex: 0 1 auto !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  width: auto !important;
  max-width: min(168px, 52%) !important;
  min-height: 28px !important;
  margin: 0 !important;
  padding: 5px 8px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 111, 166, 0.32) !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(255, 236, 246, 0.86)) padding-box,
    linear-gradient(135deg, rgba(255, 93, 131, 0.38), rgba(225, 74, 196, 0.24), rgba(125, 76, 255, 0.28)) border-box !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.78), 0 5px 12px rgba(255, 93, 131, 0.12) !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.stat-value-line .best-score-chip,
.stat-value-line small#mistakes {
  border-color: rgba(125, 76, 255, 0.30) !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(244, 238, 255, 0.88)) padding-box,
    linear-gradient(135deg, rgba(255, 93, 131, 0.22), rgba(225, 74, 196, 0.26), rgba(125, 76, 255, 0.36)) border-box !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.80), 0 5px 12px rgba(125, 76, 255, 0.12) !important;
}

.stat-value-line .best-stat-label {
  flex: 0 0 auto !important;
  color: #a33b76 !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  letter-spacing: 0 !important;
}

.stat-value-line .best-stat-value {
  flex: 0 0 auto !important;
  color: #ff3f94 !important;
  font-size: 15px !important;
  font-weight: 1000 !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

.stat-value-line .best-score-chip .best-stat-value,
.stat-value-line #mistakes .best-stat-value {
  color: #7651f3 !important;
}

.stat-value-line .best-stat-sub {
  flex: 0 0 auto !important;
  color: #8b6b9c !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  padding-left: 5px !important;
  border-left: 1px solid rgba(125, 76, 255, 0.18) !important;
}

.profile-card input#playerName[readonly] {
  background: linear-gradient(135deg, rgba(255, 93, 131, 0.35) 0%, rgba(225, 74, 196, 0.35) 50%, rgba(125, 76, 255, 0.35) 100%) !important;
  border-color: rgba(255, 255, 255, 0.62) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.42),
    inset 0 -1px 0 rgba(88, 20, 125, 0.10),
    0 8px 18px rgba(177, 57, 171, 0.12) !important;
}

.profile-card input#playerName[readonly]:hover,
.profile-card input#playerName[readonly]:focus,
.profile-card input#playerName[readonly]:focus-visible,
.profile-card input#playerName[readonly].level-tier-10,
.profile-card input#playerName[readonly].level-tier-rainbow {
  background: linear-gradient(135deg, rgba(255, 93, 131, 0.35) 0%, rgba(225, 74, 196, 0.35) 50%, rgba(125, 76, 255, 0.35) 100%) !important;
}

.profile-card input#playerName[readonly]:hover,
.profile-card input#playerName[readonly]:focus,
.profile-card input#playerName[readonly]:focus-visible {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.48),
    inset 0 -1px 0 rgba(88, 20, 125, 0.12),
    0 10px 22px rgba(177, 57, 171, 0.16),
    0 0 0 3px rgba(255, 126, 182, 0.10) !important;
}

@media (max-width: 760px) {
  .stat-value-line {
    gap: 6px !important;
  }

  .stat-value-line .best-stat-chip,
  .stat-value-line small#bestTime,
  .stat-value-line small#mistakes {
    max-width: 58% !important;
    padding-inline: 7px !important;
  }

  .stat-value-line .best-stat-label,
  .stat-value-line .best-stat-sub {
    font-size: 9px !important;
  }

  .stat-value-line .best-stat-value {
    font-size: 13px !important;
  }
}


/* 2026-05 final polish: 35% nickname capsule + clearer inline best-stat badges. */
.profile-card input#playerName[readonly],
.profile-card input#playerName[readonly]:hover,
.profile-card input#playerName[readonly]:focus,
.profile-card input#playerName[readonly]:focus-visible,
.profile-card input#playerName[readonly].level-tier-10,
.profile-card input#playerName[readonly].level-tier-rainbow {
  background: linear-gradient(135deg, rgba(255, 93, 131, 0.35) 0%, rgba(225, 74, 196, 0.35) 50%, rgba(125, 76, 255, 0.35) 100%) !important;
}

.stat-value-line {
  gap: 10px !important;
  flex-wrap: nowrap !important;
}

.stat-value-line strong#timer,
.stat-value-line strong#score {
  display: inline-flex !important;
  align-items: baseline !important;
  min-width: max-content !important;
}

.stat-value-line .best-stat-chip,
.stat-value-line small#bestTime,
.stat-value-line small#mistakes {
  min-height: 32px !important;
  padding: 6px 11px !important;
  gap: 7px !important;
  max-width: none !important;
  border: 1px solid rgba(255, 77, 148, 0.42) !important;
  background:
    linear-gradient(135deg, rgba(255, 247, 252, 0.98), rgba(255, 230, 243, 0.96)) padding-box,
    linear-gradient(135deg, rgba(255, 67, 140, 0.62), rgba(226, 72, 194, 0.46), rgba(129, 77, 255, 0.42)) border-box !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.90),
    0 6px 14px rgba(255, 77, 148, 0.16),
    0 0 0 1px rgba(255, 255, 255, 0.55) !important;
}

.stat-value-line .best-score-chip,
.stat-value-line small#mistakes {
  border-color: rgba(125, 76, 255, 0.42) !important;
  background:
    linear-gradient(135deg, rgba(250, 247, 255, 0.98), rgba(240, 232, 255, 0.96)) padding-box,
    linear-gradient(135deg, rgba(255, 67, 140, 0.36), rgba(226, 72, 194, 0.46), rgba(125, 76, 255, 0.62)) border-box !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.90),
    0 6px 14px rgba(125, 76, 255, 0.16),
    0 0 0 1px rgba(255, 255, 255, 0.55) !important;
}

.stat-value-line .best-stat-label {
  color: #9f2c72 !important;
  font-size: 12px !important;
  font-weight: 1000 !important;
  letter-spacing: 0.02em !important;
}

.stat-value-line .best-stat-value {
  color: #e8177a !important;
  font-size: 17px !important;
  font-weight: 1000 !important;
  letter-spacing: -0.02em !important;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.82), 0 0 8px rgba(255, 77, 148, 0.18) !important;
}

.stat-value-line .best-score-chip .best-stat-value,
.stat-value-line #mistakes .best-stat-value {
  color: #6040dc !important;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.82), 0 0 8px rgba(125, 76, 255, 0.18) !important;
}

.stat-value-line .best-stat-sub {
  color: #6f5a83 !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  padding-left: 7px !important;
  border-left: 1px solid rgba(125, 76, 255, 0.25) !important;
}

@media (max-width: 760px) {
  .stat-value-line {
    gap: 7px !important;
  }

  .stat-value-line .best-stat-chip,
  .stat-value-line small#bestTime,
  .stat-value-line small#mistakes {
    min-height: 30px !important;
    padding: 5px 8px !important;
    gap: 5px !important;
    max-width: 62% !important;
  }

  .stat-value-line .best-stat-label,
  .stat-value-line .best-stat-sub {
    font-size: 11px !important;
  }

  .stat-value-line .best-stat-value {
    font-size: 15px !important;
  }
}

/* 2026-05 nickname text outline: keep the capsule fixed, make only nickname text use title-like stroke/glow. */
.profile-card input#playerName[readonly] {
  color: var(--level-color, #ffffff) !important;
  -webkit-text-fill-color: var(--level-color, #ffffff) !important;
  -webkit-text-stroke: 0.45px rgba(75, 23, 110, 0.28) !important;
  text-shadow:
    0.7px 0 rgba(75, 23, 110, 0.22),
    -0.7px 0 rgba(75, 23, 110, 0.22),
    0 0.7px rgba(75, 23, 110, 0.20),
    0 -0.7px rgba(255, 255, 255, 0.42),
    0 1px 1.5px rgba(255, 255, 255, 0.26),
    0 0 7px rgba(255, 255, 255, 0.18) !important;
}

.profile-card input#playerName[readonly].level-tier-10,
.profile-card input#playerName[readonly].level-tier-rainbow {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  -webkit-text-stroke: 0.55px rgba(75, 23, 110, 0.32) !important;
  text-shadow:
    0.8px 0 rgba(75, 23, 110, 0.24),
    -0.8px 0 rgba(75, 23, 110, 0.24),
    0 0.8px rgba(75, 23, 110, 0.22),
    0 -0.8px rgba(255, 255, 255, 0.48),
    0 1px 2px rgba(255, 255, 255, 0.28),
    0 0 8px rgba(255, 225, 122, 0.22),
    0 0 13px rgba(126, 227, 255, 0.18) !important;
}

/* 2026-05 nickname outline correction: match title-style outside outline, no inner stroke. */
.profile-card input#playerName[readonly] {
  -webkit-text-stroke: 0 transparent !important;
  text-shadow:
    0.52px 0 0 rgba(75, 23, 110, 0.24),
    -0.52px 0 0 rgba(75, 23, 110, 0.24),
    0 0.52px 0 rgba(75, 23, 110, 0.22),
    0 -0.52px 0 rgba(75, 23, 110, 0.18),
    0.36px 0.36px 0 rgba(75, 23, 110, 0.18),
    -0.36px 0.36px 0 rgba(75, 23, 110, 0.16),
    0 0.9px 0.8px rgba(255, 255, 255, 0.18),
    0 0 7px rgba(255, 255, 255, 0.16) !important;
}

.profile-card input#playerName[readonly].level-tier-10,
.profile-card input#playerName[readonly].level-tier-rainbow {
  -webkit-text-stroke: 0 transparent !important;
  text-shadow:
    0.56px 0 0 rgba(75, 23, 110, 0.27),
    -0.56px 0 0 rgba(75, 23, 110, 0.27),
    0 0.56px 0 rgba(75, 23, 110, 0.25),
    0 -0.56px 0 rgba(75, 23, 110, 0.20),
    0.40px 0.40px 0 rgba(75, 23, 110, 0.20),
    -0.40px 0.40px 0 rgba(75, 23, 110, 0.18),
    0 0 1.6px rgba(255, 95, 162, 0.08),
    0 0 8px rgba(255, 225, 122, 0.20),
    0 0 13px rgba(126, 227, 255, 0.16) !important;
}


/* 2026-05 profile actions + feedback height + register code availability. */
.profile-action-row {
  grid-template-columns: 0.95fr 1fr 0.75fr !important;
  align-items: stretch !important;
  gap: 8px !important;
}

.feedback-textarea {
  height: 287.5px !important;
  min-height: 287.5px !important;
  max-height: none !important;
  font-size: 14px !important;
  line-height: 1.62 !important;
  padding: 12px 13px !important;
}

.register-code-hint {
  margin: 4px 0 0 !important;
  min-height: 16px !important;
  font-size: 11.5px !important;
  font-weight: 900 !important;
  line-height: 1.25 !important;
  letter-spacing: 0.01em !important;
}

.register-code-hint.is-ok {
  color: #16a060 !important;
}

.register-code-hint.is-bad {
  color: #e0447f !important;
}

.register-code-hint.is-checking {
  color: #9a6f9f !important;
}

@media (max-width: 520px) {
  .profile-action-row {
    grid-template-columns: 0.9fr 1fr 0.72fr !important;
    gap: 6px !important;
  }

  .profile-action-row button {
    padding-left: 7px !important;
    padding-right: 7px !important;
    font-size: 12px !important;
  }

  .feedback-textarea {
    height: 250px !important;
    min-height: 250px !important;
    max-height: none !important;
  }
}

.register-code-hint.hidden {
  display: none !important;
}

/* 2026-05 account modal close button + one-line profile actions. */
.user-code-modal-card {
  position: relative !important;
}

.modal-close-btn.account-modal-close {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  width: 34px !important;
  height: 34px !important;
  display: inline-grid !important;
  place-items: center !important;
  border: 1px solid rgba(255, 126, 182, 0.22) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.86) !important;
  color: #e0447f !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  cursor: pointer !important;
  box-shadow: 0 8px 18px rgba(247, 93, 157, 0.12) !important;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease !important;
  z-index: 3 !important;
}

.modal-close-btn.account-modal-close:hover,
.modal-close-btn.account-modal-close:focus-visible {
  transform: translateY(-1px) !important;
  background: #fff !important;
  box-shadow: 0 12px 24px rgba(247, 93, 157, 0.20) !important;
  outline: none !important;
}

.email-change-modal-card .profile-action-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr) minmax(0, 0.82fr) !important;
  gap: 7px !important;
  width: 100% !important;
  margin-top: 10px !important;
}

.email-change-modal-card .profile-action-row button {
  min-width: 0 !important;
  width: 100% !important;
  min-height: 38px !important;
  padding-left: 8px !important;
  padding-right: 8px !important;
  white-space: nowrap !important;
  font-size: 13px !important;
}

@media (max-width: 420px) {
  .email-change-modal-card .profile-action-row {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr) minmax(0, 0.78fr) !important;
    gap: 5px !important;
  }

  .email-change-modal-card .profile-action-row button {
    min-height: 36px !important;
    padding-left: 5px !important;
    padding-right: 5px !important;
    font-size: 11.5px !important;
    letter-spacing: -0.02em !important;
  }

  .modal-close-btn.account-modal-close {
    top: 10px !important;
    right: 10px !important;
    width: 31px !important;
    height: 31px !important;
    font-size: 20px !important;
  }
}

/* 2026-05 inline register code availability badge. */
.auth-code-field .code-input-status-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 8px !important;
}

.auth-code-field .code-input-status-row .modal-input {
  min-width: 0 !important;
  width: 100% !important;
  margin-top: 0 !important;
}

.compact-account-modal.auth-mode-register .register-code-hint {
  display: inline-flex !important;
}

.register-code-hint {
  min-width: 62px !important;
  margin: 0 !important;
  padding: 5px 7px 5px 5px !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 126, 182, 0.22) !important;
  background: rgba(255, 255, 255, 0.72) !important;
  box-shadow: 0 6px 14px rgba(255, 126, 182, 0.10) !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

.register-code-hint.hidden {
  display: none !important;
}

.register-code-icon {
  width: 18px !important;
  height: 18px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 1000 !important;
  line-height: 1 !important;
  box-shadow: inset 0 -1px 2px rgba(0, 0, 0, 0.12) !important;
}

.register-code-hint.is-ok {
  color: #15915a !important;
  border-color: rgba(36, 190, 111, 0.28) !important;
  background: rgba(235, 255, 245, 0.82) !important;
}

.register-code-hint.is-ok .register-code-icon {
  background: linear-gradient(135deg, #37d67a, #14a75d) !important;
}

.register-code-hint.is-bad {
  color: #d73370 !important;
  border-color: rgba(224, 68, 127, 0.30) !important;
  background: rgba(255, 240, 247, 0.86) !important;
}

.register-code-hint.is-bad .register-code-icon {
  background: linear-gradient(135deg, #ff75a8, #e0447f) !important;
}

.register-code-hint.is-checking {
  color: #8f6a98 !important;
  border-color: rgba(154, 111, 159, 0.24) !important;
}

.register-code-hint.is-checking .register-code-icon {
  background: linear-gradient(135deg, #c79dd0, #9a6f9f) !important;
}

@media (max-width: 420px) {
  .auth-code-field .code-input-status-row {
    grid-template-columns: minmax(0, 1fr) 58px !important;
    gap: 6px !important;
  }

  .register-code-hint {
    min-width: 58px !important;
    padding-inline: 4px 5px !important;
    font-size: 11px !important;
  }

  .register-code-icon {
    width: 16px !important;
    height: 16px !important;
    font-size: 11px !important;
  }
}

/* 2026-05 login button beside guest nickname */
.profile-name-row {
  grid-template-columns: minmax(0, 1fr) auto auto !important;
}

.profile-login-btn {
  border: 1px solid rgba(255, 89, 150, 0.34);
  background: linear-gradient(135deg, rgba(255, 117, 167, 0.94), rgba(200, 88, 226, 0.92));
  color: #fff;
  font-size: 13px;
  font-weight: 1000;
  letter-spacing: 0.04em;
  border-radius: 999px;
  padding: 7px 13px;
  min-height: 34px;
  min-width: 56px;
  box-shadow: 0 8px 18px rgba(255, 77, 148, 0.20), inset 0 1px 0 rgba(255, 255, 255, 0.32);
  cursor: pointer;
  white-space: nowrap;
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

.profile-login-btn:hover,
.profile-login-btn:focus-visible {
  transform: translateY(-1px);
  filter: brightness(1.04);
  box-shadow: 0 10px 22px rgba(255, 77, 148, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.40);
}

.profile-login-btn.hidden {
  display: none !important;
}

.profile-card input#playerName[readonly] {
  cursor: default;
}

.profile-card input#playerName[readonly]:not(.guest-nickname) {
  cursor: pointer;
}

@media (max-width: 520px) {
  .profile-name-row {
    grid-template-columns: minmax(0, 1fr) auto auto !important;
    gap: 6px !important;
  }

  .profile-login-btn,
  .logout-btn {
    min-width: 48px !important;
    padding: 6px 10px !important;
    font-size: 12px !important;
  }
}

/* 2026-05 desktop-only additions preserved from previous version. */
@media (min-width: 901px) {
/* 2026-05 phonetic display and word pronunciation buttons */
.target-word-button {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  border: 0;
  padding: 0;
  margin: 0;
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  color: inherit;
  background: transparent;
  text-align: left;
  cursor: pointer;
  vertical-align: baseline;
}

.target-word-button:hover .word,
.target-word-button:focus-visible .word {
  color: var(--pink-500);
}

.target-word-button:focus-visible {
  outline: 2px solid rgba(246, 93, 157, 0.42);
  outline-offset: 2px;
  border-radius: 6px;
}

.target-item .target-word-button .word {
  min-width: 0;
  display: inline-block;
  margin-right: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.05;
}

.target-item .phonetic {
  flex: 0 0 auto;
  color: var(--muted);
  font-size: clamp(7.5px, 0.58vw, 10px);
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1;
  text-transform: none;
  white-space: nowrap;
  opacity: 0.88;
}

.match-card.random-card.word strong,
.match-card.word strong {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(2px, calc(var(--match-card-size, 88px) * 0.025), 5px);
}

.match-word-text {
  display: block;
  width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.match-card-phonetic {
  display: block;
  max-width: 100%;
  color: currentColor;
  font-size: clamp(8px, calc(var(--match-card-size, 88px) * 0.082), 12px);
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.06;
  opacity: 0.72;
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: none;
  white-space: nowrap;
}

.match-card.active .match-card-phonetic {
  opacity: 0.9;
}

/* 2026-05 enlarge beginner match word text after adding phonetics */
.match-card.random-card.word strong,
.match-card.word strong {
  gap: clamp(1px, calc(var(--match-card-size, 88px) * 0.018), 4px) !important;
}

.match-card.random-card.word .match-word-text,
.match-card.word .match-word-text {
  font-size: clamp(17px, calc(var(--match-card-size, 88px) * 0.215), 32px) !important;
  line-height: 0.98 !important;
  font-weight: 1000 !important;
  letter-spacing: 0.005em !important;
}

.match-card.random-card.word .match-card-phonetic,
.match-card.word .match-card-phonetic {
  font-size: clamp(8px, calc(var(--match-card-size, 88px) * 0.076), 12px) !important;
  line-height: 1 !important;
}


/* 2026-05 local pronunciation files and one-line adaptive beginner word cards */
.match-card.random-card.word .match-word-text,
.match-card.word .match-word-text {
  display: block !important;
  max-width: 100% !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  overflow-wrap: normal !important;
  overflow: hidden !important;
  text-overflow: clip !important;
}

.match-card.random-card.word strong,
.match-card.word strong {
  min-width: 0 !important;
  overflow: hidden !important;
}


/* 2026-05 三行安全布局修复：顶部 / 主游戏区 / 底部状态栏互不渗透 */
html,
body {
  width: 100%;
  min-width: 0 !important;
  min-height: 100%;
  overflow-x: auto !important;
  overflow-y: auto !important;
}

body {
  height: auto !important;
}

.app-shell {
  box-sizing: border-box;
  min-width: 0 !important;
  min-height: 100dvh !important;
  height: auto !important;
  max-height: none !important;
  grid-template-rows: max-content minmax(0, 1fr) max-content !important;
  overflow: visible !important;
  align-content: stretch !important;
}

.app-hero,
.main-layout,
.dashboard {
  box-sizing: border-box;
  min-width: 0 !important;
  position: relative;
}

.app-hero {
  grid-row: 1 !important;
  z-index: 3;
}

.main-layout {
  grid-row: 2 !important;
  z-index: 2;
  contain: layout;
}

.dashboard {
  grid-row: 3 !important;
  z-index: 1;
}

@media (min-width: 901px) {
  .app-shell {
    width: min(1760px, calc(100vw - 8px)) !important;
    min-width: 920px !important;
    grid-template-rows: max-content minmax(clamp(520px, calc(100dvh - 180px), 760px), 1fr) max-content !important;
  }

  .main-layout {
    min-height: clamp(520px, calc(100dvh - 180px), 760px) !important;
    overflow: auto !important;
    overscroll-behavior: contain;
  }

  .side-panel .panel-card,
  .panel-card,
  .game-card {
    max-width: 100% !important;
    max-height: 100% !important;
  }

  .side-panel .panel-card:nth-child(n) {
    overflow: auto !important;
    overscroll-behavior: contain;
  }

  .game-card {
    overflow: hidden !important;
  }

  .grid-scroller {
    max-width: 100% !important;
    max-height: 100% !important;
    overflow: auto !important;
    overscroll-behavior: contain;
  }

  .match-grid,
  .letter-grid {
    max-width: none !important;
    max-height: none !important;
    overflow: visible !important;
  }

  .target-list,
  .leaderboard,
  .level-map {
    overflow: auto !important;
    overscroll-behavior: contain;
  }

  .target-item,
  .leaderboard li,
  .level-dot,
  .match-card,
  .match-card.random-card {
    min-width: 0 !important;
    max-width: 100% !important;
  }
}

@media (max-height: 640px) and (min-width: 901px) {
  .app-shell {
    grid-template-rows: max-content minmax(500px, auto) max-content !important;
  }

  .main-layout {
    min-height: 500px !important;
  }
}

/* 2026-05 viewport-lock layout: keep the whole game inside one browser window, no page scrolling */
html,
body {
  width: 100% !important;
  height: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  overscroll-behavior: none !important;
}

body {
  min-height: 100dvh !important;
}

body,
.app-shell,
.app-shell > *,
.app-hero,
.dashboard,
.main-layout,
.side-panel,
.panel-card,
.game-card,
.grid-scroller,
.letter-grid,
.match-grid {
  box-sizing: border-box !important;
  min-width: 0 !important;
  min-height: 0 !important;
}

.app-shell {
  width: 100vw !important;
  height: 100dvh !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: 100vw !important;
  max-height: 100dvh !important;
  margin: 0 !important;
  padding: clamp(2px, 0.45vmin, 6px) !important;
  display: grid !important;
  grid-template-rows: minmax(54px, auto) minmax(0, 1fr) minmax(38px, auto) !important;
  gap: clamp(2px, 0.45vmin, 6px) !important;
  overflow: hidden !important;
  align-content: stretch !important;
}

.app-hero,
.hero-card {
  grid-row: 1 !important;
  width: 100% !important;
  max-height: min(20dvh, 126px) !important;
  padding: clamp(3px, 0.65vmin, 8px) clamp(5px, 0.9vmin, 12px) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.76fr) !important;
  align-items: center !important;
  gap: clamp(4px, 0.8vmin, 10px) !important;
  overflow: hidden !important;
}

.hero-content,
.profile-card {
  min-width: 0 !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

.hero-content h1 {
  margin: 0 !important;
  font-size: clamp(14px, 2.45vmin, 28px) !important;
  line-height: 0.96 !important;
}

.game-kicker,
.eyebrow {
  margin: 0 0 1px !important;
  font-size: clamp(7px, 1.1vmin, 11px) !important;
  line-height: 1 !important;
}

.profile-card {
  width: 100% !important;
  padding: clamp(3px, 0.65vmin, 8px) !important;
  gap: clamp(2px, 0.45vmin, 5px) !important;
}

.profile-card input {
  height: clamp(18px, 3.5vmin, 32px) !important;
  padding: 2px 6px !important;
  font-size: clamp(9px, 1.55vmin, 13px) !important;
}

.profile-login-btn,
.logout-btn,
.mode-btn {
  min-height: 0 !important;
  padding: clamp(2px, 0.65vmin, 7px) clamp(4px, 0.9vmin, 10px) !important;
  font-size: clamp(8px, 1.35vmin, 12px) !important;
  line-height: 1 !important;
}

.level-pill {
  min-height: 0 !important;
  padding: clamp(2px, 0.45vmin, 5px) clamp(4px, 0.75vmin, 8px) !important;
  font-size: clamp(8px, 1.35vmin, 12px) !important;
  line-height: 1 !important;
}

.mode-switch {
  gap: clamp(2px, 0.45vmin, 5px) !important;
}

.dashboard {
  grid-row: 3 !important;
  width: 100% !important;
  max-height: min(13dvh, 82px) !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: clamp(2px, 0.45vmin, 6px) !important;
  overflow: hidden !important;
}

.stat-card {
  min-height: 0 !important;
  height: 100% !important;
  padding: clamp(3px, 0.65vmin, 8px) clamp(4px, 0.9vmin, 10px) !important;
  border-radius: clamp(8px, 1.7vmin, 16px) !important;
  overflow: hidden !important;
}

.stat-card span,
.stat-card small {
  font-size: clamp(7px, 1.2vmin, 11px) !important;
  line-height: 1.02 !important;
}

.stat-card strong {
  font-size: clamp(12px, 2.3vmin, 23px) !important;
  line-height: 1 !important;
}

.main-layout {
  grid-row: 2 !important;
  width: 100% !important;
  height: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: clamp(2px, 0.45vmin, 6px) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 0.74fr) minmax(0, 1.62fr) minmax(0, 0.74fr) !important;
  grid-template-rows: minmax(0, 3fr) minmax(0, 7fr) !important;
  gap: clamp(2px, 0.45vmin, 6px) !important;
  overflow: hidden !important;
  contain: layout size !important;
}

.side-panel {
  display: contents !important;
  min-width: 0 !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

.side-panel .panel-card:nth-child(2) {
  grid-column: 1 !important;
  grid-row: 1 !important;
}

.side-panel .panel-card:nth-child(1) {
  grid-column: 1 !important;
  grid-row: 2 !important;
}

.game-card {
  grid-column: 2 !important;
  grid-row: 1 / 3 !important;
}

.side-panel .panel-card:nth-child(4) {
  grid-column: 3 !important;
  grid-row: 1 / 3 !important;
  align-self: start !important;
  height: calc(70% - clamp(1px, 0.25vmin, 3px)) !important;
}

.side-panel .panel-card:nth-child(3) {
  grid-column: 3 !important;
  grid-row: 1 / 3 !important;
  align-self: end !important;
  height: calc(30% - clamp(1px, 0.25vmin, 3px)) !important;
}

.side-panel .panel-card,
.panel-card,
.game-card {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: 100% !important;
  max-height: 100% !important;
  padding: clamp(3px, 0.7vmin, 9px) !important;
  border-radius: clamp(9px, 1.8vmin, 20px) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}

.panel-title-row,
.game-toolbar {
  flex: 0 1 auto !important;
  min-height: 0 !important;
  margin-bottom: clamp(1px, 0.35vmin, 5px) !important;
  gap: clamp(2px, 0.45vmin, 5px) !important;
  overflow: hidden !important;
}

.panel-title-row h2,
.controls h2,
.game-toolbar h2 {
  font-size: clamp(9px, 1.7vmin, 16px) !important;
  line-height: 1 !important;
  margin: 0 !important;
}

.game-toolbar {
  max-height: min(18%, 78px) !important;
  padding: 0 !important;
}

.toolbar-controls {
  display: grid !important;
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 1fr) !important;
  align-items: center !important;
  gap: clamp(2px, 0.45vmin, 6px) !important;
  flex-wrap: nowrap !important;
  width: 100% !important;
}

.toolbar-controls .word-source-switch,
.toolbar-controls .sound-controls {
  width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
}

.toolbar-controls .sound-controls {
  display: grid !important;
  grid-template-columns: minmax(0, auto) minmax(0, 1fr) !important;
  gap: clamp(2px, 0.45vmin, 5px) !important;
  justify-content: stretch !important;
}

.source-btn,
.sound-toggle,
.sound-volume,
.primary-btn,
.ghost-btn,
.mini-btn {
  min-width: 0 !important;
  min-height: 0 !important;
  padding: clamp(2px, 0.65vmin, 7px) clamp(3px, 0.85vmin, 10px) !important;
  font-size: clamp(7px, 1.25vmin, 12px) !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.sound-volume input {
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}

.control-row,
.controls,
.word-source-switch,
.sound-controls {
  gap: clamp(2px, 0.45vmin, 5px) !important;
}

.range-label,
.profile-card label {
  font-size: clamp(7px, 1.2vmin, 11px) !important;
  line-height: 1 !important;
}

.target-list,
.leaderboard,
.level-map,
.grid-scroller {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: 100% !important;
  max-height: 100% !important;
  overflow: hidden !important;
}

.target-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
  grid-template-rows: repeat(10, minmax(0, 1fr)) !important;
  gap: clamp(1px, 0.3vmin, 3px) !important;
}

.target-item {
  min-width: 0 !important;
  min-height: 0 !important;
  padding: clamp(2px, 0.45vmin, 5px) !important;
  gap: clamp(1px, 0.3vmin, 3px) !important;
  overflow: hidden !important;
}

.target-item .word,
.target-word-button,
.target-item .phonetic,
.target-item .tag {
  font-size: clamp(7px, 1.35vmin, 12px) !important;
  line-height: 1 !important;
  min-width: 0 !important;
}

.leaderboard {
  display: grid !important;
  grid-template-columns: 1fr !important;
  grid-template-rows: repeat(10, minmax(0, 1fr)) !important;
  grid-auto-rows: minmax(0, 1fr) !important;
  gap: clamp(1px, 0.3vmin, 3px) !important;
}

.leaderboard li {
  min-width: 0 !important;
  min-height: 0 !important;
  padding: clamp(2px, 0.45vmin, 5px) !important;
  font-size: clamp(7px, 1.35vmin, 12px) !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.leaderboard li strong,
.leaderboard small {
  font-size: clamp(7px, 1.25vmin, 12px) !important;
  line-height: 1 !important;
}

.level-map {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  grid-template-rows: repeat(5, minmax(0, 1fr)) !important;
  grid-auto-rows: minmax(0, 1fr) !important;
  gap: clamp(1px, 0.3vmin, 3px) !important;
}

.level-dot {
  min-width: 0 !important;
  min-height: 0 !important;
  height: auto !important;
  padding: 0 !important;
  border-radius: clamp(4px, 0.9vmin, 9px) !important;
  font-size: clamp(7px, 1.25vmin, 11px) !important;
  line-height: 1 !important;
  aspect-ratio: auto !important;
}

.grid-scroller {
  height: auto !important;
  padding: clamp(2px, 0.45vmin, 6px) !important;
  display: grid !important;
  place-items: center !important;
}

.grid-scroller.match-mode,
.grid-scroller.letter-mode {
  overflow: hidden !important;
  touch-action: none !important;
}

.match-grid,
.letter-grid {
  max-width: 100% !important;
  max-height: 100% !important;
  overflow: hidden !important;
}

.match-grid {
  grid-template-columns: repeat(var(--match-columns), var(--match-card-size)) !important;
  grid-auto-rows: var(--match-card-size) !important;
  gap: clamp(2px, 0.75vmin, 6px) !important;
  padding: clamp(2px, 0.65vmin, 6px) !important;
  width: max-content !important;
  height: max-content !important;
  align-content: center !important;
  justify-content: center !important;
}

.match-card.random-card,
.match-card {
  width: var(--match-card-size) !important;
  height: var(--match-card-size) !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: clamp(2px, calc(var(--match-card-size) * 0.055), 8px) !important;
  border-radius: clamp(7px, calc(var(--match-card-size) * 0.12), 18px) !important;
}

.match-card.random-card.word .match-word-text,
.match-card.word .match-word-text {
  font-size: clamp(8px, calc(var(--match-card-size) * 0.21), 28px) !important;
}

.match-card.random-card.meaning strong,
.match-card.meaning strong {
  font-size: clamp(7px, calc(var(--match-card-size) * 0.12), 15px) !important;
  line-height: 1.05 !important;
  max-height: 100% !important;
}

.match-card-phonetic {
  font-size: clamp(6px, calc(var(--match-card-size) * 0.08), 11px) !important;
}

.letter-grid {
  grid-auto-rows: var(--cell) !important;
  gap: var(--letter-gap, 3px) !important;
  padding: clamp(2px, 0.65vmin, 8px) !important;
  width: max-content !important;
  height: max-content !important;
}

.cell {
  width: var(--cell) !important;
  height: var(--cell) !important;
  min-width: 0 !important;
  min-height: 0 !important;
  font-size: clamp(7px, calc(var(--cell) * 0.52), 34px) !important;
  border-radius: clamp(4px, calc(var(--cell) * 0.17), 14px) !important;
}

.cell.heart-cell {
  font-size: clamp(7px, calc(var(--cell) * 0.48), 30px) !important;
}

@media (max-height: 620px) {
  .app-shell {
    grid-template-rows: minmax(42px, auto) minmax(0, 1fr) minmax(30px, auto) !important;
  }

  .hero-description,
  .hero-copy,
  .target-item .tag,
  .leaderboard small,
  .range-label {
    display: none !important;
  }

  .game-toolbar {
    max-height: min(15%, 56px) !important;
  }
}

@media (max-width: 900px) {
  body {
    overflow: hidden !important;
  }

  .app-shell {
    width: 100vw !important;
    height: 100dvh !important;
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 2px !important;
    grid-template-rows: minmax(44px, auto) minmax(0, 1fr) minmax(30px, auto) !important;
    gap: 2px !important;
    overflow: hidden !important;
  }

  .app-hero,
  .hero-card {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    max-height: 18dvh !important;
    padding: 3px !important;
    gap: 3px !important;
  }

  .main-layout {
    grid-template-columns: minmax(0, 0.72fr) minmax(0, 1.72fr) minmax(0, 0.72fr) !important;
    grid-template-rows: minmax(0, 3fr) minmax(0, 7fr) !important;
    gap: 2px !important;
    padding: 2px !important;
    overflow: hidden !important;
  }

  .dashboard {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    max-height: 11dvh !important;
    gap: 2px !important;
  }

  .side-panel .panel-card,
  .panel-card,
  .game-card {
    padding: 3px !important;
    border-radius: 10px !important;
    overflow: hidden !important;
  }

  .toolbar-controls {
    grid-template-columns: 1fr !important;
    gap: 2px !important;
  }

  .toolbar-controls .sound-controls,
  .sound-controls {
    display: none !important;
  }

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

/* 2026-05 viewport-lock final track sizing: fixed three rows inside 100dvh */
.app-shell {
  grid-template-rows: clamp(44px, 14dvh, 126px) minmax(0, 1fr) clamp(30px, 11dvh, 82px) !important;
}

.app-hero,
.hero-card,
.dashboard {
  max-height: 100% !important;
}

@media (max-height: 620px) {
  .app-shell {
    grid-template-rows: clamp(36px, 13dvh, 72px) minmax(0, 1fr) clamp(24px, 10dvh, 52px) !important;
  }
}

@media (max-width: 900px) {
  .app-shell {
    grid-template-rows: clamp(38px, 13dvh, 92px) minmax(0, 1fr) clamp(24px, 9.5dvh, 56px) !important;
  }
}


/* 2026-05 requested: desktop profile panel half width + mobile viewport refit */
@media (min-width: 901px) {
  .app-hero,
  .hero-card {
    grid-template-columns: minmax(0, 1fr) clamp(260px, 22vw, 430px) !important;
  }

  .profile-card {
    width: 100% !important;
    justify-self: end !important;
  }
}

@media (max-width: 900px) {
  html,
  body {
    width: 100% !important;
    height: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  body {
    min-height: 100dvh !important;
    touch-action: manipulation !important;
  }

  .app-shell {
    width: 100vw !important;
    height: 100dvh !important;
    max-width: 100vw !important;
    max-height: 100dvh !important;
    min-width: 0 !important;
    min-height: 0 !important;
    padding: clamp(2px, 0.75vw, 5px) !important;
    display: grid !important;
    grid-template-rows: clamp(72px, 16dvh, 118px) minmax(0, 1fr) clamp(38px, 9dvh, 58px) !important;
    gap: clamp(2px, 0.7vw, 5px) !important;
    overflow: hidden !important;
  }

  .app-hero,
  .hero-card {
    grid-row: 1 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr) !important;
    align-items: stretch !important;
    gap: clamp(2px, 0.7vw, 5px) !important;
    padding: clamp(3px, 0.85vw, 6px) !important;
    max-height: none !important;
    overflow: hidden !important;
  }

  .hero-content {
    min-width: 0 !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    overflow: hidden !important;
  }

  .hero-copy,
  .hero-description {
    display: none !important;
  }

  .game-kicker,
  .eyebrow.game-kicker {
    max-width: 100% !important;
    margin: 0 0 2px !important;
    padding: 2px 5px !important;
    font-size: clamp(7px, 2.1vw, 10px) !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .hero-content h1 {
    margin: 0 !important;
    font-size: clamp(15px, 5.7vw, 27px) !important;
    line-height: 0.95 !important;
    letter-spacing: -0.05em !important;
    overflow: hidden !important;
  }

  .hero-content h1 span {
    display: block !important;
  }

  .marlous-link {
    min-height: 0 !important;
    width: max-content !important;
    max-width: 100% !important;
    padding: 2px 7px !important;
    font-size: clamp(8px, 2.35vw, 11px) !important;
    line-height: 1 !important;
  }

  .profile-card {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    padding: clamp(3px, 0.85vw, 6px) !important;
    display: grid !important;
    grid-template-columns: minmax(0, 0.5fr) minmax(0, 1fr) !important;
    grid-auto-rows: minmax(0, auto) !important;
    align-content: center !important;
    column-gap: clamp(2px, 0.65vw, 5px) !important;
    row-gap: clamp(2px, 0.55vw, 4px) !important;
    border-radius: clamp(9px, 2.7vw, 16px) !important;
    overflow: hidden !important;
  }

  .profile-card label#profileSchoolLabel,
  .profile-card label[for="playerName"] {
    grid-column: 1 !important;
    align-self: center !important;
    max-width: 100% !important;
    font-size: clamp(8px, 2.25vw, 11px) !important;
    line-height: 1 !important;
  }

  .profile-name-row {
    grid-column: 2 !important;
    min-width: 0 !important;
    gap: clamp(2px, 0.55vw, 4px) !important;
  }

  .profile-card input,
  .profile-card input#playerName[readonly] {
    height: clamp(20px, 4.8vw, 28px) !important;
    min-width: 0 !important;
    padding: 2px 5px !important;
    font-size: clamp(9px, 2.55vw, 12px) !important;
    line-height: 1 !important;
  }

  .profile-login-btn,
  .logout-btn {
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 2px 5px !important;
    font-size: clamp(8px, 2.25vw, 11px) !important;
    line-height: 1 !important;
  }

  .level-pill {
    grid-column: 1 / 3 !important;
    min-height: 0 !important;
    padding: 2px 5px !important;
    font-size: clamp(8px, 2.25vw, 11px) !important;
    line-height: 1 !important;
  }

  #playerTitle,
  #playerRank {
    min-width: 0 !important;
    font-size: inherit !important;
    line-height: 1 !important;
  }

  .mode-switch {
    grid-column: 1 / 3 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: clamp(2px, 0.55vw, 4px) !important;
  }

  .mode-btn {
    min-height: clamp(18px, 4.2vw, 26px) !important;
    padding: 2px 3px !important;
    font-size: clamp(8px, 2.2vw, 11px) !important;
    line-height: 1 !important;
  }

  .main-layout {
    grid-row: 2 !important;
    width: 100% !important;
    height: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: minmax(0, 2.05fr) minmax(0, 0.66fr) minmax(0, 0.66fr) !important;
    gap: clamp(2px, 0.7vw, 5px) !important;
    overflow: hidden !important;
    contain: layout size !important;
  }

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

  .game-card {
    grid-column: 1 / 3 !important;
    grid-row: 1 !important;
  }

  .side-panel .panel-card:nth-child(2) {
    grid-column: 1 !important;
    grid-row: 2 !important;
    height: auto !important;
    align-self: stretch !important;
  }

  .side-panel .panel-card:nth-child(1) {
    grid-column: 2 !important;
    grid-row: 2 !important;
    height: auto !important;
    align-self: stretch !important;
  }

  .side-panel .panel-card:nth-child(4) {
    grid-column: 1 !important;
    grid-row: 3 !important;
    height: auto !important;
    align-self: stretch !important;
  }

  .side-panel .panel-card:nth-child(3) {
    grid-column: 2 !important;
    grid-row: 3 !important;
    height: auto !important;
    align-self: stretch !important;
  }

  .side-panel .panel-card,
  .panel-card,
  .game-card {
    width: 100% !important;
    height: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    max-width: 100% !important;
    max-height: 100% !important;
    padding: clamp(3px, 0.85vw, 6px) !important;
    border-radius: clamp(9px, 2.6vw, 16px) !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }

  .panel-title-row,
  .game-toolbar {
    flex: 0 0 auto !important;
    min-height: 0 !important;
    margin-bottom: clamp(1px, 0.35vw, 3px) !important;
  }

  .panel-title-row h2,
  .controls h2 {
    font-size: clamp(9px, 2.65vw, 13px) !important;
    line-height: 1 !important;
    margin: 0 !important;
  }

  .panel-title-row span,
  #foundCounter,
  #levelRangeLabel {
    font-size: clamp(8px, 2.25vw, 11px) !important;
    line-height: 1 !important;
  }

  .game-toolbar {
    max-height: clamp(24px, 8dvh, 44px) !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  .toolbar-controls {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 2px !important;
  }

  .toolbar-controls .sound-controls,
  .sound-controls {
    display: none !important;
  }

  .word-source-switch {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 2px !important;
    margin: 0 !important;
    padding: 2px !important;
    border-radius: 999px !important;
  }

  .source-btn,
  .primary-btn,
  .ghost-btn,
  .mini-btn {
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 3px 4px !important;
    font-size: clamp(8px, 2.2vw, 11px) !important;
    line-height: 1 !important;
  }

  .game-toolbar p#selectionPreview {
    display: none !important;
  }

  .grid-scroller {
    flex: 1 1 0 !important;
    width: 100% !important;
    height: auto !important;
    min-width: 0 !important;
    min-height: 0 !important;
    padding: clamp(2px, 0.65vw, 5px) !important;
    overflow: hidden !important;
  }

  .match-grid {
    grid-template-columns: repeat(var(--match-columns), var(--match-card-size)) !important;
    grid-auto-rows: var(--match-card-size) !important;
    gap: clamp(2px, 0.75vw, 5px) !important;
    padding: clamp(2px, 0.65vw, 5px) !important;
    width: max-content !important;
    height: max-content !important;
    max-width: 100% !important;
    max-height: 100% !important;
  }

  .match-card,
  .match-card.random-card {
    width: var(--match-card-size) !important;
    height: var(--match-card-size) !important;
    min-width: 0 !important;
    min-height: 0 !important;
    padding: clamp(2px, calc(var(--match-card-size) * 0.055), 6px) !important;
  }

  .letter-grid {
    max-width: 100% !important;
    max-height: 100% !important;
    overflow: hidden !important;
  }

  .controls {
    gap: clamp(2px, 0.6vw, 4px) !important;
  }

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

  .zoom-control,
  .range-label,
  input#zoomRange {
    display: none !important;
  }

  .target-list {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: repeat(5, minmax(0, 1fr)) !important;
    grid-auto-rows: minmax(0, 1fr) !important;
    gap: 2px !important;
    overflow: hidden !important;
  }

  .target-item {
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 2px 3px !important;
    border-radius: 8px !important;
    overflow: hidden !important;
  }

  .target-item .word,
  .target-word-button {
    font-size: clamp(8px, 2.35vw, 11px) !important;
    line-height: 1 !important;
  }

  .target-item .phonetic,
  .target-item .tag {
    display: none !important;
  }

  .leaderboard {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    display: grid !important;
    grid-template-rows: repeat(6, minmax(0, 1fr)) !important;
    grid-auto-rows: minmax(0, 1fr) !important;
    gap: 2px !important;
    overflow: hidden !important;
  }

  .leaderboard li,
  .leaderboard li.leader-entry,
  .leaderboard li.leaderboard-head {
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 2px 3px !important;
    font-size: clamp(7px, 2.1vw, 10px) !important;
    line-height: 1 !important;
    overflow: hidden !important;
  }

  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.8fr) minmax(0, 0.75fr) !important;
    column-gap: 2px !important;
  }

  .leaderboard li strong,
  .leaderboard small,
  .leaderboard .leader-rank,
  .leaderboard .leader-score,
  .leaderboard .leader-time {
    font-size: clamp(7px, 2.1vw, 10px) !important;
    line-height: 1 !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .level-map {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    grid-template-rows: repeat(5, minmax(0, 1fr)) !important;
    grid-auto-rows: minmax(0, 1fr) !important;
    gap: 2px !important;
    overflow: hidden !important;
  }

  .level-dot {
    min-width: 0 !important;
    min-height: 0 !important;
    height: auto !important;
    padding: 0 !important;
    border-radius: 7px !important;
    font-size: clamp(7px, 2vw, 10px) !important;
    line-height: 1 !important;
  }

  .dashboard {
    grid-row: 3 !important;
    width: 100% !important;
    height: 100% !important;
    max-height: none !important;
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 2px !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  .stat-card {
    min-width: 0 !important;
    min-height: 0 !important;
    height: 100% !important;
    padding: 3px !important;
    border-radius: 10px !important;
    overflow: hidden !important;
  }

  .stat-card span,
  .stat-card small,
  .best-stat-chip,
  .best-stat-value,
  .best-stat-sub {
    font-size: clamp(7px, 2vw, 10px) !important;
    line-height: 1 !important;
  }

  .stat-card strong,
  .stat-value-line strong {
    font-size: clamp(10px, 3.6vw, 17px) !important;
    line-height: 1 !important;
  }
}

@media (max-width: 420px) {
  .app-shell {
    grid-template-rows: clamp(68px, 15.5dvh, 104px) minmax(0, 1fr) clamp(34px, 8.5dvh, 52px) !important;
  }

  .app-hero,
  .hero-card {
    grid-template-columns: minmax(0, 0.68fr) minmax(0, 1.32fr) !important;
  }

  .hero-content h1 {
    font-size: clamp(14px, 5.2vw, 23px) !important;
  }

  .main-layout {
    grid-template-rows: minmax(0, 2fr) minmax(0, 0.62fr) minmax(0, 0.62fr) !important;
  }

  .profile-card {
    row-gap: 2px !important;
  }
}

/* 2026-05 mobile reference blocks copied from uploaded styles.css */
@media (max-width: 760px) {
  .hero-card, .game-toolbar { flex-direction: column; align-items: stretch; }
  .dashboard, .side-panel { grid-template-columns: 1fr; }
  .app-shell { width: min(100% - 18px, 1480px); padding-top: 10px; }
  .hero-card, .panel-card, .game-card { border-radius: 24px; padding: 16px; }
  .stat-card strong { font-size: 28px; }
  .grid-scroller { height: 70vh; padding: 10px; }
  .match-grid { gap: 6px; padding: 8px; }
  .match-card { min-height: 58px; border-radius: 13px; padding: 5px; }
  .match-card.word strong { font-size: clamp(10px, 2.9vw, 14px); }
  .match-card.meaning strong { font-size: clamp(9px, 2.45vw, 11px); }
  .mode-switch { grid-template-columns: 1fr; border-radius: 22px; }
}

@media (max-width: 860px) {
  body { overflow: auto; }
  .app-shell {
    height: auto;
    min-height: 100vh;
  }
  .hero-card,
  .game-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .profile-card { width: 100%; }
  .dashboard { grid-template-columns: repeat(2, 1fr); }
  .main-layout {
    height: auto;
    grid-template-columns: 1fr;
    overflow: visible;
  }
  .side-panel { height: auto; overflow: visible; }
  .grid-scroller { min-height: 420px; }
}

@media (max-width: 860px) {
  .app-shell { width: min(100% - 8px, 1620px); }
  .target-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .match-grid { grid-template-columns: repeat(var(--match-columns), minmax(58px, 1fr)); width: min(100%, 520px); }
  .match-card.random-card { width: auto; min-height: 68px; }
}

@media (max-width: 720px) {
  .hero-card,
  .game-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .profile-card { width: 100%; }
  .dashboard { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .match-grid { gap: 6px; }
}

@media (max-width: 900px) {
  .app-shell { min-width: 820px; }
  body { overflow: auto hidden; }
}

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

@media (max-width: 520px) {
  .game-kicker {
    white-space: normal;
  }
}

@media (max-width: 760px) {
  .word-source-switch {
    grid-template-columns: 1fr;
    border-radius: 22px;
  }
}

@media (max-width: 900px) {
  html,
  body {
    width: 100%;
    min-height: 100dvh;
  }

  body {
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  .bg-decor {
    display: none !important;
  }

  .app-shell {
    width: min(100% - 12px, 560px) !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 100dvh !important;
    padding: 6px 0 12px !important;
    display: grid !important;
    grid-template-rows: auto auto auto !important;
    gap: 8px !important;
    overflow: visible !important;
  }

  .app-hero,
  .hero-card {
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
    gap: 10px !important;
    padding: 12px !important;
    border-radius: 22px !important;
    overflow: visible !important;
  }

  .hero-content {
    grid-template-columns: 1fr !important;
    gap: 7px !important;
  }

  .game-kicker {
    max-width: 100% !important;
    padding: 5px 10px !important;
    font-size: 10px !important;
    letter-spacing: 0.05em !important;
    white-space: normal !important;
  }

  .hero-content h1 {
    font-size: clamp(24px, 8vw, 34px) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.04em !important;
  }

  .hero-description {
    grid-template-columns: 1fr !important;
    gap: 6px !important;
    font-size: 12px !important;
    line-height: 1.42 !important;
  }

  .hero-description span {
    padding: 7px 9px !important;
    border-radius: 14px !important;
  }

  .profile-card {
    width: 100% !important;
    padding: 10px !important;
    border-radius: 18px !important;
  }

  .profile-card input {
    width: 100% !important;
    height: 38px !important;
    font-size: 14px !important;
  }

  .profile-card .user-code {
    font-size: 12px !important;
  }

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

  .mode-btn {
    padding: 9px 6px !important;
    font-size: 13px !important;
  }

  .main-layout {
    grid-row: 2 !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    min-width: 0 !important;
    padding: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    gap: 8px !important;
    overflow: visible !important;
  }

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

  .game-card {
    grid-column: 1 !important;
    grid-row: 1 !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 8px !important;
    border-radius: 22px !important;
    overflow: visible !important;
  }

  .side-panel .panel-card:nth-child(2) {
    grid-column: 1 !important;
    grid-row: 2 !important;
  }

  .side-panel .panel-card:nth-child(1) {
    grid-column: 1 !important;
    grid-row: 3 !important;
  }

  .side-panel .panel-card:nth-child(4) {
    grid-column: 1 !important;
    grid-row: 4 !important;
    align-self: stretch !important;
    height: auto !important;
  }

  .side-panel .panel-card:nth-child(3) {
    grid-column: 1 !important;
    grid-row: 5 !important;
    align-self: stretch !important;
    height: auto !important;
  }

  .side-panel .panel-card,
  .panel-card {
    width: 100% !important;
    min-height: 0 !important;
    padding: 10px !important;
    border-radius: 20px !important;
    overflow: visible !important;
  }

  .panel-title-row {
    margin-bottom: 8px !important;
  }

  .panel-title-row h2,
  .controls h2 {
    font-size: 17px !important;
  }

  .game-toolbar {
    display: block !important;
    padding-bottom: 6px !important;
    margin-bottom: 4px !important;
    text-align: center !important;
  }

  .game-toolbar > div:first-child {
    width: 100% !important;
  }

  .game-toolbar p#selectionPreview {
    display: block !important;
    margin: 5px 0 0 !important;
    font-size: 12px !important;
    line-height: 1.32 !important;
  }

  .word-source-switch {
    width: 100% !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 4px !important;
    margin: 0 auto 5px !important;
    padding: 4px !important;
    border-radius: 18px !important;
  }

  .source-btn {
    padding: 7px 3px !important;
    font-size: 11px !important;
    line-height: 1.12 !important;
    white-space: normal !important;
  }

  .grid-scroller {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 6px !important;
    border-radius: 18px !important;
    overflow: hidden !important;
  }

  .grid-scroller.match-mode {
    min-height: 360px !important;
  }

  .grid-scroller.letter-mode {
    min-height: min(88vw, 520px) !important;
    padding: 6px !important;
  }

  .match-grid {
    width: 100% !important;
    max-width: 100% !important;
    max-height: none !important;
    grid-template-columns: repeat(var(--match-columns), minmax(0, 1fr)) !important;
    grid-auto-rows: minmax(58px, auto) !important;
    gap: 5px !important;
    padding: 6px !important;
    border-radius: 16px !important;
    overflow: visible !important;
  }

  .match-card,
  .match-card.random-card {
    width: auto !important;
    height: auto !important;
    min-height: clamp(58px, 16vw, 78px) !important;
    padding: 5px !important;
    border-radius: 14px !important;
  }

  .match-card.random-card.word strong,
  .match-card.word strong {
    font-size: clamp(12px, 3.35vw, 17px) !important;
    line-height: 1.06 !important;
  }

  .match-card.random-card.meaning strong,
  .match-card.meaning strong {
    font-size: clamp(10px, 2.9vw, 14px) !important;
    line-height: 1.18 !important;
  }

  .letter-grid {
    max-width: 100% !important;
    max-height: none !important;
    padding: 6px !important;
    gap: var(--letter-gap, 3px) !important;
    border-radius: 18px !important;
  }

  .cell {
    border-radius: clamp(8px, calc(var(--cell) * 0.16), 13px) !important;
  }

  .first-letter-heart {
    top: clamp(1px, calc(var(--cell) * 0.04), 4px) !important;
    left: clamp(1px, calc(var(--cell) * 0.04), 4px) !important;
  }

  .controls {
    gap: 8px !important;
  }

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

  .primary-btn,
  .ghost-btn,
  .mini-btn {
    min-height: 36px !important;
    padding: 8px 10px !important;
    font-size: 13px !important;
  }

  .range-label {
    font-size: 12px !important;
  }

  input[type="range"] {
    width: 100% !important;
    height: 26px !important;
  }

  .target-list {
    height: auto !important;
    min-height: 0 !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: none !important;
    grid-auto-rows: auto !important;
    gap: 6px !important;
    overflow: visible !important;
  }

  .target-item {
    min-height: 44px !important;
    padding: 7px !important;
    border-radius: 14px !important;
  }

  .target-item .word {
    font-size: 13px !important;
  }

  .target-item .tag {
    display: block !important;
    font-size: 10px !important;
  }

  .leaderboard {
    max-height: 300px !important;
    overflow-y: auto !important;
    grid-template-rows: none !important;
    grid-auto-rows: auto !important;
    gap: 6px !important;
    padding-right: 2px !important;
  }

  .leaderboard li {
    min-height: 48px !important;
    padding: 8px 9px !important;
    font-size: 14px !important;
    white-space: normal !important;
  }

  .leaderboard li strong {
    font-size: 18px !important;
  }

  .leaderboard small {
    font-size: 12px !important;
  }

  .level-map {
    height: auto !important;
    min-height: 0 !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    grid-template-rows: none !important;
    grid-auto-rows: 36px !important;
    gap: 5px !important;
    overflow: visible !important;
  }

  .level-dot {
    height: 36px !important;
    border-radius: 12px !important;
    font-size: 12px !important;
  }

  .dashboard {
    grid-row: 3 !important;
    width: 100% !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
    padding: 7px !important;
    border-radius: 20px !important;
  }

  .stat-card {
    min-height: 58px !important;
    padding: 8px !important;
    border-radius: 16px !important;
  }

  .stat-card span,
  .stat-card small {
    font-size: 11px !important;
  }

  .stat-card strong {
    font-size: 22px !important;
  }
}

@media (max-width: 420px) {
  .app-shell {
    width: calc(100% - 8px) !important;
    gap: 6px !important;
  }

  .hero-description {
    display: none !important;
  }

  .word-source-switch {
    gap: 3px !important;
  }

  .source-btn {
    font-size: 10px !important;
    padding: 6px 2px !important;
  }

  .grid-scroller.match-mode {
    min-height: 330px !important;
  }

  .match-grid {
    gap: 4px !important;
    padding: 5px !important;
  }

  .match-card,
  .match-card.random-card {
    min-height: 54px !important;
    padding: 4px !important;
  }

  .match-card.random-card.word strong,
  .match-card.word strong {
    font-size: 11px !important;
  }

  .match-card.random-card.meaning strong,
  .match-card.meaning strong {
    font-size: 9.5px !important;
  }

  .target-list {
    gap: 5px !important;
  }

  .target-item {
    min-height: 40px !important;
    padding: 6px !important;
  }

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

@media (max-width: 900px) {
  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(84px, 1fr) minmax(66px, 0.75fr) minmax(64px, 0.7fr) !important;
    column-gap: 8px !important;
  }

  .leaderboard li.leader-entry {
    min-height: 46px !important;
  }

  .leaderboard .leader-rank,
  .leaderboard .leader-score {
    font-size: 14px !important;
  }

  .leaderboard .leader-time {
    font-size: 16px !important;
  }
}

@media (max-width: 760px) {
  .profile-card label[for="playerName"] {
    font-size: 14px !important;
  }
}

@media (max-width: 760px) {
  .marlous-link {
    min-height: 30px !important;
    padding: 7px 12px !important;
    font-size: 12px !important;
  }
}

@media (max-width: 760px) {
  .marlous-link {
    align-self: flex-end !important;
    min-height: 20px !important;
    padding: 4px 8px !important;
    font-size: 8px !important;
  }
}

@media (max-width: 760px) {
  #playerTitle {
    gap: 6px !important;
  }

  .title-lollipop {
    width: 14px !important;
    height: 14px !important;
  }

  .title-lollipop::after {
    height: 11px !important;
    left: 9px !important;
    top: 11px !important;
  }
}

@media (max-width: 760px) {
  .modal-copy {
    font-size: 13px !important;
  }

  .modal-input {
    font-size: 17px !important;
  }

  .rank-detail-list p {
    grid-template-columns: 76px 1fr;
  }
}

@media (max-width: 760px) {
  .rank-detail-level-pill {
    gap: 8px !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
  }

  .rank-detail-level-pill .title-badge {
    gap: 5px !important;
  }
}

@media (max-width: 760px) {
  .rank-detail-level-row {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}

@media (max-width: 760px) {
  .rank-detail-card {
    width: min(520px, calc(100vw - 22px)) !important;
  }

  .rank-detail-level-row {
    grid-template-columns: 48px minmax(0, 1fr) !important;
  }

  .rank-detail-level-pill {
    flex-wrap: wrap !important;
    white-space: normal !important;
    row-gap: 6px !important;
  }

  .rank-detail-level-pill .title-badge {
    flex: 1 1 100% !important;
    flex-wrap: wrap !important;
    white-space: normal !important;
  }

  .rank-detail-level-pill .title-name,
  .rank-detail-level-pill .title-stars {
    white-space: normal !important;
  }

  .rank-detail-level-pill > strong {
    margin-left: auto !important;
  }

  .complete-score-grid,
  .complete-action-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .modal-backdrop {
    padding: 10px !important;
    overflow-y: auto !important;
    align-items: center !important;
  }

  .rank-detail-card,
  .level-complete-card {
    width: min(94vw, 420px) !important;
    max-height: calc(100dvh - 20px) !important;
    overflow-y: auto !important;
    padding: 20px 14px 16px !important;
    border-radius: 26px !important;
  }

  .rank-detail-card .modal-sparkle,
  .level-complete-card .modal-sparkle {
    width: 44px !important;
    height: 44px !important;
    margin: -2px auto 8px !important;
    font-size: 22px !important;
  }

  .rank-detail-card h2,
  .level-complete-card h2 {
    font-size: 28px !important;
    line-height: 1.08 !important;
    margin-bottom: 4px !important;
    letter-spacing: -0.02em !important;
  }

  .rank-detail-card .eyebrow,
  .level-complete-card .eyebrow {
    margin-bottom: 4px !important;
    font-size: 11px !important;
  }

  .level-complete-card .modal-copy {
    margin: 0 auto 10px !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
  }

  .rank-detail-list {
    gap: 8px !important;
    margin: 12px 0 4px !important;
  }

  .rank-detail-list p {
    grid-template-columns: 72px minmax(0, 1fr) !important;
    gap: 8px !important;
    padding: 9px 10px !important;
    border-radius: 16px !important;
  }

  .rank-detail-list span {
    font-size: 12px !important;
    line-height: 1.2 !important;
  }

  .rank-detail-list strong {
    font-size: 14px !important;
    line-height: 1.35 !important;
  }

  .rank-detail-level-row {
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
    gap: 7px !important;
    padding: 10px !important;
  }

  .rank-detail-level-row > span {
    display: inline-flex !important;
    width: fit-content !important;
    justify-self: start !important;
    align-items: center !important;
    padding: 5px 9px !important;
    border-radius: 999px !important;
    background: rgba(255, 126, 182, 0.12) !important;
    color: #9a6d97 !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
  }

  #rankDetailLevel {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .rank-detail-level-pill {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: auto !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: nowrap !important;
    gap: 7px !important;
    padding: 10px 10px !important;
    white-space: normal !important;
    overflow: visible !important;
    text-align: center !important;
  }

  .rank-detail-level-pill .title-badge {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    gap: 5px 6px !important;
    white-space: normal !important;
    overflow: visible !important;
    text-align: center !important;
  }

  .rank-detail-level-pill .title-lollipop {
    flex: 0 0 auto !important;
  }

  .rank-detail-level-pill .title-name {
    flex: 0 1 auto !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
    line-height: 1.25 !important;
    text-align: center !important;
  }

  .rank-detail-level-pill .title-stars {
    width: 100% !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    line-height: 1.15 !important;
    text-align: center !important;
  }

  .rank-detail-level-pill > strong {
    flex: 0 0 auto !important;
    align-self: center !important;
    margin: 0 !important;
    padding: 4px 10px !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.44) !important;
    font-size: 14px !important;
    line-height: 1 !important;
  }

  .complete-score-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin: 12px 0 0 !important;
  }

  .complete-score-grid div {
    padding: 10px 9px !important;
    border-radius: 16px !important;
    text-align: center !important;
  }

  .complete-score-grid span {
    font-size: 11px !important;
    margin-bottom: 5px !important;
  }

  .complete-score-grid strong {
    font-size: 18px !important;
    line-height: 1.08 !important;
    word-break: keep-all !important;
  }

  .complete-action-row {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin-top: 12px !important;
  }

  .complete-action-row button {
    min-height: 42px !important;
    padding: 10px 8px !important;
    border-radius: 16px !important;
    font-size: 14px !important;
    line-height: 1.15 !important;
  }

  #completeNextLevel {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 380px) {
  .rank-detail-card,
  .level-complete-card {
    width: calc(100vw - 16px) !important;
    padding: 18px 12px 14px !important;
    border-radius: 22px !important;
  }

  .rank-detail-list p {
    grid-template-columns: 64px minmax(0, 1fr) !important;
  }

  .complete-score-grid,
  .complete-action-row {
    grid-template-columns: 1fr !important;
  }

  #completeNextLevel {
    grid-column: auto !important;
  }
}

@media (max-width: 760px) {
  .rank-detail-level-row {
    grid-template-columns: 42px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 9px 10px !important;
  }

  .rank-detail-level-row > span {
    display: inline-flex !important;
    width: auto !important;
    justify-self: start !important;
    align-self: center !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: #9a6d97 !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  #rankDetailLevel {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  .rank-detail-level-pill {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 40px !important;
    height: 40px !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
    padding: 7px 9px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-align: left !important;
    border-radius: 999px !important;
  }

  .rank-detail-level-pill .title-badge {
    flex: 1 1 auto !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    flex-wrap: nowrap !important;
    gap: 4px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-align: left !important;
  }

  .rank-detail-level-pill .title-lollipop {
    flex: 0 0 auto !important;
    transform: scale(0.86) !important;
    transform-origin: center !important;
    margin-right: 0 !important;
  }

  .rank-detail-level-pill .title-name {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
    line-height: 1.1 !important;
    text-align: left !important;
    font-size: 12px !important;
  }

  .rank-detail-level-pill .title-stars {
    flex: 0 1 auto !important;
    width: auto !important;
    max-width: 54px !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    line-height: 1 !important;
    text-align: left !important;
    font-size: 10px !important;
    letter-spacing: -0.05em !important;
  }

  .rank-detail-level-pill > strong {
    flex: 0 0 auto !important;
    align-self: center !important;
    margin: 0 0 0 2px !important;
    padding: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    font-size: 12px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }
}

@media (max-width: 380px) {
  .rank-detail-level-row {
    grid-template-columns: 36px minmax(0, 1fr) !important;
    gap: 6px !important;
    padding: 8px 8px !important;
  }

  .rank-detail-level-row > span {
    font-size: 11px !important;
  }

  .rank-detail-level-pill {
    height: 38px !important;
    min-height: 38px !important;
    padding: 6px 7px !important;
    gap: 4px !important;
  }

  .rank-detail-level-pill .title-lollipop {
    transform: scale(0.78) !important;
  }

  .rank-detail-level-pill .title-name {
    font-size: 11px !important;
  }

  .rank-detail-level-pill .title-stars {
    max-width: 44px !important;
    font-size: 9px !important;
  }

  .rank-detail-level-pill > strong {
    font-size: 11px !important;
  }
}

@media (max-width: 760px) {
  .sound-controls {
    width: 100%;
    gap: 5px;
    margin: 0 auto 5px !important;
  }

  .sound-toggle,
  .sound-volume {
    width: 100%;
    justify-content: center;
    padding: 7px 8px !important;
    font-size: 11px !important;
  }

  .sound-volume input {
    flex: 1;
    max-width: 180px;
  }
}

@media (max-width: 760px) {
  .toolbar-controls {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 5px !important;
  }

  .toolbar-controls .word-source-switch,
  .toolbar-controls .sound-controls {
    width: 100% !important;
    margin: 0 auto 5px !important;
  }

  .toolbar-controls .sound-controls {
    display: grid !important;
    grid-template-columns: minmax(96px, 0.8fr) minmax(0, 1.2fr) !important;
    gap: 5px !important;
  }

  .toolbar-controls .sound-toggle,
  .toolbar-controls .sound-volume {
    width: auto !important;
    min-width: 0 !important;
  }
}

@media (max-width: 760px) {
  .leaderboard-title-row {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
  }

  .leaderboard-title-row h2 {
    grid-column: 1 / -1;
  }

  .leaderboard-select {
    width: 100%;
  }

  .qq-email-row {
    grid-template-columns: 1fr;
  }

  .qq-email-row span {
    text-align: center;
  }
}

@media (max-width: 760px) {
  .profile-account-row,
  .profile-school {
    grid-column: 1 / -1 !important;
  }

  .profile-card .user-code-display {
    flex: 1 1 auto !important;
    justify-content: center !important;
    min-height: 32px !important;
  }

  .logout-btn {
    min-height: 32px !important;
    padding-inline: 12px !important;
  }

  .level-pill {
    grid-template-columns: minmax(0, 1fr) auto !important;
    padding: 9px 10px !important;
  }

  #playerTitle .title-stars {
    font-size: 0.74em !important;
    letter-spacing: -0.04em !important;
  }
}

@media (max-width: 380px) {
  .level-pill {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    text-align: center !important;
  }

  #playerTitle {
    justify-content: center !important;
  }

  #playerRank {
    justify-self: center !important;
  }
}

@media (max-width: 760px) {
  .profile-name-row {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }

  .level-pill {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-items: stretch !important;
    text-align: left !important;
  }

  #playerTitle {
    justify-content: flex-start !important;
  }

  #playerTitle .title-name {
    max-width: 52% !important;
  }

  #playerTitle .title-stars {
    max-width: 58px !important;
  }

  #playerRank {
    justify-self: auto !important;
  }
}

@media (max-width: 380px) {
  .level-pill {
    display: flex !important;
    grid-template-columns: none !important;
  }

  #playerTitle .title-name {
    max-width: 46% !important;
  }

  #playerTitle .title-stars {
    max-width: 50px !important;
    font-size: 10px !important;
  }
}

@media (max-width: 760px) {
  .profile-card {
    grid-template-columns: auto minmax(0, 1fr) !important;
    column-gap: 5px !important;
  }
}

@media (max-width: 760px) {
  .profile-card label#profileSchoolLabel,
  .profile-card label[for="playerName"] {
    max-width: 96px !important;
  }

  .reset-inline-row {
    grid-template-columns: minmax(72px, 0.74fr) minmax(68px, 0.7fr) minmax(76px, 0.8fr) !important;
    gap: 5px !important;
  }

  .reset-inline-row .modal-input,
  .reset-inline-row .modal-action,
  .reset-inline-row .modal-secondary {
    font-size: 11px !important;
    padding-inline: 6px !important;
  }

  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1fr) minmax(62px, auto) minmax(56px, auto) !important;
    column-gap: 6px !important;
  }
}

@media (max-width: 420px) {
  .verify-inline-row,
  .profile-verify-row {
    grid-template-columns: 1fr !important;
  }

  .compact-account-modal .qq-email-row,
  .compact-qq-row {
    grid-template-columns: 1fr auto !important;
  }
}

@media (max-width: 420px) {
  .verify-inline-row,
  .password-reset-panel .verify-inline-row,
  .reset-inline-row,
  .register-inline-row {
    grid-template-columns: minmax(62px, 0.76fr) minmax(62px, 0.76fr) minmax(48px, 0.58fr) !important;
    gap: 4px !important;
  }

  .verify-inline-row .modal-input,
  .verify-inline-row .modal-action,
  .verify-inline-row .modal-secondary {
    font-size: 10.5px !important;
    padding-left: 4px !important;
    padding-right: 4px !important;
  }

  .profile-verify-row {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 760px) {
  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1fr) 74px 60px !important;
    column-gap: 6px !important;
  }

  .leaderboard li.leaderboard-head {
    font-size: 11px !important;
  }

  .leaderboard .leader-time,
  .leaderboard .leader-score {
    font-size: 13px !important;
  }
}

@media (max-width: 760px) {
  .leaderboard-title-row {
    grid-template-columns: 1fr !important;
    gap: 6px !important;
  }

  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1fr) 8.5ch 6ch !important;
    column-gap: 7px !important;
  }
}

@media (max-width: 760px) {
  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1fr) 9ch 6.5ch !important;
    column-gap: 7px !important;
  }

  .leaderboard .leader-head-value,
  .leaderboard .leader-time,
  .leaderboard .leader-time-value {
    width: 9ch !important;
    min-width: 9ch !important;
  }

  .leaderboard .leader-head-extra,
  .leaderboard .leader-score {
    width: 6.5ch !important;
    min-width: 6.5ch !important;
  }

  .leaderboard .leader-count-value {
    min-width: 3.5ch !important;
  }
}

@media (max-width: 760px) {
  .leaderboard li.leaderboard-head,
  .leaderboard li.leader-entry {
    grid-template-columns: minmax(0, 1fr) 86px 60px !important;
    column-gap: 7px !important;
  }

  .leaderboard .leader-head-value,
  .leaderboard .leader-time,
  .leaderboard .leader-time-value {
    width: 86px !important;
    min-width: 86px !important;
    max-width: 86px !important;
  }

  .leaderboard .leader-head-extra,
  .leaderboard .leader-score {
    width: 60px !important;
    min-width: 60px !important;
    max-width: 60px !important;
  }

  .leaderboard .leader-count-value {
    min-width: 34px !important;
  }

  .profile-action-row {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 420px) {
  .compact-account-modal.auth-mode-login .auth-login-row {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .auth-login-row .remember-account-row {
    justify-self: start !important;
  }
}

@media (max-width: 520px) {
  .profile-name-row {
    grid-template-columns: minmax(0, 1fr) auto !important;
    justify-content: stretch !important;
  }

  .profile-card input#playerName[readonly] {
    width: 100% !important;
  }
}

@media (max-width: 520px) {
  .profile-name-row {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }
}

@media (max-width: 520px) {
  .stat-card small.best-stat-chip,
  .stat-card small#bestTime,
  .stat-card small#mistakes {
    gap: 5px !important;
    padding-inline: 7px !important;
  }

  .best-stat-label,
  .best-stat-sub {
    font-size: 9px !important;
  }

  .best-stat-value {
    font-size: 11px !important;
  }
}

@media (max-width: 760px) {
  .stat-value-line {
    gap: 6px !important;
  }

  .stat-value-line .best-stat-chip,
  .stat-value-line small#bestTime,
  .stat-value-line small#mistakes {
    max-width: 58% !important;
    padding-inline: 7px !important;
  }

  .stat-value-line .best-stat-label,
  .stat-value-line .best-stat-sub {
    font-size: 9px !important;
  }

  .stat-value-line .best-stat-value {
    font-size: 13px !important;
  }
}

@media (max-width: 760px) {
  .stat-value-line {
    gap: 7px !important;
  }

  .stat-value-line .best-stat-chip,
  .stat-value-line small#bestTime,
  .stat-value-line small#mistakes {
    min-height: 30px !important;
    padding: 5px 8px !important;
    gap: 5px !important;
    max-width: 62% !important;
  }

  .stat-value-line .best-stat-label,
  .stat-value-line .best-stat-sub {
    font-size: 11px !important;
  }

  .stat-value-line .best-stat-value {
    font-size: 15px !important;
  }
}

@media (max-width: 520px) {
  .profile-action-row {
    grid-template-columns: 0.9fr 1fr 0.72fr !important;
    gap: 6px !important;
  }

  .profile-action-row button {
    padding-left: 7px !important;
    padding-right: 7px !important;
    font-size: 12px !important;
  }

  .feedback-textarea {
    height: 250px !important;
    min-height: 250px !important;
    max-height: none !important;
  }
}

@media (max-width: 420px) {
  .email-change-modal-card .profile-action-row {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr) minmax(0, 0.78fr) !important;
    gap: 5px !important;
  }

  .email-change-modal-card .profile-action-row button {
    min-height: 36px !important;
    padding-left: 5px !important;
    padding-right: 5px !important;
    font-size: 11.5px !important;
    letter-spacing: -0.02em !important;
  }

  .modal-close-btn.account-modal-close {
    top: 10px !important;
    right: 10px !important;
    width: 31px !important;
    height: 31px !important;
    font-size: 20px !important;
  }
}

@media (max-width: 420px) {
  .auth-code-field .code-input-status-row {
    grid-template-columns: minmax(0, 1fr) 58px !important;
    gap: 6px !important;
  }

  .register-code-hint {
    min-width: 58px !important;
    padding-inline: 4px 5px !important;
    font-size: 11px !important;
  }

  .register-code-icon {
    width: 16px !important;
    height: 16px !important;
    font-size: 11px !important;
  }
}

@media (max-width: 520px) {
  .profile-name-row {
    grid-template-columns: minmax(0, 1fr) auto auto !important;
    gap: 6px !important;
  }

  .profile-login-btn,
  .logout-btn {
    min-width: 48px !important;
    padding: 6px 10px !important;
    font-size: 12px !important;
  }
}

/* 2026-05 mobile final override: follow uploaded styles.css on mobile only; keep desktop unchanged.
   Exception requested: target word + phonetic are plain text, not boxed controls. */
@media (max-width: 900px) {
  html,
  body {
    width: 100% !important;
    height: auto !important;
    min-width: 0 !important;
    min-height: 100dvh !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  body {
    touch-action: manipulation !important;
  }

  .target-word-button {
    appearance: none !important;
    -webkit-appearance: none !important;
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    border: 0 !important;
    outline: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    display: inline-flex !important;
    align-items: baseline !important;
    gap: 4px !important;
    color: inherit !important;
    text-align: left !important;
  }

  .target-word-button .word,
  .target-word-button .phonetic {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
  }

  .target-word-button:focus,
  .target-word-button:focus-visible,
  .target-word-button:hover {
    outline: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }
}
}


/* 2026-05 mobile strict reference override: phone follows uploaded styles.css; desktop-only additions above do not affect mobile.
   Requested exception: in mobile "本关单词", word and phonetic are plain text with no box/button styling. */
@media (max-width: 900px) {
  html,
  body {
    width: 100% !important;
    height: auto !important;
    min-width: 0 !important;
    min-height: 100dvh !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  body {
    touch-action: manipulation !important;
    overscroll-behavior-y: auto !important;
  }

  .app-shell {
    height: auto !important;
    min-height: 100dvh !important;
    overflow: visible !important;
  }

  .main-layout,
  .game-card,
  .side-panel .panel-card,
  .panel-card {
    overflow: visible !important;
  }

  .target-word-button {
    appearance: none !important;
    -webkit-appearance: none !important;
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    border: 0 !important;
    outline: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    display: inline-flex !important;
    align-items: baseline !important;
    gap: 4px !important;
    color: inherit !important;
    text-align: left !important;
    font: inherit !important;
  }

  .target-word-button .word,
  .target-word-button .phonetic,
  .target-item .target-word-button .word,
  .target-item .phonetic {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
  }

  .target-word-button:focus,
  .target-word-button:focus-visible,
  .target-word-button:hover {
    outline: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }
}

/* 2026-05 desktop-only final patch: halve the "关卡与玩法" card height and make "本关单词" two columns. */
@media (min-width: 901px) {
  .main-layout {
    grid-template-rows: minmax(0, 1.5fr) minmax(0, 8.5fr) !important;
  }

  .side-panel .panel-card:nth-child(2) {
    grid-column: 1 !important;
    grid-row: 1 !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  .side-panel .panel-card:nth-child(1) {
    grid-column: 1 !important;
    grid-row: 2 !important;
  }

  .target-list {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: repeat(5, minmax(0, 1fr)) !important;
    grid-auto-flow: row !important;
    grid-auto-rows: minmax(0, 1fr) !important;
    gap: clamp(1px, 0.3vmin, 3px) !important;
    overflow: hidden !important;
  }

  .target-item {
    min-width: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }
}

/* 2026-05 requested title/status override: only adjust the specified title sizes and mobile bottom stats layout. */
@media (min-width: 901px) {
  .app-hero .game-kicker,
  .hero-card .game-kicker {
    font-size: clamp(11.2px, 0.98vw, 15.4px) !important;
  }

  .app-hero .hero-content h1,
  .hero-card .hero-content h1 {
    font-size: clamp(26.4px, 2.64vw, 46.2px) !important;
  }
}

@media (max-width: 900px) {
  .app-hero .hero-content h1,
  .hero-card .hero-content h1 {
    font-size: clamp(19.44px, 6.48vw, 27.54px) !important;
  }

  .dashboard {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-areas:
      "level growth"
      "timer timer"
      "score score" !important;
  }

  .dashboard .stat-card:nth-child(1) { grid-area: level !important; }
  .dashboard .stat-card:nth-child(2) { grid-area: timer !important; }
  .dashboard .stat-card:nth-child(3) { grid-area: score !important; }
  .dashboard .stat-card:nth-child(4) { grid-area: growth !important; }
}
