:root {
  --dg-bg: #05050c;
  --dg-panel: rgba(9, 8, 18, 0.88);
  --dg-panel-soft: rgba(14, 12, 28, 0.72);
  --dg-border: rgba(132, 76, 255, 0.27);
  --dg-border-strong: rgba(132, 76, 255, 0.48);
  --dg-purple: #7b42ff;
  --dg-blue: #2ea8ff;
  --dg-pink: #ff2e6f;
  --dg-text: rgba(255,255,255,.94);
  --dg-muted: rgba(255,255,255,.62);
}

* { box-sizing: border-box; }
html { background: var(--dg-bg); }
body.games-body {
  min-height: 100vh;
  margin: 0;
  color: var(--dg-text);
  background:
    radial-gradient(circle at 15% -8%, rgba(123,66,255,.22), transparent 34%),
    radial-gradient(circle at 92% 0%, rgba(46,168,255,.15), transparent 30%),
    linear-gradient(135deg, #05050c 0%, #080516 54%, #03101a 100%);
  overflow-x: hidden;
}

body.games-body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(rgba(255,255,255,.017) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.014) 1px, transparent 1px);
  background-size: 72px 72px;
  opacity: .23;
  mask-image: linear-gradient(to bottom, black, transparent 78%);
}

.games-topbar,
.games-shell { position: relative; z-index: 2; }

.games-topbar {
  width: min(1180px, calc(100% - 32px));
  min-height: 68px;
  margin: 18px auto 0;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  border: 1px solid var(--dg-border);
  border-radius: 22px;
  background: rgba(5,5,13,.86);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 20px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.055);
}

.games-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: #fff;
  flex: 0 0 auto;
}

.games-brand img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  border-radius: 13px;
  border: 1px solid rgba(123,66,255,.46);
  box-shadow: 0 0 22px rgba(123,66,255,.28);
}

.games-brand span { display: grid; gap: 1px; line-height: 1.05; }
.games-brand strong { font-size: 1rem; letter-spacing: .02em; font-weight: 1000; }
.games-brand small { color: rgba(255,255,255,.58); font-size: .7rem; font-weight: 1000; letter-spacing: .22em; text-transform: uppercase; }

.games-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}
.games-nav a {
  min-height: 38px;
  padding: 0 15px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 13px;
  color: rgba(255,255,255,.72);
  text-decoration: none;
  font-weight: 950;
  font-size: .92rem;
}
.games-nav a:hover,
.games-nav a.is-active {
  color: #fff;
  background: rgba(132,76,255,.15);
}

.games-shell {
  width: min(1180px, calc(100% - 32px));
  margin: 26px auto 68px;
}

.games-panel {
  padding: clamp(18px, 3vw, 30px);
  border: 1px solid var(--dg-border);
  border-radius: 30px;
  background:
    radial-gradient(circle at 10% 0%, rgba(123,66,255,.18), transparent 34%),
    radial-gradient(circle at 95% 0%, rgba(46,168,255,.10), transparent 32%),
    linear-gradient(145deg, rgba(12,9,25,.93), rgba(5,8,18,.88));
  box-shadow: 0 28px 86px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.055);
}

.games-panel-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 390px);
  gap: 22px;
  align-items: end;
  margin-bottom: 22px;
}

.games-label {
  width: fit-content;
  margin: 0 0 10px;
  padding: 6px 10px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  color: rgba(255,255,255,.70);
  text-transform: uppercase;
  letter-spacing: .13em;
  font-size: .7rem;
  font-weight: 1000;
}

.games-panel h1 {
  margin: 0;
  font-size: clamp(2rem, 4.2vw, 3.8rem);
  line-height: .98;
  letter-spacing: -.06em;
  background: linear-gradient(90deg, #fff 0%, #d8ccff 58%, #78bdff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.games-subtitle {
  max-width: 570px;
  margin: 12px 0 0;
  color: var(--dg-muted);
  line-height: 1.55;
  font-weight: 760;
}

.games-search-wrap { position: relative; }
.games-search-label {
  display: block;
  margin: 0 0 8px;
  color: rgba(255,255,255,.65);
  text-transform: uppercase;
  font-size: .74rem;
  letter-spacing: .13em;
  font-weight: 1000;
}
.games-search-box {
  height: 50px;
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 11px;
  align-items: center;
  padding: 0 15px;
  border: 1px solid rgba(132,76,255,.34);
  border-radius: 17px;
  background: rgba(0,0,0,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.052), 0 14px 40px rgba(0,0,0,.22);
}
.games-search-box svg { width: 21px; height: 21px; fill: rgba(96,185,255,.88); }
.games-search-box input { width: 100%; border: 0; outline: 0; background: transparent; color: #fff; font: inherit; font-weight: 820; }
.games-search-box input::placeholder { color: rgba(255,255,255,.42); }

.games-suggestions[hidden] { display: none !important; }
.games-suggestions {
  position: absolute;
  z-index: 20;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  display: grid;
  gap: 6px;
  padding: 9px;
  border: 1px solid rgba(132,76,255,.34);
  border-radius: 16px;
  background: rgba(8,7,17,.98);
  box-shadow: 0 22px 64px rgba(0,0,0,.45);
}
.games-suggestion {
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border: 0;
  border-radius: 12px;
  padding: 0 12px;
  background: rgba(255,255,255,.055);
  color: #fff;
  cursor: pointer;
  font-weight: 900;
}
.games-suggestion:hover { background: rgba(132,76,255,.18); }
.games-suggestion small { color: rgba(96,185,255,.88); font-weight: 1000; }

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

.game-card {
  position: relative;
  min-height: 232px;
  padding: 18px;
  display: grid;
  grid-template-columns: 92px 1fr;
  grid-template-rows: auto 1fr auto;
  column-gap: 18px;
  row-gap: 12px;
  overflow: hidden;
  border: 1px solid var(--dg-border);
  border-radius: 24px;
  background: linear-gradient(145deg, rgba(10,9,19,.95), rgba(7,8,17,.88));
  box-shadow: 0 20px 62px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.045);
}
.game-card::before {
  content: "";
  position: absolute;
  inset: -1px;
  pointer-events: none;
  border-radius: inherit;
  background:
    radial-gradient(circle at 18% 10%, rgba(123,66,255,.18), transparent 31%),
    radial-gradient(circle at 95% 6%, rgba(46,168,255,.10), transparent 28%);
  opacity: .9;
}
.game-card > * { position: relative; z-index: 1; }
.game-card[hidden] { display: none !important; }

.game-visual {
  grid-column: 1;
  grid-row: 1 / span 3;
  display: grid;
  grid-template-rows: auto auto;
  align-content: start;
  justify-items: center;
  gap: 10px;
}
.game-icon {
  width: 86px;
  height: 86px;
  display: grid;
  place-items: center;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(122,65,255,.95), rgba(45,166,255,.88));
  box-shadow: 0 18px 38px rgba(123,66,255,.22), inset 0 1px 0 rgba(255,255,255,.20);
  color: #fff;
}
.game-icon svg {
  width: 80px;
  height: 80px;
  display: block;
  overflow: visible;
}
.icon-tile-bg { fill: rgba(6, 7, 16, .18); stroke: rgba(255,255,255,.18); stroke-width: 1.2; }
.icon-board-line,
.icon-sudoku-bold,
.icon-sudoku-thin {
  fill: none;
  stroke: rgba(255,255,255,.78);
  stroke-linecap: round;
  stroke-linejoin: round;
}
.icon-board-line { stroke-width: 5.5; opacity: .86; }
.icon-x { stroke: #ff2e6f; stroke-width: 8; stroke-linecap: round; filter: drop-shadow(0 0 5px rgba(255,46,111,.65)); }
.icon-o { fill: none; stroke: #63c7ff; stroke-width: 7; filter: drop-shadow(0 0 5px rgba(46,168,255,.7)); }
.icon-sudoku-thin { stroke-width: 1.2; opacity: .35; }
.icon-sudoku-bold { stroke-width: 3.1; opacity: .82; }
.icon-number,
.icon-letter {
  font-family: Inter, system-ui, -apple-system, Segoe UI, sans-serif;
  text-anchor: middle;
  dominant-baseline: central;
  fill: rgba(255,255,255,.92);
  font-weight: 1000;
  font-size: 18px;
}
.icon-number-blue { fill: #77ccff; }
.icon-number-pink { fill: #ff4a83; }
.icon-pencil { fill: rgba(255,255,255,.92); opacity: .93; filter: drop-shadow(0 2px 6px rgba(0,0,0,.35)); }
.icon-pencil-line { fill: none; stroke: rgba(6,7,16,.76); stroke-width: 3; stroke-linecap: round; }
.icon-word-petal { fill: rgba(255,255,255,.90); stroke: rgba(8,8,18,.90); stroke-width: 4; }
.icon-word-center { fill: rgba(123,66,255,.95); stroke: rgba(255,255,255,.92); stroke-width: 3; filter: drop-shadow(0 0 9px rgba(123,66,255,.65)); }
.icon-letter { fill: #11121c; font-size: 18px; }
.icon-letter-main { fill: #fff; font-size: 23px; }

.game-help {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(127,76,255,.28);
  border-radius: 15px;
  background: linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
  color: rgba(255,255,255,.92);
  font-size: 1.02rem;
  font-weight: 1000;
  cursor: pointer;
  transition: 160ms ease;
}
.game-help:hover {
  transform: translateY(-1px);
  border-color: rgba(167,105,255,.70);
  background: rgba(127,76,255,.14);
  color: #fff;
}

.game-content {
  grid-column: 2;
  grid-row: 1 / span 2;
  min-width: 0;
}
.game-kicker {
  width: fit-content;
  margin: 0 0 12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.085);
  color: rgba(255,255,255,.72);
  text-transform: uppercase;
  font-size: .72rem;
  letter-spacing: .11em;
  font-weight: 1000;
}
.game-content h2 {
  margin: 0;
  color: #fff;
  font-size: clamp(1.7rem, 3vw, 2.45rem);
  line-height: 1;
  letter-spacing: -.045em;
}
.game-content p:last-child {
  margin: 12px 0 0;
  color: var(--dg-muted);
  line-height: 1.42;
  font-weight: 760;
}

.game-action {
  grid-column: 2;
  grid-row: 3;
  justify-self: start;
  min-width: 126px;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--dg-purple), var(--dg-blue));
  color: #fff;
  text-decoration: none;
  font-weight: 1000;
  box-shadow: 0 15px 38px rgba(46,168,255,.16);
}
.game-action:hover { transform: translateY(-1px); }

.games-empty {
  margin: 22px 0 0;
  padding: 18px;
  border: 1px solid var(--dg-border);
  border-radius: 18px;
  color: var(--dg-muted);
  background: rgba(0,0,0,.16);
  font-weight: 850;
}
.games-empty[hidden] { display: none !important; }

.game-help-modal[hidden] { display: none !important; }
.game-help-modal { position: fixed; inset: 0; z-index: 50; display: grid; place-items: center; padding: 22px; }
.game-help-backdrop { position: absolute; inset: 0; border: 0; background: rgba(0,0,0,.66); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
.game-help-card {
  position: relative;
  width: min(520px, 100%);
  border: 1px solid rgba(132,76,255,.38);
  border-radius: 26px;
  padding: 28px;
  background: linear-gradient(145deg, rgba(15,12,30,.98), rgba(5,8,18,.98));
  box-shadow: 0 30px 100px rgba(0,0,0,.55);
}
.game-help-card h2 { margin: 0 0 10px; font-size: 2rem; }
.game-help-card p:last-child { color: var(--dg-muted); line-height: 1.65; font-weight: 760; }
.game-help-close { position: absolute; top: 14px; right: 14px; width: 36px; height: 36px; border: 1px solid rgba(255,255,255,.12); border-radius: 50%; background: rgba(255,255,255,.08); color: #fff; font-size: 1.35rem; cursor: pointer; }

.games-rain {
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  opacity: .72;
}
.games-rain-item {
  position: absolute;
  left: var(--x);
  top: -90px;
  width: var(--size);
  height: var(--size);
  opacity: var(--op);
  filter: blur(var(--blur));
  animation: games-fall var(--speed) linear var(--delay) infinite;
}
.rain-symbol,
.rain-board,
.rain-wordle,
.rain-tiles,
.rain-word-flower,
.rain-pencil {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  transform: rotate(var(--rot)) scale(var(--scale));
}
.rain-symbol { font-weight: 1000; font-size: calc(var(--size) * .75); }
.rain-x { color: var(--dg-pink); text-shadow: 0 0 18px rgba(255,46,111,.46); }
.rain-o { color: var(--dg-blue); text-shadow: 0 0 18px rgba(46,168,255,.48); }
.rain-num { color: #b9a7ff; }
.rain-word { color: #ffffff; }
.rain-small,
.rain-label { color: rgba(255,255,255,.44); font-size: calc(var(--size) * .34); letter-spacing: .08em; font-weight: 1000; }
.rain-board { grid-template-columns: repeat(3, 1fr); gap: 2px; border: 1px solid rgba(255,255,255,.18); border-radius: 9px; padding: 4px; color: rgba(255,255,255,.7); }
.rain-board i,
.rain-board b,
.rain-tiles b,
.rain-wordle b { border-radius: 4px; background: rgba(255,255,255,.10); font-style: normal; font-size: calc(var(--size) * .16); display: grid; place-items: center; min-width: 0; min-height: 0; }
.rain-wordle { grid-template-columns: repeat(4, 1fr); gap: 3px; }
.rain-tiles { grid-template-columns: repeat(3, 1fr); gap: 3px; }
.rain-tiles b:nth-child(odd) { background: rgba(123,66,255,.35); }
.rain-tiles b:nth-child(even) { background: rgba(46,168,255,.28); }
.rain-board-ttt b:nth-child(1),
.rain-board-ttt b:nth-child(5) { color: var(--dg-blue); }
.rain-board-ttt b:nth-child(3),
.rain-board-ttt b:nth-child(7) { color: var(--dg-pink); }
.rain-board-sudoku { color: rgba(255,255,255,.82); }
.rain-word-flower {
  position: relative;
  width: 100%;
  height: 100%;
}
.rain-word-flower b,
.rain-word-flower i {
  position: absolute;
  width: 38%;
  height: 38%;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.10);
  color: rgba(255,255,255,.72);
  font-style: normal;
  font-weight: 1000;
  font-size: calc(var(--size) * .18);
}
.rain-word-flower b { left: 31%; top: 31%; background: rgba(123,66,255,.32); color: #fff; }
.rain-word-flower i:nth-child(2) { left: 0; top: 31%; }
.rain-word-flower i:nth-child(3) { left: 31%; top: 0; }
.rain-word-flower i:nth-child(4) { right: 0; top: 31%; }
.rain-word-flower i:nth-child(5) { right: 11%; bottom: 0; }
.rain-word-flower i:nth-child(6) { left: 11%; bottom: 0; }
.rain-pencil {
  position: relative;
}
.rain-pencil::before {
  content: "";
  width: 18%;
  height: 78%;
  border-radius: 999px 999px 4px 4px;
  background: rgba(255,255,255,.40);
  transform: rotate(35deg);
  box-shadow: 0 0 14px rgba(255,255,255,.12);
}
.rain-pencil::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  border-left: calc(var(--size) * .08) solid transparent;
  border-right: calc(var(--size) * .08) solid transparent;
  border-top: calc(var(--size) * .16) solid rgba(255,255,255,.58);
  transform: translate(24%, 26%) rotate(35deg);
}

@keyframes games-fall {
  from { transform: translate3d(0, -100px, 0) rotate(0deg); }
  to { transform: translate3d(var(--drift), calc(100vh + 160px), 0) rotate(var(--spin)); }
}

@media (max-width: 980px) {
  .games-panel-head { grid-template-columns: 1fr; align-items: start; }
  .games-grid { grid-template-columns: 1fr; }
  .game-card { min-height: 218px; }
}

@media (max-width: 640px) {
  .games-topbar { align-items: stretch; flex-direction: column; }
  .games-nav { justify-content: flex-start; }
  .games-nav a { padding: 0 12px; }
  .game-card { grid-template-columns: 80px 1fr; padding: 16px; }
  .game-icon { width: 74px; height: 74px; border-radius: 19px; }
  .game-icon svg { width: 68px; height: 68px; }
  .game-help { width: 40px; height: 40px; border-radius: 14px; }
  .game-content h2 { font-size: 1.7rem; }
}


/* v22 icon refinements + synced help content */
.game-icon-sudoku svg,
.game-icon-wordle svg {
  width: 78px;
  height: 78px;
}
.icon-sudoku-grid rect,
.icon-sudoku-grid path {
  fill: none;
  stroke: rgba(255, 255, 255, .78);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.icon-sudoku-grid rect {
  stroke-width: 3.2;
  filter: drop-shadow(0 0 5px rgba(255,255,255,.14));
}
.icon-sudoku-numbers text {
  font-family: Inter, system-ui, -apple-system, Segoe UI, sans-serif;
  text-anchor: middle;
  dominant-baseline: middle;
  fill: rgba(255,255,255,.90);
  font-size: 13px;
  font-weight: 1000;
}
.icon-sudoku-numbers .is-main {
  fill: #ffffff;
  font-size: 19px;
  filter: drop-shadow(0 0 7px rgba(255,255,255,.35));
}
.icon-sudoku-pencil path:first-child {
  fill: rgba(255,255,255,.90);
  stroke: rgba(7,8,18,.45);
  stroke-width: 1;
  filter: drop-shadow(0 3px 7px rgba(0,0,0,.34));
}
.icon-sudoku-pencil path:nth-child(2),
.icon-sudoku-pencil path:nth-child(3) {
  fill: none;
  stroke: rgba(7,8,18,.72);
  stroke-width: 2.4;
  stroke-linecap: round;
}
.icon-word-flower circle {
  fill: rgba(255,255,255,.92);
  stroke: rgba(8,8,18,.92);
  stroke-width: 3.4;
  filter: drop-shadow(0 3px 7px rgba(0,0,0,.20));
}
.icon-word-flower .is-center {
  fill: rgba(123,66,255,.96);
  stroke: rgba(255,255,255,.96);
  stroke-width: 3;
  filter: drop-shadow(0 0 10px rgba(123,66,255,.7));
}
.icon-word-letters text {
  font-family: Inter, system-ui, -apple-system, Segoe UI, sans-serif;
  text-anchor: middle;
  dominant-baseline: middle;
  fill: #11121c;
  font-size: 15px;
  font-weight: 1000;
}
.icon-word-letters .is-main {
  fill: #fff;
  font-size: 22px;
  filter: drop-shadow(0 0 4px rgba(255,255,255,.20));
}
.game-help-body {
  color: var(--dg-muted);
  line-height: 1.58;
  font-weight: 760;
}
.game-help-body h3 {
  margin: 18px 0 6px;
  color: rgba(255,255,255,.92);
  font-size: 1rem;
}
.game-help-body h3:first-child { margin-top: 0; }
.game-help-body p { margin: 0 0 10px; }
.game-help-body ul {
  margin: 7px 0 0;
  padding-left: 20px;
}
.game-help-body li { margin: 6px 0; }
.game-help-grid {
  display: grid;
  gap: 12px;
}
.game-help-grid article {
  padding: 13px;
  border: 1px solid rgba(132,76,255,.24);
  border-radius: 16px;
  background: rgba(255,255,255,.045);
}
.game-help-grid strong {
  display: block;
  margin-bottom: 5px;
  color: rgba(255,255,255,.94);
}
.game-help-grid p { margin: 0; }


/* v23: compact help modal + cleaner Sudoku icon */
.game-help-card {
  width: min(560px, calc(100vw - 32px));
  max-height: calc(100vh - 44px);
  overflow-y: auto;
  padding: 24px 26px;
  scrollbar-width: thin;
  scrollbar-color: rgba(132,76,255,.72) rgba(255,255,255,.08);
}
.game-help-card::-webkit-scrollbar { width: 9px; }
.game-help-card::-webkit-scrollbar-track { background: rgba(255,255,255,.06); border-radius: 999px; }
.game-help-card::-webkit-scrollbar-thumb { background: rgba(132,76,255,.68); border-radius: 999px; }
.game-help-card h2 {
  font-size: clamp(1.45rem, 3vw, 1.85rem);
  line-height: 1.08;
  padding-right: 40px;
}
.game-help-body { font-size: .94rem; line-height: 1.48; }
.game-help-body h3 { margin: 14px 0 6px; }
.game-help-body li { margin: 4px 0; }
.game-help-modal { padding: 16px; }

.game-icon-sudoku svg { width: 79px; height: 79px; }
.icon-sudoku-board rect,
.icon-sudoku-board path {
  fill: none;
  stroke: rgba(255,255,255,.82);
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: .86;
}
.icon-sudoku-board rect {
  fill: rgba(8,10,24,.26);
  stroke-width: 2.2;
  filter: drop-shadow(0 0 5px rgba(255,255,255,.12));
}
.icon-sudoku-board .is-outer {
  stroke-width: 3.1;
  opacity: .96;
}
.icon-sudoku-numbers text {
  font-family: Inter, system-ui, -apple-system, Segoe UI, sans-serif;
  text-anchor: middle;
  dominant-baseline: middle;
  fill: rgba(255,255,255,.90);
  font-size: 12px;
  font-weight: 1000;
}
.icon-sudoku-numbers .is-main {
  fill: #ffffff;
  font-size: 18px;
  filter: drop-shadow(0 0 6px rgba(255,255,255,.34));
}
.icon-sudoku-pencil .pencil-body {
  fill: rgba(255,255,255,.94);
  stroke: rgba(6,7,16,.54);
  stroke-width: 1.2;
  filter: drop-shadow(0 3px 7px rgba(0,0,0,.34));
}
.icon-sudoku-pencil .pencil-band,
.icon-sudoku-pencil .pencil-tip {
  fill: none;
  stroke: rgba(6,7,16,.74);
  stroke-width: 2.25;
  stroke-linecap: round;
}
@media (max-height: 720px) {
  .game-help-card { padding: 20px 22px; max-height: calc(100vh - 28px); }
  .game-help-body { font-size: .9rem; line-height: 1.42; }
  .game-help-body h3 { margin: 12px 0 5px; }
}

/* v24: move game help button next to Play Now */
.game-visual {
  grid-template-rows: auto;
  gap: 0;
}

.game-actions {
  grid-column: 2;
  grid-row: 3;
  display: flex;
  align-items: center;
  gap: 10px;
  justify-self: start;
}

.game-actions .game-action {
  grid-column: auto;
  grid-row: auto;
}

.game-actions .game-help {
  width: 42px;
  height: 42px;
  flex: 0 0 42px;
  border-radius: 14px;
  font-size: 1rem;
  background: linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.065);
}

@media (max-width: 640px) {
  .game-actions {
    gap: 8px;
  }

  .game-actions .game-help {
    width: 40px;
    height: 40px;
    flex-basis: 40px;
  }
}

/* v26: place the help button on the far left and Play Now on the far right */
.game-actions {
  grid-column: 1 / -1;
  grid-row: 3;
  width: 100%;
  justify-self: stretch;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: 4px;
}

.game-actions .game-help {
  order: 1;
  margin-right: auto;
}

.game-actions .game-action {
  order: 2;
  margin-left: auto;
}

@media (max-width: 640px) {
  .game-actions {
    grid-column: 1 / -1;
    justify-content: space-between;
  }
}

/* v27: help sits under the game logo, Play Now stays on the right */
.game-actions {
  grid-column: 1 / -1;
  grid-row: 3;
  width: 100%;
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  align-items: center;
  gap: 18px;
  margin-top: 6px;
}

.game-actions .game-help {
  order: initial;
  grid-column: 1;
  justify-self: center;
  margin: 0;
}

.game-actions .game-action {
  order: initial;
  grid-column: 2;
  justify-self: end;
  margin: 0;
}

/* v27: smaller, centered Sudoku mark with a balanced pencil */
.game-icon-sudoku svg {
  width: 78px;
  height: 78px;
}

.icon-sudoku-board rect {
  fill: rgba(7, 9, 21, .24);
  stroke: rgba(255,255,255,.82);
  stroke-width: 2.1;
  filter: drop-shadow(0 0 4px rgba(255,255,255,.10));
}

.icon-sudoku-board path {
  fill: none;
  stroke: rgba(255,255,255,.72);
  stroke-width: 1.65;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: .9;
}

.icon-sudoku-board .is-outer {
  stroke-width: 3;
  opacity: .98;
}

.icon-sudoku-numbers text {
  font-family: Inter, system-ui, -apple-system, Segoe UI, sans-serif;
  text-anchor: middle;
  dominant-baseline: middle;
  fill: rgba(255,255,255,.88);
  font-size: 12px;
  font-weight: 1000;
}

.icon-sudoku-numbers .is-main {
  fill: #fff;
  font-size: 18px;
  filter: drop-shadow(0 0 6px rgba(255,255,255,.34));
}

.icon-sudoku-pencil .pencil-body {
  fill: rgba(255,255,255,.92);
  stroke: rgba(6,7,16,.52);
  stroke-width: 1;
  filter: drop-shadow(0 2px 5px rgba(0,0,0,.30));
}

.icon-sudoku-pencil .pencil-band {
  fill: none;
  stroke: rgba(6,7,16,.70);
  stroke-width: 1.75;
  stroke-linecap: round;
}

.icon-sudoku-pencil .pencil-tip {
  fill: rgba(255,255,255,.90);
  stroke: rgba(6,7,16,.62);
  stroke-width: 1;
  stroke-linejoin: round;
}

@media (max-width: 640px) {
  .game-actions {
    grid-template-columns: 80px minmax(0, 1fr);
    gap: 14px;
  }
}


/* v29: logo opens help on click; ? appears on logo hover; Play Now centered */
.game-visual {
  grid-template-rows: auto;
  align-content: start;
  justify-items: center;
  gap: 0;
}

.game-icon-help {
  width: 86px;
  height: 86px;
  position: relative;
  display: grid;
  place-items: center;
  padding: 0;
  border: 0;
  border-radius: 22px;
  background: transparent;
  color: #fff;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}

.game-icon-help .game-icon {
  width: 86px;
  height: 86px;
  transition: transform 160ms ease, filter 160ms ease, box-shadow 160ms ease;
}

.game-icon-help-mark {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.26);
  border-radius: 50%;
  background: rgba(6, 7, 17, .76);
  box-shadow: 0 12px 28px rgba(0,0,0,.34), 0 0 18px rgba(132,76,255,.32);
  color: #fff;
  font-size: 1.05rem;
  font-weight: 1000;
  opacity: 0;
  transform: translate(-50%, -50%) scale(.82);
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
}

.game-icon-help:hover .game-icon,
.game-icon-help:focus-visible .game-icon {
  transform: translateY(-1px) scale(1.015);
  filter: brightness(.72) saturate(1.1);
  box-shadow: 0 20px 42px rgba(123,66,255,.28), inset 0 1px 0 rgba(255,255,255,.20);
}

.game-icon-help:hover .game-icon-help-mark,
.game-icon-help:focus-visible .game-icon-help-mark {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.game-icon-help:focus-visible {
  outline: 2px solid rgba(96,185,255,.88);
  outline-offset: 5px;
}

.game-actions {
  grid-column: 1 / -1;
  grid-row: 3;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 7px;
}

.game-actions .game-action {
  margin: 0;
  justify-self: center;
  min-width: 148px;
}

/* v29: final small Sudoku balance */
.game-icon-sudoku svg {
  width: 78px;
  height: 78px;
}

.icon-sudoku-board rect {
  fill: rgba(7, 9, 21, .24);
  stroke: rgba(255,255,255,.84);
  stroke-width: 2.05;
  filter: drop-shadow(0 0 4px rgba(255,255,255,.10));
}

.icon-sudoku-board path {
  fill: none;
  stroke: rgba(255,255,255,.74);
  stroke-width: 1.55;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: .9;
}

.icon-sudoku-board .is-outer {
  stroke-width: 2.85;
  opacity: .98;
}

.icon-sudoku-numbers text {
  font-size: 11.5px;
  font-weight: 1000;
}

.icon-sudoku-numbers .is-main {
  font-size: 17px;
}

.icon-sudoku-pencil .pencil-body {
  fill: rgba(255,255,255,.92);
  stroke: rgba(6,7,16,.52);
  stroke-width: .9;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.28));
}

.icon-sudoku-pencil .pencil-band {
  fill: none;
  stroke: rgba(6,7,16,.70);
  stroke-width: 1.45;
  stroke-linecap: round;
}

.icon-sudoku-pencil .pencil-tip {
  fill: rgba(255,255,255,.90);
  stroke: rgba(6,7,16,.62);
  stroke-width: .9;
  stroke-linejoin: round;
}

@media (max-width: 640px) {
  .game-icon-help,
  .game-icon-help .game-icon {
    width: 74px;
    height: 74px;
    border-radius: 19px;
  }

  .game-icon-help-mark {
    width: 38px;
    height: 38px;
  }

  .game-actions {
    grid-column: 1 / -1;
    justify-content: center;
  }
}

/* v30: make the Play Now label sit perfectly centered inside the button */
.game-actions .game-action,
.game-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
  white-space: nowrap;
  padding-top: 1px;
}

.game-actions {
  align-items: center;
  justify-content: center;
}

/* v31: center the game info above the centered Play Now button */
.game-card {
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto minmax(0, 1fr) auto;
  text-align: center;
  row-gap: 14px;
  padding: 20px 18px 18px;
}

.game-visual {
  grid-column: 1;
  grid-row: 1;
  justify-self: center;
}

.game-content {
  grid-column: 1;
  grid-row: 2;
  width: 100%;
  max-width: 310px;
  justify-self: center;
  align-self: center;
  text-align: center;
}

.game-kicker {
  margin-left: auto;
  margin-right: auto;
}

.game-content p:last-child {
  max-width: 31ch;
  margin-left: auto;
  margin-right: auto;
}

.game-actions {
  grid-column: 1;
  grid-row: 3;
  justify-self: center;
  justify-content: center;
  width: 100%;
  margin-top: 2px;
}

.game-actions .game-action {
  justify-self: center;
}

@media (max-width: 640px) {
  .game-card {
    grid-template-columns: minmax(0, 1fr);
    padding: 18px 16px 16px;
  }

  .game-content {
    max-width: 290px;
  }
}


/* v32: showcase layout - featured Tic-Tac-Toe + stacked puzzle cards */
.games-grid {
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, .85fr);
  grid-template-rows: repeat(2, minmax(220px, auto));
  gap: 18px;
  align-items: stretch;
}

.game-card {
  isolation: isolate;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.game-card:hover {
  transform: translateY(-4px);
  border-color: rgba(142, 96, 255, .58);
  box-shadow: 0 26px 72px rgba(0,0,0,.36), 0 0 34px rgba(123,66,255,.12), inset 0 1px 0 rgba(255,255,255,.06);
}

.game-card:first-child {
  grid-column: 1;
  grid-row: 1 / span 2;
  min-height: 472px;
  padding: 30px 28px 26px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto minmax(0, 1fr) auto;
  align-items: center;
  text-align: center;
  background:
    radial-gradient(circle at 50% 8%, rgba(123,66,255,.28), transparent 38%),
    radial-gradient(circle at 16% 88%, rgba(255,46,111,.12), transparent 34%),
    radial-gradient(circle at 88% 82%, rgba(46,168,255,.13), transparent 34%),
    linear-gradient(150deg, rgba(12,9,28,.96), rgba(7,8,19,.92));
}

.game-card:first-child::after {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 20px;
  pointer-events: none;
  background:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: radial-gradient(circle at 50% 38%, black, transparent 70%);
  opacity: .58;
  z-index: 0;
}

.game-card:first-child .game-visual,
.game-card:first-child .game-content,
.game-card:first-child .game-actions {
  grid-column: 1;
  justify-self: center;
}

.game-card:first-child .game-visual { grid-row: 1; }
.game-card:first-child .game-content {
  grid-row: 2;
  max-width: 430px;
  align-self: center;
}
.game-card:first-child .game-actions { grid-row: 3; }

.game-card:first-child .game-icon-help,
.game-card:first-child .game-icon-help .game-icon {
  width: 118px;
  height: 118px;
  border-radius: 30px;
}

.game-card:first-child .game-icon svg {
  width: 108px;
  height: 108px;
}

.game-card:first-child .game-icon-help-mark {
  width: 50px;
  height: 50px;
  font-size: 1.18rem;
}

.game-card:first-child .game-kicker {
  margin-bottom: 14px;
}

.game-card:first-child .game-content h2 {
  font-size: clamp(2.65rem, 5vw, 4.35rem);
  letter-spacing: -.065em;
}

.game-card:first-child .game-content p:last-child {
  max-width: 38ch;
  margin-top: 15px;
  font-size: 1.02rem;
  line-height: 1.55;
}

.game-card:first-child .game-action {
  min-width: 184px;
  min-height: 50px;
  border-radius: 16px;
  font-size: 1rem;
}

.game-card:nth-child(2),
.game-card:nth-child(3) {
  grid-column: 2;
  min-height: 227px;
  padding: 22px;
  display: grid;
  grid-template-columns: 98px minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) auto;
  column-gap: 20px;
  row-gap: 14px;
  align-items: center;
  text-align: left;
}

.game-card:nth-child(2) { grid-row: 1; }
.game-card:nth-child(3) { grid-row: 2; }

.game-card:nth-child(2)::after,
.game-card:nth-child(3)::after {
  content: "";
  position: absolute;
  left: 0;
  top: 18px;
  bottom: 18px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(to bottom, var(--dg-purple), var(--dg-blue));
  opacity: .72;
}

.game-card:nth-child(2) .game-visual,
.game-card:nth-child(3) .game-visual {
  grid-column: 1;
  grid-row: 1 / span 2;
  justify-self: center;
  align-self: center;
}

.game-card:nth-child(2) .game-content,
.game-card:nth-child(3) .game-content {
  grid-column: 2;
  grid-row: 1;
  width: 100%;
  max-width: none;
  align-self: end;
  justify-self: stretch;
  text-align: left;
}

.game-card:nth-child(2) .game-kicker,
.game-card:nth-child(3) .game-kicker {
  margin-left: 0;
  margin-right: 0;
  margin-bottom: 10px;
}

.game-card:nth-child(2) .game-content h2,
.game-card:nth-child(3) .game-content h2 {
  font-size: clamp(1.8rem, 2.6vw, 2.45rem);
}

.game-card:nth-child(2) .game-content p:last-child,
.game-card:nth-child(3) .game-content p:last-child {
  max-width: 34ch;
  margin-left: 0;
  margin-right: 0;
  margin-top: 10px;
  line-height: 1.45;
}

.game-card:nth-child(2) .game-actions,
.game-card:nth-child(3) .game-actions {
  grid-column: 2;
  grid-row: 2;
  width: auto;
  justify-self: start;
  justify-content: flex-start;
  margin-top: 0;
}

.game-card:nth-child(2) .game-action,
.game-card:nth-child(3) .game-action {
  min-width: 136px;
  min-height: 42px;
  border-radius: 14px;
}

.game-card:nth-child(2) .game-icon-help,
.game-card:nth-child(2) .game-icon-help .game-icon,
.game-card:nth-child(3) .game-icon-help,
.game-card:nth-child(3) .game-icon-help .game-icon {
  width: 90px;
  height: 90px;
  border-radius: 24px;
}

.game-card:nth-child(2) .game-icon svg,
.game-card:nth-child(3) .game-icon svg {
  width: 82px;
  height: 82px;
}

.game-card:nth-child(2) .game-icon-help-mark,
.game-card:nth-child(3) .game-icon-help-mark {
  width: 42px;
  height: 42px;
}

/* Keep the search results clean instead of leaving empty featured-grid space. */
.games-grid.is-filtering {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  grid-template-rows: auto;
}

.games-grid.is-filtering .game-card {
  grid-column: auto !important;
  grid-row: auto !important;
  min-height: 270px;
  padding: 20px 18px 18px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto minmax(0, 1fr) auto;
  text-align: center;
}

.games-grid.is-filtering .game-card .game-visual,
.games-grid.is-filtering .game-card .game-content,
.games-grid.is-filtering .game-card .game-actions {
  grid-column: 1;
  justify-self: center;
  text-align: center;
}

.games-grid.is-filtering .game-card .game-visual { grid-row: 1; }
.games-grid.is-filtering .game-card .game-content {
  grid-row: 2;
  max-width: 310px;
  align-self: center;
}
.games-grid.is-filtering .game-card .game-actions {
  grid-row: 3;
  justify-content: center;
}
.games-grid.is-filtering .game-card .game-kicker {
  margin-left: auto;
  margin-right: auto;
}
.games-grid.is-filtering .game-card .game-content p:last-child {
  margin-left: auto;
  margin-right: auto;
}
.games-grid.is-filtering .game-card .game-icon-help,
.games-grid.is-filtering .game-card .game-icon-help .game-icon {
  width: 86px;
  height: 86px;
  border-radius: 22px;
}
.games-grid.is-filtering .game-card .game-icon svg {
  width: 78px;
  height: 78px;
}

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

  .game-card:first-child,
  .game-card:nth-child(2),
  .game-card:nth-child(3) {
    grid-column: 1;
    grid-row: auto;
  }

  .game-card:first-child {
    min-height: 390px;
  }

  .game-card:nth-child(2),
  .game-card:nth-child(3) {
    grid-template-columns: 96px minmax(0, 1fr);
  }
}

@media (max-width: 640px) {
  .game-card:first-child,
  .game-card:nth-child(2),
  .game-card:nth-child(3),
  .games-grid.is-filtering .game-card {
    min-height: 270px;
    padding: 20px 16px 18px;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto minmax(0, 1fr) auto;
    text-align: center;
  }

  .game-card:nth-child(2) .game-visual,
  .game-card:nth-child(3) .game-visual,
  .game-card:nth-child(2) .game-content,
  .game-card:nth-child(3) .game-content,
  .game-card:nth-child(2) .game-actions,
  .game-card:nth-child(3) .game-actions {
    grid-column: 1;
    justify-self: center;
    text-align: center;
  }

  .game-card:nth-child(2) .game-visual,
  .game-card:nth-child(3) .game-visual { grid-row: 1; }
  .game-card:nth-child(2) .game-content,
  .game-card:nth-child(3) .game-content {
    grid-row: 2;
    max-width: 300px;
    align-self: center;
  }
  .game-card:nth-child(2) .game-actions,
  .game-card:nth-child(3) .game-actions {
    grid-row: 3;
    justify-content: center;
  }
  .game-card:nth-child(2) .game-kicker,
  .game-card:nth-child(3) .game-kicker {
    margin-left: auto;
    margin-right: auto;
  }
  .game-card:nth-child(2) .game-content p:last-child,
  .game-card:nth-child(3) .game-content p:last-child {
    margin-left: auto;
    margin-right: auto;
  }

  .game-card:first-child .game-icon-help,
  .game-card:first-child .game-icon-help .game-icon,
  .game-card:nth-child(2) .game-icon-help,
  .game-card:nth-child(2) .game-icon-help .game-icon,
  .game-card:nth-child(3) .game-icon-help,
  .game-card:nth-child(3) .game-icon-help .game-icon {
    width: 82px;
    height: 82px;
    border-radius: 22px;
  }

  .game-card:first-child .game-icon svg,
  .game-card:nth-child(2) .game-icon svg,
  .game-card:nth-child(3) .game-icon svg {
    width: 76px;
    height: 76px;
  }

  .game-card:first-child .game-content h2 {
    font-size: 2.35rem;
  }
}

/* v33: all game cards use the same horizontal showcase layout in one row */
.games-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: auto;
  gap: 18px;
  align-items: stretch;
}

.game-card,
.game-card:first-child,
.game-card:nth-child(2),
.game-card:nth-child(3) {
  grid-column: auto;
  grid-row: auto;
  min-height: 286px;
  padding: 24px 20px 22px;
  display: grid;
  grid-template-columns: 94px minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) auto;
  column-gap: 20px;
  row-gap: 16px;
  align-items: center;
  text-align: left;
  background:
    radial-gradient(circle at 0% 0%, rgba(123,66,255,.17), transparent 36%),
    radial-gradient(circle at 100% 14%, rgba(46,168,255,.12), transparent 34%),
    linear-gradient(150deg, rgba(12,9,28,.96), rgba(5,8,18,.91));
}

.game-card:first-child::after,
.game-card:nth-child(2)::after,
.game-card:nth-child(3)::after {
  content: "";
  position: absolute;
  left: 0;
  top: 22px;
  bottom: 22px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(to bottom, var(--dg-purple), var(--dg-blue));
  opacity: .76;
  inset-inline-end: auto;
  right: auto;
  mask-image: none;
  background-size: auto;
  z-index: 0;
}

.game-card .game-visual,
.game-card:first-child .game-visual,
.game-card:nth-child(2) .game-visual,
.game-card:nth-child(3) .game-visual {
  grid-column: 1;
  grid-row: 1 / span 2;
  justify-self: center;
  align-self: center;
}

.game-card .game-content,
.game-card:first-child .game-content,
.game-card:nth-child(2) .game-content,
.game-card:nth-child(3) .game-content {
  grid-column: 2;
  grid-row: 1;
  width: 100%;
  max-width: none;
  justify-self: stretch;
  align-self: end;
  text-align: left;
}

.game-card .game-kicker,
.game-card:first-child .game-kicker,
.game-card:nth-child(2) .game-kicker,
.game-card:nth-child(3) .game-kicker {
  margin-left: 0;
  margin-right: 0;
  margin-bottom: 12px;
}

.game-card .game-content h2,
.game-card:first-child .game-content h2,
.game-card:nth-child(2) .game-content h2,
.game-card:nth-child(3) .game-content h2 {
  font-size: clamp(2rem, 2.45vw, 2.8rem);
  line-height: .95;
  letter-spacing: -.055em;
}

.game-card .game-content p:last-child,
.game-card:first-child .game-content p:last-child,
.game-card:nth-child(2) .game-content p:last-child,
.game-card:nth-child(3) .game-content p:last-child {
  max-width: 28ch;
  margin-left: 0;
  margin-right: 0;
  margin-top: 12px;
  font-size: .96rem;
  line-height: 1.45;
}

.game-card .game-actions,
.game-card:first-child .game-actions,
.game-card:nth-child(2) .game-actions,
.game-card:nth-child(3) .game-actions {
  grid-column: 2;
  grid-row: 2;
  width: auto;
  justify-self: start;
  justify-content: flex-start;
  margin-top: 0;
}

.game-card .game-action,
.game-card:first-child .game-action,
.game-card:nth-child(2) .game-action,
.game-card:nth-child(3) .game-action {
  min-width: 144px;
  min-height: 44px;
  border-radius: 15px;
  font-size: .96rem;
}

.game-card .game-icon-help,
.game-card .game-icon-help .game-icon,
.game-card:first-child .game-icon-help,
.game-card:first-child .game-icon-help .game-icon,
.game-card:nth-child(2) .game-icon-help,
.game-card:nth-child(2) .game-icon-help .game-icon,
.game-card:nth-child(3) .game-icon-help,
.game-card:nth-child(3) .game-icon-help .game-icon {
  width: 88px;
  height: 88px;
  border-radius: 24px;
}

.game-card .game-icon svg,
.game-card:first-child .game-icon svg,
.game-card:nth-child(2) .game-icon svg,
.game-card:nth-child(3) .game-icon svg {
  width: 80px;
  height: 80px;
}

.game-card .game-icon-help-mark,
.game-card:first-child .game-icon-help-mark,
.game-card:nth-child(2) .game-icon-help-mark,
.game-card:nth-child(3) .game-icon-help-mark {
  width: 42px;
  height: 42px;
  font-size: 1rem;
}

.games-grid.is-filtering {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  grid-template-rows: auto;
}

.games-grid.is-filtering .game-card {
  min-height: 286px;
  grid-template-columns: 94px minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) auto;
  text-align: left;
}

.games-grid.is-filtering .game-card .game-visual {
  grid-column: 1;
  grid-row: 1 / span 2;
}

.games-grid.is-filtering .game-card .game-content,
.games-grid.is-filtering .game-card .game-actions {
  grid-column: 2;
  justify-self: start;
  text-align: left;
}

.games-grid.is-filtering .game-card .game-content { grid-row: 1; }
.games-grid.is-filtering .game-card .game-actions { grid-row: 2; justify-content: flex-start; }
.games-grid.is-filtering .game-card .game-kicker { margin-left: 0; margin-right: 0; }
.games-grid.is-filtering .game-card .game-content p:last-child { margin-left: 0; margin-right: 0; }

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

  .game-card,
  .game-card:first-child,
  .game-card:nth-child(2),
  .game-card:nth-child(3) {
    min-height: 228px;
    grid-template-columns: 104px minmax(0, 1fr);
    padding: 24px 28px;
  }

  .game-card .game-icon-help,
  .game-card .game-icon-help .game-icon,
  .game-card:first-child .game-icon-help,
  .game-card:first-child .game-icon-help .game-icon,
  .game-card:nth-child(2) .game-icon-help,
  .game-card:nth-child(2) .game-icon-help .game-icon,
  .game-card:nth-child(3) .game-icon-help,
  .game-card:nth-child(3) .game-icon-help .game-icon {
    width: 92px;
    height: 92px;
  }
}

@media (max-width: 640px) {
  .game-card,
  .game-card:first-child,
  .game-card:nth-child(2),
  .game-card:nth-child(3),
  .games-grid.is-filtering .game-card {
    min-height: 270px;
    padding: 20px 16px 18px;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto minmax(0, 1fr) auto;
    text-align: center;
  }

  .game-card .game-visual,
  .game-card:first-child .game-visual,
  .game-card:nth-child(2) .game-visual,
  .game-card:nth-child(3) .game-visual,
  .games-grid.is-filtering .game-card .game-visual {
    grid-column: 1;
    grid-row: 1;
  }

  .game-card .game-content,
  .game-card:first-child .game-content,
  .game-card:nth-child(2) .game-content,
  .game-card:nth-child(3) .game-content,
  .games-grid.is-filtering .game-card .game-content {
    grid-column: 1;
    grid-row: 2;
    max-width: 300px;
    justify-self: center;
    align-self: center;
    text-align: center;
  }

  .game-card .game-actions,
  .game-card:first-child .game-actions,
  .game-card:nth-child(2) .game-actions,
  .game-card:nth-child(3) .game-actions,
  .games-grid.is-filtering .game-card .game-actions {
    grid-column: 1;
    grid-row: 3;
    justify-self: center;
    justify-content: center;
  }

  .game-card .game-kicker,
  .game-card:first-child .game-kicker,
  .game-card:nth-child(2) .game-kicker,
  .game-card:nth-child(3) .game-kicker,
  .games-grid.is-filtering .game-card .game-kicker,
  .game-card .game-content p:last-child,
  .game-card:first-child .game-content p:last-child,
  .game-card:nth-child(2) .game-content p:last-child,
  .game-card:nth-child(3) .game-content p:last-child,
  .games-grid.is-filtering .game-card .game-content p:last-child {
    margin-left: auto;
    margin-right: auto;
  }
}

/* v34: lock all three desktop cards to the same internal baseline */
@media (min-width: 1081px) {
  .games-grid:not(.is-filtering) .game-card,
  .games-grid:not(.is-filtering) .game-card:first-child,
  .games-grid:not(.is-filtering) .game-card:nth-child(2),
  .games-grid:not(.is-filtering) .game-card:nth-child(3) {
    min-height: 286px;
    grid-template-columns: 94px minmax(0, 1fr);
    grid-template-rows: 1fr auto;
    align-items: stretch;
    padding-top: 24px;
    padding-bottom: 22px;
  }

  .games-grid:not(.is-filtering) .game-card .game-visual,
  .games-grid:not(.is-filtering) .game-card:first-child .game-visual,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-visual,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-visual {
    grid-column: 1;
    grid-row: 1 / span 2;
    align-self: center;
    justify-self: center;
    transform: translateY(0);
  }

  .games-grid:not(.is-filtering) .game-card .game-content,
  .games-grid:not(.is-filtering) .game-card:first-child .game-content,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-content,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-content {
    grid-column: 2;
    grid-row: 1;
    align-self: start;
    justify-self: stretch;
    padding-top: 36px;
    text-align: left;
  }

  .games-grid:not(.is-filtering) .game-card .game-actions,
  .games-grid:not(.is-filtering) .game-card:first-child .game-actions,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-actions,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-actions {
    grid-column: 2;
    grid-row: 2;
    align-self: end;
    justify-self: start;
    justify-content: flex-start;
    margin-top: 0;
  }

  .games-grid:not(.is-filtering) .game-card .game-kicker,
  .games-grid:not(.is-filtering) .game-card:first-child .game-kicker,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-kicker,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-kicker {
    margin-top: 0;
    margin-bottom: 14px;
  }
}

/* v35: compact the desktop game cards without changing the layout */
@media (min-width: 1081px) {
  .games-grid:not(.is-filtering) {
    gap: 16px;
  }

  .games-grid:not(.is-filtering) .game-card,
  .games-grid:not(.is-filtering) .game-card:first-child,
  .games-grid:not(.is-filtering) .game-card:nth-child(2),
  .games-grid:not(.is-filtering) .game-card:nth-child(3) {
    min-height: 244px;
    padding: 18px 18px 18px;
    grid-template-columns: 84px minmax(0, 1fr);
    column-gap: 18px;
    row-gap: 10px;
    border-radius: 22px;
  }

  .games-grid:not(.is-filtering) .game-card:first-child::after,
  .games-grid:not(.is-filtering) .game-card:nth-child(2)::after,
  .games-grid:not(.is-filtering) .game-card:nth-child(3)::after {
    top: 18px;
    bottom: 18px;
  }

  .games-grid:not(.is-filtering) .game-card .game-content,
  .games-grid:not(.is-filtering) .game-card:first-child .game-content,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-content,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-content {
    padding-top: 26px;
  }

  .games-grid:not(.is-filtering) .game-card .game-kicker,
  .games-grid:not(.is-filtering) .game-card:first-child .game-kicker,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-kicker,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-kicker {
    margin-bottom: 10px;
    padding: 7px 12px;
    font-size: .72rem;
  }

  .games-grid:not(.is-filtering) .game-card .game-content h2,
  .games-grid:not(.is-filtering) .game-card:first-child .game-content h2,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-content h2,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-content h2 {
    font-size: clamp(1.9rem, 2.25vw, 2.45rem);
  }

  .games-grid:not(.is-filtering) .game-card .game-content p:last-child,
  .games-grid:not(.is-filtering) .game-card:first-child .game-content p:last-child,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-content p:last-child,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-content p:last-child {
    margin-top: 10px;
    font-size: .91rem;
    line-height: 1.38;
  }

  .games-grid:not(.is-filtering) .game-card .game-icon-help,
  .games-grid:not(.is-filtering) .game-card .game-icon-help .game-icon,
  .games-grid:not(.is-filtering) .game-card:first-child .game-icon-help,
  .games-grid:not(.is-filtering) .game-card:first-child .game-icon-help .game-icon,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-icon-help,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-icon-help .game-icon,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-icon-help,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-icon-help .game-icon {
    width: 78px;
    height: 78px;
    border-radius: 21px;
  }

  .games-grid:not(.is-filtering) .game-card .game-icon svg,
  .games-grid:not(.is-filtering) .game-card:first-child .game-icon svg,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-icon svg,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-icon svg {
    width: 72px;
    height: 72px;
  }

  .games-grid:not(.is-filtering) .game-card .game-action,
  .games-grid:not(.is-filtering) .game-card:first-child .game-action,
  .games-grid:not(.is-filtering) .game-card:nth-child(2) .game-action,
  .games-grid:not(.is-filtering) .game-card:nth-child(3) .game-action {
    min-width: 136px;
    min-height: 40px;
    border-radius: 14px;
    font-size: .92rem;
  }
}


/* Unified topbar/background cleanup */
html, body.games-body{
  background-color:#060612 !important;
}
body.games-body{
  min-height:100dvh;
  background-image:
    radial-gradient(900px 620px at 18% 8%, rgba(123,66,255,.22), transparent 62%),
    radial-gradient(820px 560px at 85% 18%, rgba(46,168,255,.14), transparent 60%),
    radial-gradient(900px 620px at 82% 86%, rgba(123,66,255,.10), transparent 64%) !important;
  background-repeat:no-repeat !important;
  background-size:cover !important;
  background-attachment:fixed !important;
}
.games-topbar.unified-topbar{
  width:min(1180px, calc(100% - 32px));
  min-height:68px;
  margin:18px auto 0;
  padding:10px 12px;
  border:1px solid rgba(132, 76, 255, .27);
  background:rgba(5,5,13,.86);
  border-radius:22px;
}
.games-nav.unified-nav a,
.games-nav.unified-nav button{
  min-height:38px;
  padding:0 15px;
  border-radius:13px;
  color:rgba(255,255,255,.72);
  font:inherit;
  font-size:.92rem;
  font-weight:950;
}
.games-nav.unified-nav a:hover,
.games-nav.unified-nav button:hover,
.games-nav.unified-nav a.is-active,
.games-nav.unified-nav button.is-active{
  color:#fff;
  background:rgba(132,76,255,.15);
}

/* Final topbar strip cleanup */
html, body.games-body{
  margin:0 !important;
  overscroll-behavior-y:none;
}
.games-topbar.unified-topbar{
  margin-top:0 !important;
  position:sticky !important;
  top:0 !important;
}


/* v16 title clipping fix */
.games-panel,
.games-panel-head,
.games-panel-head > div{
  overflow: visible !important;
}
.games-panel h1,
#gamesTitle{
  line-height: 1.16 !important;
  padding: .03em 0 .20em !important;
  overflow: visible !important;
  display: inline-block !important;
}


/* v17 topbar/modal/background polish */
html, body.games-body{ background-color:#05050c !important; }
body.games-body{
  background-attachment:fixed !important;
  background-size:cover !important;
}
.games-panel h1,#gamesTitle{ line-height:1.18 !important; padding:.02em 0 .25em !important; overflow:visible !important; }
.game-help-modal{ z-index:9300 !important; }
body.game-help-open .unified-topbar{ transform:translateY(-118%) !important; opacity:0 !important; pointer-events:none !important; }


/* v20 force game instructions to be a true modal bubble */
.game-help-modal[hidden]{ display:none !important; }
.game-help-modal:not([hidden]){
  position:fixed !important;
  inset:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:24px !important;
  width:100vw !important;
  height:100vh !important;
  z-index:99999 !important;
  overflow:hidden !important;
}
.game-help-backdrop{ position:fixed !important; inset:0 !important; background:rgba(0,0,0,.72) !important; backdrop-filter:blur(10px) !important; -webkit-backdrop-filter:blur(10px) !important; }
.game-help-card{ position:relative !important; z-index:1 !important; width:min(760px, calc(100vw - 40px)) !important; max-height:min(82vh, 760px) !important; overflow:auto !important; }
