/* =============================================================================
   Mini Games Library — Global Styles
   -----------------------------------------------------------------------------
   - Game-agnostic foundations first (theme, layout, utilities)
   - Game-specific sections appended below (TTT, Connect Four, Snake, Dots & Boxes, Checkers)
   - Mobile-accurate viewport sizing via --vh/--header-h/--footer-h
   ============================================================================= */

/* -----------------------------------------------------------------------------
   Root: Theme tokens (dark default) + dynamic viewport vars
   ----------------------------------------------------------------------------- */
:root {
  /* Core palette */
  --bg: #0b1220;
  --panel: #121a2b;
  --text: #e5e7eb;
  --muted: #9ca3af;
  --primary: #60a5fa;
  --accent: #7c3aed;
  --ok: #34d399;
  --warn: #f59e0b;
  --danger: #ef4444;
  --focus: #f472b6;
  --primary-glow: rgba(96,165,250,.15);
  --accent-glow: rgba(124,58,237,.15);
  --surface: #172238;
  --surface-soft: rgba(255,255,255,.035);
  --border: rgba(255,255,255,.10);
  --border-strong: rgba(96,165,250,.30);
  --button-bg: linear-gradient(180deg, rgba(255,255,255,.06), rgba(0,0,0,.08));
  --primary-button-bg: linear-gradient(180deg, rgba(37,99,235,.28), rgba(124,58,237,.20));
  --card-wash: linear-gradient(155deg, rgba(255,255,255,.04), transparent 45%);

  /* Focus ring (rgba) */
  --ring: 0 0 0 3px rgba(244, 114, 182, 0.45);

  /* Player colors shared by games */
  --player-red:   #ef4444; /* Tailwind Red-500 */
  --player-yellow:#f59e0b; /* Tailwind Yellow-400 */

  /* Dynamic viewport sizing (JS will set these precisely) */
  --vh: 1vh;       /* 1% of *visual* viewport height */
  --header-h: 0px; /* measured in JS */
  --footer-h: 0px; /* measured in JS */

  /* Header/control sizing (logo-driven, no wobble) */
  --brand-img-h: 3em;       /* ← change this to scale logo without shifts */
  --hdr-vpad: 16px;         /* header vertical padding total (8px top + 8px bottom) */
  --hdr-h: calc(var(--brand-img-h) + var(--hdr-vpad));
  --ctrl-h: 36px;           /* control row height (buttons/selects/theme) */
}

/* Light theme override */
[data-theme="light"] {
  --bg: #f7fafc;
  --panel: #ffffff;
  --text: #111827;
  --muted: #6b7280;
  --primary: #2563eb;
  --accent: #6d28d9;
  --ok: #047857;
  --warn: #b45309;
  --danger: #b91c1c;
  --focus: #7c3aed;
  --ring: 0 0 0 3px rgba(124, 58, 237, 0.35);
  --primary-glow: rgba(37,99,235,.12);
  --accent-glow: rgba(109,40,217,.10);
  --surface: #eef3fb;
  --surface-soft: rgba(17,24,39,.035);
  --border: rgba(17,24,39,.12);
  --border-strong: rgba(37,99,235,.32);
  --button-bg: linear-gradient(180deg, #ffffff, #eef2f7);
  --primary-button-bg: linear-gradient(180deg, rgba(37,99,235,.16), rgba(109,40,217,.12));
  --card-wash: linear-gradient(155deg, rgba(37,99,235,.045), transparent 45%);
}

/* Respect system preference (unless user forced dark) */
@media (prefers-color-scheme: light) {
  :root:not([data-theme="dark"]) {
    --bg: #f7fafc;
    --panel: #ffffff;
    --text: #111827;
    --muted: #6b7280;
    --primary: #2563eb;
    --accent: #6d28d9;
    --ok: #047857;
    --warn: #b45309;
    --danger: #b91c1c;
    --focus: #7c3aed;
    --ring: 0 0 0 3px rgba(124, 58, 237, 0.35);
  }
}

/* Full visual skins. Each skin has independent dark and light character. */
[data-theme="dark"][data-skin="lattice"] {
  --bg: #0b1220; --panel: #121a2b; --surface: #172238; --surface-soft: rgba(255,255,255,.035);
  --text: #e5e7eb; --muted: #9ca3af; --primary: #60a5fa; --accent: #7c3aed;
  --ok: #34d399; --warn: #f59e0b; --danger: #ef4444; --focus: #f472b6;
  --border: rgba(255,255,255,.10); --border-strong: rgba(96,165,250,.30);
  --primary-glow: rgba(96,165,250,.17); --accent-glow: rgba(124,58,237,.17);
  --button-bg: linear-gradient(180deg, rgba(255,255,255,.06), rgba(0,0,0,.08));
  --primary-button-bg: linear-gradient(180deg, rgba(37,99,235,.28), rgba(124,58,237,.20));
  --card-wash: linear-gradient(155deg, rgba(255,255,255,.04), transparent 45%);
  --ring: 0 0 0 3px rgba(244,114,182,.45);
}
[data-theme="light"][data-skin="lattice"] {
  --bg: #f7fafc; --panel: #ffffff; --surface: #eef3fb; --surface-soft: rgba(17,24,39,.035);
  --text: #111827; --muted: #6b7280; --primary: #2563eb; --accent: #6d28d9;
  --ok: #047857; --warn: #b45309; --danger: #b91c1c; --focus: #7c3aed;
  --border: rgba(17,24,39,.12); --border-strong: rgba(37,99,235,.32);
  --primary-glow: rgba(37,99,235,.12); --accent-glow: rgba(109,40,217,.10);
  --button-bg: linear-gradient(180deg, #ffffff, #eef2f7);
  --primary-button-bg: linear-gradient(180deg, rgba(37,99,235,.16), rgba(109,40,217,.12));
  --card-wash: linear-gradient(155deg, rgba(37,99,235,.045), transparent 45%);
  --ring: 0 0 0 3px rgba(124,58,237,.35);
}
[data-theme="dark"][data-skin="arcade"] {
  --bg: #160b2d; --panel: #241044; --surface: #31145b; --surface-soft: rgba(255,217,61,.055);
  --text: #fff6d6; --muted: #c6afd8; --primary: #ffd93d; --accent: #ff4ecd;
  --ok: #65f58a; --warn: #ff9f1c; --danger: #ff5964; --focus: #32e6ff;
  --border: rgba(255,217,61,.22); --border-strong: rgba(255,78,205,.46);
  --primary-glow: rgba(255,217,61,.15); --accent-glow: rgba(255,78,205,.20);
  --button-bg: linear-gradient(180deg, rgba(255,217,61,.11), rgba(255,78,205,.08));
  --primary-button-bg: linear-gradient(135deg, rgba(255,217,61,.28), rgba(255,78,205,.30));
  --card-wash: linear-gradient(145deg, rgba(255,78,205,.10), transparent 52%);
  --ring: 0 0 0 3px rgba(50,230,255,.48);
}
[data-theme="light"][data-skin="arcade"] {
  --bg: #fff6d8; --panel: #fffdf4; --surface: #f8e8ff; --surface-soft: rgba(112,33,153,.045);
  --text: #30123f; --muted: #745c7f; --primary: #b45309; --accent: #b31587;
  --ok: #15803d; --warn: #c2410c; --danger: #be123c; --focus: #0369a1;
  --border: rgba(112,33,153,.20); --border-strong: rgba(179,21,135,.38);
  --primary-glow: rgba(245,158,11,.14); --accent-glow: rgba(217,70,239,.12);
  --button-bg: linear-gradient(180deg, #fffdf4, #f8e8ff);
  --primary-button-bg: linear-gradient(135deg, rgba(245,158,11,.20), rgba(217,70,239,.18));
  --card-wash: linear-gradient(145deg, rgba(217,70,239,.07), transparent 52%);
  --ring: 0 0 0 3px rgba(3,105,161,.35);
}
[data-theme="dark"][data-skin="neon"] {
  --bg: #030712; --panel: #07101f; --surface: #0b1729; --surface-soft: rgba(34,211,238,.045);
  --text: #e6fffb; --muted: #8da6ad; --primary: #22d3ee; --accent: #a3ff12;
  --ok: #4ade80; --warn: #facc15; --danger: #fb7185; --focus: #f0abfc;
  --border: rgba(34,211,238,.24); --border-strong: rgba(163,255,18,.45);
  --primary-glow: rgba(34,211,238,.20); --accent-glow: rgba(163,255,18,.12);
  --button-bg: linear-gradient(180deg, rgba(34,211,238,.08), rgba(0,0,0,.18));
  --primary-button-bg: linear-gradient(135deg, rgba(34,211,238,.24), rgba(163,255,18,.16));
  --card-wash: linear-gradient(155deg, rgba(34,211,238,.08), transparent 48%);
  --ring: 0 0 0 3px rgba(240,171,252,.45);
}
[data-theme="light"][data-skin="neon"] {
  --bg: #edffff; --panel: #ffffff; --surface: #e4fbfa; --surface-soft: rgba(8,145,178,.045);
  --text: #06242b; --muted: #4f6c72; --primary: #0e7490; --accent: #4d7c0f;
  --ok: #15803d; --warn: #a16207; --danger: #be123c; --focus: #a21caf;
  --border: rgba(8,145,178,.22); --border-strong: rgba(77,124,15,.40);
  --primary-glow: rgba(6,182,212,.13); --accent-glow: rgba(132,204,22,.11);
  --button-bg: linear-gradient(180deg, #ffffff, #e4fbfa);
  --primary-button-bg: linear-gradient(135deg, rgba(6,182,212,.17), rgba(132,204,22,.14));
  --card-wash: linear-gradient(155deg, rgba(6,182,212,.06), transparent 48%);
  --ring: 0 0 0 3px rgba(162,28,175,.32);
}
[data-theme="dark"][data-skin="retro"] {
  --bg: #261b18; --panel: #352622; --surface: #44312a; --surface-soft: rgba(250,204,21,.045);
  --text: #f8e7c5; --muted: #c0a78d; --primary: #f4b942; --accent: #dc6b3c;
  --ok: #9bbf5b; --warn: #e69f3a; --danger: #d45d52; --focus: #f3d08a;
  --border: rgba(244,185,66,.22); --border-strong: rgba(220,107,60,.42);
  --primary-glow: rgba(244,185,66,.14); --accent-glow: rgba(220,107,60,.14);
  --button-bg: linear-gradient(180deg, rgba(244,185,66,.08), rgba(0,0,0,.10));
  --primary-button-bg: linear-gradient(180deg, rgba(244,185,66,.24), rgba(220,107,60,.22));
  --card-wash: linear-gradient(155deg, rgba(244,185,66,.06), transparent 50%);
  --ring: 0 0 0 3px rgba(243,208,138,.40);
}
[data-theme="light"][data-skin="retro"] {
  --bg: #f6ecd6; --panel: #fff8e8; --surface: #ead8b8; --surface-soft: rgba(92,61,46,.045);
  --text: #3b2922; --muted: #765f51; --primary: #9a5b0b; --accent: #a84424;
  --ok: #4d7c0f; --warn: #a16207; --danger: #b42318; --focus: #7c2d12;
  --border: rgba(92,61,46,.20); --border-strong: rgba(168,68,36,.38);
  --primary-glow: rgba(180,117,23,.12); --accent-glow: rgba(168,68,36,.10);
  --button-bg: linear-gradient(180deg, #fff8e8, #ead8b8);
  --primary-button-bg: linear-gradient(180deg, rgba(180,117,23,.18), rgba(168,68,36,.15));
  --card-wash: linear-gradient(155deg, rgba(180,117,23,.06), transparent 50%);
  --ring: 0 0 0 3px rgba(124,45,18,.30);
}
[data-theme="dark"][data-skin="forest"] {
  --bg: #091711; --panel: #10251b; --surface: #173526; --surface-soft: rgba(167,243,208,.035);
  --text: #e5f4e9; --muted: #9bb6a2; --primary: #86d17f; --accent: #d6a85f;
  --ok: #4ade80; --warn: #eab308; --danger: #f87171; --focus: #a7f3d0;
  --border: rgba(134,209,127,.20); --border-strong: rgba(214,168,95,.42);
  --primary-glow: rgba(134,209,127,.14); --accent-glow: rgba(214,168,95,.12);
  --button-bg: linear-gradient(180deg, rgba(134,209,127,.07), rgba(0,0,0,.10));
  --primary-button-bg: linear-gradient(135deg, rgba(134,209,127,.22), rgba(214,168,95,.17));
  --card-wash: linear-gradient(155deg, rgba(134,209,127,.06), transparent 48%);
  --ring: 0 0 0 3px rgba(167,243,208,.38);
}
[data-theme="light"][data-skin="forest"] {
  --bg: #eef5eb; --panel: #fbfdf8; --surface: #dfead9; --surface-soft: rgba(20,83,45,.035);
  --text: #173421; --muted: #5c7463; --primary: #287a42; --accent: #946517;
  --ok: #15803d; --warn: #a16207; --danger: #b91c1c; --focus: #166534;
  --border: rgba(20,83,45,.18); --border-strong: rgba(148,101,23,.38);
  --primary-glow: rgba(34,139,75,.11); --accent-glow: rgba(180,127,35,.10);
  --button-bg: linear-gradient(180deg, #fbfdf8, #dfead9);
  --primary-button-bg: linear-gradient(135deg, rgba(40,122,66,.16), rgba(148,101,23,.14));
  --card-wash: linear-gradient(155deg, rgba(40,122,66,.05), transparent 48%);
  --ring: 0 0 0 3px rgba(22,101,52,.30);
}
[data-theme="dark"][data-skin="ocean"] {
  --bg: #061521; --panel: #0b2434; --surface: #11364a; --surface-soft: rgba(125,211,252,.04);
  --text: #e5f7ff; --muted: #9ab8c7; --primary: #7dd3fc; --accent: #2dd4bf;
  --ok: #5ee0a0; --warn: #f6c453; --danger: #fb7185; --focus: #bae6fd;
  --border: rgba(125,211,252,.20); --border-strong: rgba(45,212,191,.42);
  --primary-glow: rgba(125,211,252,.16); --accent-glow: rgba(45,212,191,.14);
  --button-bg: linear-gradient(180deg, rgba(125,211,252,.08), rgba(0,0,0,.12));
  --primary-button-bg: linear-gradient(135deg, rgba(125,211,252,.24), rgba(45,212,191,.20));
  --card-wash: linear-gradient(155deg, rgba(125,211,252,.07), transparent 50%);
  --ring: 0 0 0 3px rgba(186,230,253,.38);
}
[data-theme="light"][data-skin="ocean"] {
  --bg: #eaf7fb; --panel: #fbfeff; --surface: #d8edf4; --surface-soft: rgba(8,89,117,.04);
  --text: #0b3040; --muted: #557684; --primary: #075985; --accent: #0f766e;
  --ok: #047857; --warn: #a16207; --danger: #be123c; --focus: #0369a1;
  --border: rgba(8,89,117,.18); --border-strong: rgba(15,118,110,.38);
  --primary-glow: rgba(14,116,144,.11); --accent-glow: rgba(13,148,136,.10);
  --button-bg: linear-gradient(180deg, #fbfeff, #d8edf4);
  --primary-button-bg: linear-gradient(135deg, rgba(7,89,133,.16), rgba(15,118,110,.14));
  --card-wash: linear-gradient(155deg, rgba(14,116,144,.05), transparent 50%);
  --ring: 0 0 0 3px rgba(3,105,161,.30);
}
[data-theme="dark"][data-skin="sakura"] {
  --bg: #1d1019; --panel: #2d1726; --surface: #402036; --surface-soft: rgba(251,207,232,.04);
  --text: #fff0f7; --muted: #c9a6b8; --primary: #f9a8d4; --accent: #c4b5fd;
  --ok: #86d9a7; --warn: #f6c177; --danger: #fb7185; --focus: #fbcfe8;
  --border: rgba(249,168,212,.20); --border-strong: rgba(196,181,253,.42);
  --primary-glow: rgba(249,168,212,.16); --accent-glow: rgba(196,181,253,.14);
  --button-bg: linear-gradient(180deg, rgba(249,168,212,.08), rgba(0,0,0,.12));
  --primary-button-bg: linear-gradient(135deg, rgba(249,168,212,.24), rgba(196,181,253,.20));
  --card-wash: linear-gradient(155deg, rgba(249,168,212,.07), transparent 50%);
  --ring: 0 0 0 3px rgba(251,207,232,.40);
}
[data-theme="light"][data-skin="sakura"] {
  --bg: #fff1f5; --panel: #fffafb; --surface: #f8dfe9; --surface-soft: rgba(131,45,80,.04);
  --text: #451a2d; --muted: #7f5969; --primary: #9d174d; --accent: #6d28d9;
  --ok: #047857; --warn: #a16207; --danger: #be123c; --focus: #9d174d;
  --border: rgba(131,45,80,.18); --border-strong: rgba(109,40,217,.35);
  --primary-glow: rgba(190,24,93,.10); --accent-glow: rgba(109,40,217,.09);
  --button-bg: linear-gradient(180deg, #fffafb, #f8dfe9);
  --primary-button-bg: linear-gradient(135deg, rgba(157,23,77,.15), rgba(109,40,217,.13));
  --card-wash: linear-gradient(155deg, rgba(190,24,93,.05), transparent 50%);
  --ring: 0 0 0 3px rgba(157,23,77,.28);
}
[data-theme="dark"][data-skin="mono"] {
  --bg: #0d0d0d; --panel: #171717; --surface: #222222; --surface-soft: rgba(255,255,255,.035);
  --text: #f2f2f2; --muted: #a3a3a3; --primary: #f5f5f5; --accent: #bdbdbd;
  --ok: #d4d4d4; --warn: #c7c7c7; --danger: #e5e5e5; --focus: #ffffff;
  --border: rgba(255,255,255,.16); --border-strong: rgba(255,255,255,.42);
  --primary-glow: rgba(255,255,255,.08); --accent-glow: rgba(255,255,255,.05);
  --button-bg: linear-gradient(180deg, #262626, #171717);
  --primary-button-bg: linear-gradient(180deg, #f5f5f5, #bdbdbd);
  --card-wash: linear-gradient(155deg, rgba(255,255,255,.045), transparent 48%);
  --ring: 0 0 0 3px rgba(255,255,255,.42);
}
[data-theme="light"][data-skin="mono"] {
  --bg: #ededed; --panel: #ffffff; --surface: #dfdfdf; --surface-soft: rgba(0,0,0,.035);
  --text: #111111; --muted: #5f5f5f; --primary: #222222; --accent: #555555;
  --ok: #333333; --warn: #555555; --danger: #111111; --focus: #000000;
  --border: rgba(0,0,0,.16); --border-strong: rgba(0,0,0,.42);
  --primary-glow: rgba(0,0,0,.07); --accent-glow: rgba(0,0,0,.04);
  --button-bg: linear-gradient(180deg, #ffffff, #dfdfdf);
  --primary-button-bg: linear-gradient(180deg, #444444, #111111);
  --card-wash: linear-gradient(155deg, rgba(0,0,0,.035), transparent 48%);
  --ring: 0 0 0 3px rgba(0,0,0,.32);
}

/* -----------------------------------------------------------------------------
   Base / Reset-ish
   ----------------------------------------------------------------------------- */
* { box-sizing: border-box; }

[hidden] { display: none !important; }

html { min-height: 100%; }
body { min-height: 100vh; }

/* Thin scrollbars that follow the active light/dark skin tokens. */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--accent) var(--surface);
}

*::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

*::-webkit-scrollbar-track {
  background: var(--surface);
}

*::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--primary), var(--accent));
  border: 2px solid var(--surface);
  border-radius: 999px;
}

*::-webkit-scrollbar-thumb:hover {
  background: var(--accent);
}

*::-webkit-scrollbar-corner {
  background: var(--surface);
}

body {
  margin: 0;
  font: 16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell,
        "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
  background:
    radial-gradient(1200px 800px at 20% -10%, var(--accent-glow), transparent 60%),
    radial-gradient(800px 600px at 100% 10%, var(--primary-glow), transparent 60%),
    var(--bg);
  color: var(--text);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Links use colour, hover surfaces, and focus rings instead of underlines. */
a,
a:visited,
a:hover,
a:active,
a:focus {
  color: var(--primary);
  text-decoration: none;
  text-decoration-line: none;
}

a:not(.btn):not(.brand-link):hover {
  background: var(--surface-soft);
  color: var(--primary);
  border-radius: .25rem;
}

a:not(.btn):not(.brand-link) {
  font-weight: 700;
}

a:not(.btn):not(.brand-link):focus-visible {
  outline: none;
  border-radius: .25rem;
  box-shadow: var(--ring);
}

/* Accessibility helpers */
.skip-link {
  position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden;
}
.skip-link:focus {
  position: static; width: auto; height: auto;
  padding: .5rem .75rem; background: var(--panel); border-radius: .5rem;
}
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); border: 0;
}

/* -----------------------------------------------------------------------------
   App Header (standardised)
   ----------------------------------------------------------------------------- */
.app-header {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 8px clamp(1rem, 2vw, 2rem);
  margin-bottom: 1rem;
  min-block-size: var(--hdr-h);      /* constant, logo-driven height across pages */
  background: none;
  gap: .75rem;
}

/* Brand strip: logo / library name / divider / game title */
.brand {
  display: inline-flex;
  align-items: center;               /* keep everything on the same line */
  gap: .6em;
  min-height: var(--ctrl-h);         /* matches control row height */
}
.brand-mark {
  block-size: var(--brand-img-h);
  inline-size: auto;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  display: inline-block;
  vertical-align: baseline;    /* not middle */
}
.brand-title {
  font-size: 1.24rem;
  font-weight: 800;
  margin: 0;
  letter-spacing: .03em;
  line-height: 1.1;
}
.divider {
  font-size: 1.2rem;
  color: var(--muted);
  opacity: .5;
  margin: 0 .55em;
  font-weight: 600;
  user-select: none;
  line-height: 1.1;
}
.game-title {
  font-size: 1.13rem;
  font-weight: 700;
  color: var(--muted);
  margin: 0;
  line-height: 1.1;
}

/* Controls */
.controls {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  flex-wrap: wrap;
  margin: 0;                          /* remove vertical creep */
}

/* Controls: lock to a shared height */
.btn,
.theme-btn { height: var(--ctrl-h); }

/* Buttons */
.btn {
  appearance: none;
  cursor: pointer;
  user-select: none;
  background: var(--button-bg), var(--panel);
  border: 1px solid var(--border);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  line-height: 1;
  padding: 0 .82rem;
  border-radius: .65rem;
  font-weight: 600;
  font-size: 1em;
  margin: 0;
  transition: background .12s, border-color .14s, color .14s;
  text-decoration: none;
}
.btn.primary {
  background: var(--primary-button-bg);
  border-color: var(--border-strong);
  color: var(--primary-button-text, var(--text));
}
.btn:hover,
.btn:focus-visible {
  border-color: var(--border-strong);
  color: var(--primary);
  outline: none;
}
.btn.primary:hover,
.btn.primary:focus-visible {
  color: var(--primary-button-text, var(--text));
}
.btn[disabled] { opacity: 0.5; cursor: not-allowed; }

/* Theme toggle: square, same height as other controls */
.theme-btn {
  background: none;
  border: none;
  box-shadow: none;
  width: var(--ctrl-h);
  padding: 0;
  font-size: 1.15rem;                 /* icon sizing */
  color: var(--text);
  border-radius: .55rem;
  transition: background .14s, color .14s;
  cursor: pointer;
}
.theme-btn:hover,
.theme-btn:focus-visible {
  background: rgba(124,58,237,0.11);
  color: var(--accent);
  outline: none;
}
.theme-btn:active { background: rgba(124,58,237,0.17); color: var(--accent); }

/* Small screens: stack header cleanly without changing heights */
@media (max-width: 650px) {
  .app-header {
    grid-template-columns: 1fr;
    gap: .4rem;
    padding: .75rem .6rem;
    margin-bottom: .8rem;
  }
  .controls { justify-content: flex-start; }
}

/* Branding link reset */
.brand-title a,
.brand-link {
  color: inherit;
  text-decoration: none;
  font: inherit;
}
.brand-title a:focus-visible,
.brand-link:focus-visible {
  box-shadow: 0 0 0 3px var(--focus, #7c3aed);
  background: rgba(124,58,237,0.09);
}
.brand-title a:hover,
.brand-link:hover {
  text-decoration: none;
  color: var(--accent);
}
/* Text pieces use the same line-height so their baselines match exactly */
.brand-title,
.game-title,
.divider {
  display: inline-block;
  line-height: 1;
}
/* center by boxes (not baselines) to ignore icon’s transparent padding */
.brand,
.brand-link{
  display:inline-flex;
  align-items:center;     /* was baseline in your file */
  gap:.6em;
  line-height:1;
}

.brand-mark{
  display:block;          /* no inline baseline box */
  block-size:var(--brand-img-h);
  inline-size:auto;
  aspect-ratio:1/1;
  object-fit:contain;
}

/* micro nudges: purely visual, don’t affect layout height or wrap */
.brand-title{ transform: translateY(var(--brand-title-y)); }
.divider,
.game-title{ transform: translateY(var(--crumb-y)); }


/* -----------------------------------------------------------------------------
   Native Select wrapper (kept for consistency with other pages)
   ----------------------------------------------------------------------------- */
.select-wrap {
  display: inline-flex; align-items: center;
  background: var(--panel); border: 1px solid var(--border);
  border-radius: .65rem; padding: .2em .85em .2em .5em;
  position: relative;
  min-width: 110px; font-size: 1em; margin-right: 0.2em;
}
.select-wrap select {
  appearance: none; background: transparent; color: var(--text);
  border: none; padding: .38em 1.7em .38em .2em;
  font-weight: 600; font-size: 1em; outline: none; min-width: 72px; cursor: pointer;
}
.select-wrap select:focus { outline: none; box-shadow: var(--ring); border-radius: .55rem; }
.select-wrap::after {
  content: '';
  pointer-events: none;
  position: absolute; right: .68em; top: 50%;
  width: 0.66em; height: 0.39em;
  border: solid var(--muted); border-width: 0 0 2.5px 2.5px; border-radius: .14em;
  transform: translateY(-45%) rotate(-45deg); opacity: 0.78;
}
.select-wrap select:disabled { opacity: 0.55; cursor: not-allowed; }

/* -----------------------------------------------------------------------------
   Hub layout (landing page)
   ----------------------------------------------------------------------------- */
   
.layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 1rem;
  padding: 0 clamp(1rem, 2vw, 2rem) 2rem;
}
@media (max-width: 900px) { .layout { grid-template-columns: 1fr; } }
.board-wrap { display: grid; gap: .75rem; align-content: start; }

.status { text-align: center; padding: .5rem; font-weight: 700; color: var(--muted); }
.hub-icon img { display: block; width: 100%; height: auto; border-radius: 0.9rem; }

.sidebar { display: grid; gap: 1rem; align-content: start; }
.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 1rem;
  padding: 1rem;
  margin-bottom: 1em;
}
.card h3 { margin: 0 0 .5rem; font-size: 1.05rem; }

.score { display: grid; gap: .4rem; }
.score dt { color: var(--muted); }
.score dd { margin: 0; font-weight: 800; }

/* Footer */
.app-footer {
  background: var(--panel);
  color: var(--muted);
  border-top: 1px solid var(--border);
  font-size: 1rem;
  text-align: center;
  margin-top: auto;
  padding: 1.1rem 0.8rem 1.2rem;
  box-shadow: 0 -2px 12px rgba(24,32,56,.06);
}
.footer-meta { font-size: 0.97em; color: var(--muted); letter-spacing: .01em; }
.footer-meta a { color: var(--primary); text-decoration: none; font-weight: 700; }
.footer-meta a:hover,
.footer-meta a:focus { color: var(--primary); text-decoration: none; outline: none; }

/* Keyboard hint */
.kbd, kbd {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-bottom-width: 2px;
  border-radius: .4rem;
  padding: .1rem .35rem;
  font-size: .875em;
}
/* -----------------------------------------------------------------------------
   Hub-specific blocks
   ----------------------------------------------------------------------------- */
.hub-layout { grid-template-columns: 1fr 320px; }
.hub-section { display: grid; align-content: start; gap: 1rem; }
.hub-search input {
  appearance: none; background: var(--panel); border: 1px solid rgba(255,255,255,.08);
  border-radius: .65rem; padding: .55rem .8rem; color: var(--text); font-weight: 600; min-width: 14ch;
}
.hub-grid {
  --card-min: 260px;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(var(--card-min), 1fr));
  gap: 1rem; padding: 0; margin: 0; list-style: none;
}
.hub-card {
  display: grid; gap: .8rem;
  background: var(--panel); border: 1px solid rgba(255,255,255,.08);
  border-radius: 1rem; padding: 1rem;
}
.hub-card.coming { opacity: .7; }
.status-chip {
  display: inline-block;
  margin-left: .35rem;
  padding: .08rem .35rem;
  border: 1px solid rgba(245,158,11,.45);
  border-radius: .4rem;
  color: var(--warn);
  font-size: .72rem;
  vertical-align: middle;
}
.hub-card-body { display: grid; grid-template-columns: 72px 1fr; gap: .8rem; align-items: center; }
.hub-icon {
  display: grid; place-items: center; width: 72px; height: 72px;
  border-radius: .9rem; font-size: 1.25rem; font-weight: 900;
  background:
    radial-gradient(200px 160px at 20% -20%, rgba(124,58,237,.24), transparent 55%),
    radial-gradient(200px 160px at 120% 20%, rgba(96,165,250,.22), transparent 55%),
    var(--panel);
  border: 1px solid rgba(255,255,255,.08);
}
.hub-title { margin: 0 0 .35rem; font-size: 1.05rem; }
.hub-meta {
  display: grid;
  grid-template-columns: repeat(3, auto);
  gap: 1rem .8rem;
}
.hub-meta dt { color: var(--muted); font-weight: 600; }
.hub-meta dd { margin: 0; font-weight: 800; }
.hub-actions { display: flex; gap: .5rem; }
.hub-list { margin: .25rem 0 0; padding-left: 1.1rem; }

/* -----------------------------------------------------------------------------
   Privacy & Legal page
   ----------------------------------------------------------------------------- */
.legal-layout { max-width: 120ch; margin-inline: auto; padding-top: 2rem; }
.legal-layout h2 {
  font-size: 1.6rem; font-weight: 900; margin-bottom: 1rem;
  background: linear-gradient(90deg, var(--primary), var(--accent));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.legal-layout .card {
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.05)), var(--panel);
  border-left: 4px solid var(--accent);
  box-shadow: 0 1px 2px rgba(0,0,0,0.1);
  padding: 1.25rem; border-radius: 0.8rem; line-height: 1.65;
}
.legal-layout .card + .card { margin-top: 1.5rem; }
.legal-layout h3 { font-size: 1.1rem; color: var(--primary); margin-bottom: 0.5rem; }
.legal-layout ul { margin: 0.5rem 0 1rem 1.25rem; padding: 0; list-style: disc; }
.legal-layout li { margin-bottom: 0.3rem; }
body.legal-page {
  background:
    radial-gradient(1600px 800px at 50% 0%, rgba(124,58,237,.12), transparent 70%) no-repeat,
    radial-gradient(1000px 700px at 100% 10%, rgba(96,165,250,.1), transparent 60%) no-repeat,
    var(--bg);
  background-repeat: no-repeat; background-attachment: fixed; background-size: cover;
}

/* =============================================================================
   Shared Game Layout (applies to all games)
   - Accurate height via 100dvh + --vh fallback
   ============================================================================= */
.game-layout {
  display: grid;
  grid-template-columns: minmax(200px, 320px) 1fr;
  gap: 2.5rem;
  align-items: start;
  max-width: 1120px;
  margin: 0 auto 2rem;
  padding: 0 1.2rem;
  /* min-block-size: calc(100dvh - var(--header-h) - var(--footer-h)); */
}
@supports not (height: 1dvh) {
  .game-layout {
    min-block-size: calc((var(--vh) * 100) - var(--header-h) - var(--footer-h));
  }
}
.game-sidebar { position: sticky; top: 1.6rem; min-width: 200px; max-width: 320px; }
.game-main { max-width: 600px; width: 100%; margin: 0 auto; }

@media (max-width: 820px) {
  .game-layout { display: block; max-width: none; gap: 0; padding: 0 .5rem; }
  .game-sidebar { position: static; min-width: 0; max-width: none; margin: 1.5em 0 0 0; }
  .game-main { max-width: 98vw; }
}

.game-header { background: none; display: flex; flex-direction: column; align-items: center; padding: 1.1rem 0 .5rem; gap: .35rem; }
.brand-row { display: flex; align-items: center; gap: .8rem; margin-bottom: .3em; }
.game-title { font-size: 1.4rem; font-weight: 700; letter-spacing: .015em; }

.settings-row { display: flex; gap: .5em; flex-wrap: wrap; justify-content: center; margin-bottom: .4em; }
@media (max-width: 520px) { .settings-row { flex-direction: column; gap: .4em; width: 100%; } }

.status-bar {
  font-size: 1.15rem;
  background: linear-gradient(90deg, var(--primary), var(--accent));
  color: #fff;
  border-radius: .7rem;
  padding: .7em 1.2em;
  margin: 0 0 1.2rem 0;
  box-shadow: 0 2px 8px rgba(124,58,237,0.14);
  text-align: center; letter-spacing: .02em;
}
.actions-bar { display: flex; gap: .55em; flex-wrap: wrap; justify-content: center; margin-bottom: 1.2em; }
@media (max-width:520px) { .actions-bar { flex-direction: column; align-items: stretch; gap: .5em; margin-bottom: .8em; } }

/* =============================================================================
   Custom Select (shared)
   - Rotating chevron only on the trigger
   - No styling on option items beyond your palette
   ============================================================================= */
.custom-select {
  position: relative;
  display: inline-block;
  font-size: 1rem;
  font-weight: 600;
  min-width: 140px;
  max-width: 100%;
  user-select: none;
  cursor: pointer;
  z-index: 10;
  color: var(--text);
}
.custom-select-selected {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  height: var(--ctrl-h);
  width: 100%;
  padding: 0 1em;
  border-radius: .4em;
  background: var(--panel);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition: background .2s ease, border .2s ease;
  position: relative; /* for arrow */
}
.custom-select-selected:hover,
.custom-select-selected:focus { background: rgba(255, 255, 255, 0.05); outline: none; }

/* Rotate-only arrow on the trigger */
.custom-select-selected::after {
  content: "⯆";
  position: absolute; right: .75em; top: 50%;
  transform: translateY(-50%) rotate(0deg);
  transition: transform .25s ease;
  pointer-events: none;
  font-size: .85em; color: var(--muted);
}
.custom-select-selected[aria-expanded="true"]::after {
  transform: translateY(-50%) rotate(180deg);
}

.custom-select-options {
  position: absolute; top: calc(100% + .25em); left: 0; width: 100%;
  margin-top: 0; padding: .25em 0;
  border-radius: .4em; background: var(--panel);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 6px 12px rgba(0,0,0,.25);
  z-index: 100; font-size: 1rem;
}
.custom-select-options[hidden] { display: none; }
.custom-select-options li {
  padding: .45em 1em;
  white-space: nowrap;
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
  list-style: none; /* scoped reset */
}
.custom-select-options li:hover,
.custom-select-options li:focus {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
  outline: none;
}
.custom-select-options li[aria-selected="true"] {
  font-weight: 700;
  background: rgba(255, 255, 255, 0.08);
}




/* ============================================================================
   Responsive hardening (320px → desktop)
   - Prevent overflows
   - Compact controls on small screens
   - Stack "About" card cleanly
   - Make hub grid adapt without gaps
   ============================================================================ */

/* 1) Generic guards: prevent mystery overflows */
html { overflow-x: hidden; }
body { overflow-x: clip; }

img, svg, video, canvas {
  max-inline-size: 100%;
  block-size: auto;
  display: block;
}

*,
*::before,
*::after { min-inline-size: 0; } /* allow flex/grid children to shrink */

/* Long words / URLs don’t push layouts off-screen */
.hub-card, .card, .brand, .controls {
  word-wrap: break-word;
  overflow-wrap: anywhere;
}

/* 2) Header: shrink & wrap sanely on small screens */
.app-header {
  grid-template-columns: 1fr auto;
  gap: .75rem 1rem;
}

.brand { flex-wrap: wrap; }
.brand .brand-title,
.brand .game-title {
  /* Allow wrapping on tiny viewports */
  white-space: normal;
}

/* Controls can wrap to multiple lines without pushing width */
.controls {
  flex-wrap: wrap;
  gap: .45rem .55rem;
  justify-content: flex-end;
}
.controls > * {
  flex: 0 1 auto;        /* allow shrinking */
  min-inline-size: 0;    /* no min-content overflow */
}

/* Buttons & theme toggle compress gracefully at 320–360px */
.btn {
  padding-inline: .7rem;
  font-size: clamp(.9rem, 2.6vw, 1rem);
  height: var(--ctrl-h);
}
.theme-btn { width: var(--ctrl-h); }

/* 3) Selects: allow shrinking + scrolling menu on phones */
.select-wrap { min-width: 0; }
.custom-select { min-width: 0; max-width: 100%; }
.custom-select-selected { padding-inline: .75em 2.25em; }
.custom-select-options {
  max-height: 240px;
  overflow: auto;
  overscroll-behavior: contain;
}

/* 5) Hub layout: keep same outer width, make grid adaptive inside */
.layout {
  /* Existing structure kept; just safe padding on tiny screens */
  padding-inline: clamp(.75rem, 3vw, 2rem);
}

.hub-grid {
  /* Make cards adapt to narrow phones without overflow gaps */
  --card-min: clamp(200px, 46vw, 280px);
  grid-auto-rows: 1fr;
}

/* Ensure hub cards don't get squished by long text */
.hub-card { min-width: 0; }

/* 6) Sidebar: no overflow on small viewports */
.sidebar { min-width: 0; }

/* 7) Game layout: avoid horizontal scroll at small widths */
.game-layout {
  gap: clamp(1rem, 3vw, 2.5rem);
  padding-inline: clamp(.5rem, 2vw, 1.2rem);
}

@media (max-width: 820px) {
  .game-layout { display: block; }
  .game-sidebar, .game-main { max-width: 100%; }
}

/* 8) Tiny baseline tweaks to keep brand row visually level */
:root{
  --brand-title-y: 0.03em;
  --crumb-y:       0.02em;
}
.brand-title{ transform: translateY(var(--brand-title-y)); }
.divider, .game-title{ transform: translateY(var(--crumb-y)); }

/* 9) Motion-respectful UI (optional but nice) */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
}
/* Orientation overlay base */
.orientation-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.72);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

/* respect [hidden] attribute */
.orientation-overlay[hidden] { display: none !important; }

.orientation-box {
  background: var(--panel);
  color: var(--text);
  padding: 1.25rem 1.5rem;
  border-radius: 1rem;
  font-weight: 800;
  text-align: center;
  box-shadow: 0 6px 16px rgba(0,0,0,.4);
}

/* Restrict to mobile/tablet only */
@media (min-width: 1025px) {
  #orientationOverlay { display: none !important; }
}

/* =============================================================================
   End of file
   ============================================================================= */

/* =============================================================================
   Project PlayDeck hub dashboard
   - Scoped to .hub-page so game pages retain their existing layout
   ============================================================================= */
.hub-page .hub-header {
  width: min(1440px, 100%);
  margin: 0 auto;
  padding-block: .85rem;
}

.hub-page .brand-link > span {
  display: grid;
  gap: .18rem;
}

.hub-page .brand-subtitle {
  color: var(--muted);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  line-height: 1;
  text-transform: uppercase;
}

.hub-page .hub-controls {
  justify-content: flex-end;
}

.hub-page .hub-search {
  flex: 1 1 220px;
  max-width: 340px;
}

.hub-page .hub-search input {
  width: 100%;
  min-height: var(--ctrl-h);
  appearance: none;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: .65rem;
  color: var(--text);
  font: inherit;
  font-weight: 600;
  padding: .5rem .8rem;
}

.hub-page .hub-search input:focus-visible,
.hub-page .hub-sort:focus-within {
  outline: none;
  box-shadow: var(--ring);
}

.hub-dashboard {
  display: grid;
  gap: clamp(1.2rem, 3vw, 2rem);
  width: min(1440px, 100%);
  margin: 0 auto;
  padding: 0 clamp(.75rem, 3vw, 2rem) 2.5rem;
}

.hub-hero {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(280px, .85fr);
  gap: clamp(1.5rem, 4vw, 3.5rem);
  align-items: center;
  padding: clamp(1.35rem, 4vw, 3rem);
  background:
    radial-gradient(700px 400px at 105% -15%, var(--primary-glow), transparent 65%),
    radial-gradient(650px 420px at -10% 110%, var(--accent-glow), transparent 70%),
    var(--panel);
  border: 1px solid var(--border);
  border-radius: 1.35rem;
  box-shadow: 0 18px 50px rgba(0,0,0,.12);
}

.hub-hero-copy { max-width: 760px; }
.eyebrow,
.section-kicker {
  margin: 0 0 .35rem;
  color: var(--primary);
  font-size: .74rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.hub-hero h1 {
  max-width: 18ch;
  margin: 0;
  font-size: clamp(2rem, 5vw, 4.3rem);
  line-height: 1.02;
  letter-spacing: -.045em;
}

.hub-value {
  max-width: 62ch;
  margin: 1rem 0 0;
  color: var(--muted);
  font-size: clamp(1rem, 2vw, 1.16rem);
}

.hub-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem;
}

.summary-stat {
  display: grid;
  align-content: center;
  min-height: 118px;
  padding: 1rem;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 1rem;
}

.summary-stat strong {
  color: var(--text);
  font-size: clamp(1.7rem, 4vw, 2.8rem);
  line-height: 1;
}

.summary-stat span {
  margin-top: .45rem;
  color: var(--muted);
  font-size: .82rem;
  font-weight: 700;
  line-height: 1.25;
}

.privacy-note-icon {
  display: grid;
  place-items: center;
  flex: 0 0 30px;
  width: 30px;
  height: 30px;
  background: color-mix(in srgb, var(--ok) 16%, transparent);
  border-radius: 50%;
  color: var(--ok);
  font-weight: 900;
}

.personalisation-panel {
  display: grid;
  grid-template-columns: minmax(210px, .8fr) minmax(0, 2.2fr);
  gap: 1.25rem;
  padding: 1rem 1.1rem;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 1rem;
}

.personalisation-copy h2 {
  margin: 0;
  font-size: 1rem;
}

.personalisation-copy p:last-child {
  margin: .25rem 0 0;
  color: var(--muted);
  font-size: .84rem;
}

.personalisation-controls {
  display: grid;
  gap: .8rem;
}

.mode-switcher,
.skin-switcher {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  min-width: 0;
  margin: 0;
  padding: 0;
  border: 0;
}

.mode-switcher legend,
.skin-switcher legend {
  flex: 0 0 100%;
  margin-bottom: .15rem;
  color: var(--muted);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.setting-pill,
.skin-option {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  min-height: 40px;
  padding: .35rem .65rem;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: .65rem;
  color: var(--muted);
  font-size: .8rem;
  font-weight: 800;
  cursor: pointer;
}

.setting-pill {
  appearance: none;
  color: var(--text);
  font: inherit;
  font-size: .8rem;
  font-weight: 800;
}

.setting-pill:hover,
.skin-option:hover { border-color: var(--primary); color: var(--text); }
.skin-option:has(input:checked) {
  background: color-mix(in srgb, var(--primary) 10%, transparent);
  border-color: var(--primary);
  color: var(--text);
}
.setting-pill:focus-visible,
.skin-option:has(input:focus-visible) {
  outline: none;
  box-shadow: var(--ring);
}
.setting-pill[aria-pressed="true"] {
  background: color-mix(in srgb, var(--primary) 10%, transparent);
  border-color: var(--primary);
}
.skin-option input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.mode-icon {
  display: block;
  flex: 0 0 auto;
  width: 34px;
  height: 20px;
  background: linear-gradient(90deg, #050505, #ffffff);
  border: 0;
  border-radius: 999px;
  box-shadow: inset 0 0 0 1px rgba(127,127,127,.45);
}

.mode-icon--dark {
  background: linear-gradient(90deg, #050505, #ffffff);
}

.mode-icon--light {
  background: linear-gradient(90deg, #ffffff, #050505);
}

.skin-preview {
  display: inline-flex;
  overflow: hidden;
  width: 34px;
  height: 20px;
  border: 1px solid var(--border);
  border-radius: 999px;
}
.skin-preview i { flex: 1; }
.skin-lattice i:nth-child(1) { background: #0b1220; } .skin-lattice i:nth-child(2) { background: #60a5fa; } .skin-lattice i:nth-child(3) { background: #7c3aed; }
.skin-arcade i:nth-child(1) { background: #241044; } .skin-arcade i:nth-child(2) { background: #ffd93d; } .skin-arcade i:nth-child(3) { background: #ff4ecd; }
.skin-neon i:nth-child(1) { background: #030712; } .skin-neon i:nth-child(2) { background: #22d3ee; } .skin-neon i:nth-child(3) { background: #a3ff12; }
.skin-retro i:nth-child(1) { background: #352622; } .skin-retro i:nth-child(2) { background: #f4b942; } .skin-retro i:nth-child(3) { background: #dc6b3c; }
.skin-forest i:nth-child(1) { background: #10251b; } .skin-forest i:nth-child(2) { background: #86d17f; } .skin-forest i:nth-child(3) { background: #d6a85f; }
.skin-ocean i:nth-child(1) { background: #0b2434; } .skin-ocean i:nth-child(2) { background: #7dd3fc; } .skin-ocean i:nth-child(3) { background: #2dd4bf; }
.skin-sakura i:nth-child(1) { background: #2d1726; } .skin-sakura i:nth-child(2) { background: #f9a8d4; } .skin-sakura i:nth-child(3) { background: #c4b5fd; }
.skin-mono i:nth-child(1) { background: #171717; } .skin-mono i:nth-child(2) { background: #f5f5f5; } .skin-mono i:nth-child(3) { background: #777; }

.personalisation-privacy {
  display: flex;
  align-items: center;
  gap: .75rem;
  grid-column: 1 / -1;
  padding: .8rem .9rem;
  background: linear-gradient(90deg, color-mix(in srgb, var(--ok) 9%, var(--panel)), color-mix(in srgb, var(--primary) 7%, var(--panel)));
  border: 1px solid color-mix(in srgb, var(--ok) 30%, var(--border));
  border-radius: .75rem;
}

.personalisation-privacy p { flex: 1; margin: 0; color: var(--muted); font-size: .84rem; }
.personalisation-privacy strong { color: var(--text); }
.personalisation-privacy a { white-space: nowrap; }

.hub-options {
  width: min(760px, calc(100vw - 2rem));
  max-height: min(760px, calc(100dvh - 2rem));
  padding: 0;
  overflow: auto;
  color: var(--text);
  background:
    radial-gradient(520px 260px at 12% 0%, var(--primary-glow), transparent 62%),
    linear-gradient(180deg, color-mix(in srgb, var(--panel) 96%, var(--surface)), var(--panel));
  border: 1px solid var(--border);
  border-radius: 1rem;
  box-shadow: 0 28px 90px rgba(0,0,0,.42);
}

.hub-options::backdrop {
  background:
    radial-gradient(900px 520px at 50% 10%, color-mix(in srgb, var(--primary) 14%, transparent), transparent 62%),
    rgba(0,0,0,.62);
  backdrop-filter: blur(5px);
}

.hub-options__header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1rem .85rem;
  border-bottom: 1px solid var(--border);
}

.hub-options__header h2,
.hub-options__header p {
  margin: 0;
}

.hub-options__header h2 {
  font-size: 1.24rem;
  line-height: 1.1;
}

.hub-options__header .section-kicker {
  margin-bottom: .28rem;
}

.hub-options__header p:last-child {
  margin-top: .35rem;
  color: var(--muted);
  font-size: .88rem;
}

.hub-options__close {
  flex: 0 0 auto;
}

.hub-options__body {
  display: grid;
  gap: 1rem;
  padding: 1rem;
}

.hub-options .personalisation-panel {
  grid-template-columns: 1fr;
  gap: 1rem;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
}

.hub-options .personalisation-copy {
  display: none;
}

.hub-options .personalisation-controls {
  gap: 1rem;
}

.hub-options .mode-switcher,
.hub-options .skin-switcher {
  padding: .85rem;
  background: color-mix(in srgb, var(--surface-soft) 72%, transparent);
  border: 1px solid var(--border);
  border-radius: .9rem;
}

.hub-options .skin-switcher {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hub-options .skin-switcher legend {
  grid-column: 1 / -1;
}

.hub-options .setting-pill,
.hub-options .skin-option {
  min-height: 42px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(0,0,0,.06)),
    var(--panel);
}

.hub-options .skin-option {
  justify-content: start;
}

.hub-options .personalisation-privacy {
  margin-top: 0;
}

@media (max-width: 650px) {
  .hub-options {
    width: min(100vw - 1rem, 680px);
    max-height: calc(100dvh - 1rem);
  }

  .hub-options__header {
    flex-direction: column;
  }

  .hub-options__close {
    width: 100%;
    justify-content: center;
  }

  .hub-options .skin-switcher {
    grid-template-columns: 1fr;
  }
}

.library-section {
  display: grid;
  gap: 1rem;
  scroll-margin-top: 1rem;
}

.section-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: .65rem;
  border-bottom: 1px solid var(--border);
}

.section-heading h2 {
  margin: 0;
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  letter-spacing: -.025em;
}

.section-count {
  color: var(--muted);
  font-size: .82rem;
  font-weight: 800;
}

.clear-history-btn {
  flex: 0 0 auto;
  height: auto;
  min-height: 34px;
  padding: .35rem .7rem;
  color: var(--muted);
  font-size: .78rem;
}

.clear-history-btn:hover,
.clear-history-btn:focus-visible {
  color: var(--text);
}

.continue-empty-card {
  display: grid;
  gap: .3rem;
  padding: 1rem 1.1rem;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--primary) 5%, transparent), transparent 55%),
    var(--panel);
  border: 1px solid var(--border);
  border-radius: 1rem;
}

.continue-empty-card strong {
  font-size: .95rem;
}

.continue-empty-card p {
  max-width: 64ch;
  margin: 0;
  color: var(--muted);
  font-size: .86rem;
}

.hub-page .hub-grid {
  --card-min: 300px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, var(--card-min)), 1fr));
  gap: 1rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.hub-page .hub-grid-continue {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 340px), 1fr));
}

.hub-page .hub-card {
  position: relative;
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  gap: 1rem;
  min-height: 235px;
  padding: 1rem;
  background:
    var(--card-wash),
    var(--panel);
  border: 1px solid var(--border);
  border-radius: 1.1rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.hub-page .hub-card:hover {
  transform: translateY(-2px);
  border-color: var(--border-strong);
  box-shadow: 0 14px 34px rgba(0,0,0,.13);
}

.hub-card-image {
  display: grid;
  place-items: center;
  width: 104px;
  height: 104px;
  overflow: hidden;
  background:
    radial-gradient(130px 100px at 20% 0%, var(--accent-glow), transparent 60%),
    var(--bg);
  border: 1px solid var(--border);
  border-radius: .95rem;
}

.hub-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hub-placeholder-mark {
  color: var(--primary);
  font-size: 2.35rem;
  font-weight: 900;
}

.hub-card-content {
  display: grid;
  align-content: start;
  gap: .65rem;
  min-width: 0;
}

.hub-card-heading {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: .65rem;
}

.hub-card-heading h3 {
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.25;
}

.status-badge {
  flex: 0 0 auto;
  padding: .18rem .45rem;
  border: 1px solid currentColor;
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .04em;
  line-height: 1.25;
  text-transform: uppercase;
}

.status-live {
  color: #4ade80;
  background: rgba(34,197,94,.12);
  border-color: rgba(74,222,128,.58);
}
.status-beta {
  color: #86efac;
  background: rgba(134,239,172,.10);
  border-color: rgba(134,239,172,.52);
}
.status-development {
  color: #fbbf24;
  background: rgba(245,158,11,.12);
  border-color: rgba(251,191,36,.58);
}
.status-coming {
  color: #fb7185;
  background: rgba(244,63,94,.12);
  border-color: rgba(251,113,133,.58);
}

[data-theme="light"] .status-live { color: #166534; background: #dcfce7; border-color: #16a34a; }
[data-theme="light"] .status-beta { color: #86198f; background: #fae8ff; border-color: #d946ef; }
[data-theme="light"] .status-development { color: #92400e; background: #fef3c7; border-color: #d97706; }
[data-theme="light"] .status-coming { color: #9f1239; background: #ffe4e6; border-color: #e11d48; }

.hub-description {
  margin: 0;
  color: var(--muted);
  font-size: .88rem;
  line-height: 1.45;
}

.hub-page .hub-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .45rem;
  grid-column: 1 / -1;
  margin: 0;
}

.hub-page .hub-meta > div {
  padding: .45rem .55rem;
  background: var(--surface-soft);
  border-radius: .55rem;
}

.hub-page .hub-meta dt {
  color: var(--muted);
  font-size: .67rem;
  font-weight: 800;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.hub-page .hub-meta dd {
  overflow: hidden;
  margin: .12rem 0 0;
  font-size: .83rem;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hub-page .hub-actions {
  display: flex;
  grid-column: 1 / -1;
  margin-top: .1rem;
}

.hub-page .hub-actions .btn {
  justify-content: center;
  width: 100%;
  min-height: 38px;
}

.hub-page .hub-card.compact {
  grid-template-columns: 52px minmax(0, 1fr);
  min-height: 148px;
  gap: .8rem;
  padding: .9rem;
}

.hub-page .hub-card.compact .hub-card-image {
  width: 52px;
  height: 52px;
  border-radius: .7rem;
}

.hub-page .hub-card.compact .hub-placeholder-mark {
  font-size: 1.35rem;
}

.hub-page .hub-card.compact .hub-card-heading {
  align-items: center;
}

.hub-page .hub-card.compact .hub-card-heading h3 {
  font-size: 1rem;
  line-height: 1.25;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.hub-page .hub-card.compact .hub-description {
  margin: .45rem 0 0;
}

.section-empty {
  margin: 0;
  padding: 1rem;
  color: var(--muted);
  background: var(--surface-soft);
  border: 1px dashed var(--border);
  border-radius: .9rem;
  text-align: center;
}

.no-results { padding: 2rem 1rem; }

@media (max-width: 1050px) {
  .hub-hero { grid-template-columns: 1fr; }
  .hub-summary { max-width: 680px; }
}

@media (max-width: 650px) {
  .hub-page .hub-header { padding-inline: .75rem; }
  .hub-page .hub-controls { width: 100%; justify-content: stretch; }
  .hub-page .hub-search { flex-basis: 100%; max-width: none; }
  .hub-page .hub-sort { flex: 1 1 auto; }
  .hub-page .hub-sort select { width: 100%; }
  .hub-hero { padding: 1.2rem; border-radius: 1rem; }
  .hub-hero h1 { max-width: none; }
  .hub-summary { grid-template-columns: 1fr; }
  .summary-stat { min-height: 82px; }
  .personalisation-panel { grid-template-columns: 1fr; }
  .skin-switcher { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .skin-switcher legend { grid-column: 1 / -1; }
  .personalisation-privacy { align-items: start; flex-wrap: wrap; }
  .personalisation-privacy p { flex-basis: calc(100% - 50px); }
  .personalisation-privacy a { margin-left: 42px; }
  .hub-page .hub-card {
    grid-template-columns: 76px minmax(0, 1fr);
    min-height: 0;
    gap: .8rem;
    padding: .85rem;
  }
  .hub-card-image { width: 76px; height: 76px; }
  .hub-card-heading { align-items: start; flex-wrap: wrap; }
  .hub-page .hub-meta { grid-column: 1 / -1; }
  .hub-page .hub-actions .btn { width: 100%; min-height: 42px; }
  .hub-page .hub-card.compact {
    grid-template-columns: 48px minmax(0, 1fr);
  }
  .hub-page .hub-card.compact .hub-card-image {
    width: 48px;
    height: 48px;
  }
}

@media (max-width: 390px) {
  .hub-page .brand-mark { block-size: 2.5em; }
  .hub-page .brand-title { font-size: 1.05rem; }
  .hub-page .hub-card { grid-template-columns: 1fr; }
  .hub-card-image { width: 100%; height: 140px; }
  .hub-page .hub-meta { grid-column: auto; }
  .skin-switcher { grid-template-columns: 1fr; }
  .hub-page .hub-card.compact {
    grid-template-columns: 42px minmax(0, 1fr);
  }
  .hub-page .hub-card.compact .hub-card-image {
    width: 42px;
    height: 42px;
  }
}

[data-theme="dark"][data-skin="mono"] .btn.primary { --primary-button-text: #111111; }
[data-theme="light"][data-skin="mono"] .btn.primary { --primary-button-text: #ffffff; }

/* -----------------------------------------------------------------------------
   Layout stability
   Prevent horizontal layout shift when the vertical scrollbar appears/disappears.
   ----------------------------------------------------------------------------- */

html {
  overflow-y: scroll;
  scrollbar-gutter: stable;
}

/* -----------------------------------------------------------------------------
   Header PL mark — final positioning pass
   ----------------------------------------------------------------------------- */

.app-header__mark {
  --mark-size: 2.55rem;
  --mark-radius: 0.62rem;

  --p-size: 1.75rem;
  --l-size: 1.55rem;

  --p-x: 0.48rem;
  --p-y: 0.38rem;

  --l-x: 1.12rem;
  --l-y: 0.86rem;

  position: relative;
  display: block;
  inline-size: var(--mark-size);
  block-size: var(--mark-size);
  flex: 0 0 var(--mark-size);

  overflow: hidden;
  border-radius: var(--mark-radius);
  border: 1px solid rgba(255, 255, 255, 0.12);

  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.10),
      rgba(0, 0, 0, 0.10)
    ),
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--accent) 34%, var(--panel)),
      color-mix(in srgb, var(--primary) 22%, var(--panel))
    );

  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.07),
    0 0.45rem 1rem rgba(0, 0, 0, 0.28);
}

.app-header__mark::before,
.app-header__mark::after {
  content: none;
}

.app-header__mark-letter {
  position: absolute;
  display: block;
  margin: 0;
  padding: 0;

  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-weight: 900;
  line-height: 0.82;
  letter-spacing: -0.12em;

  color: rgba(255, 255, 255, 0.94);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);

  transform: none;
}

.app-header__mark-letter--p {
  left: var(--p-x);
  top: var(--p-y);
  z-index: 2;

  font-size: var(--p-size);
  opacity: 1;
}

.app-header__mark-letter--l {
  left: var(--l-x);
  top: var(--l-y);
  z-index: 1;

  font-size: var(--l-size);
  opacity: 0.52;
}

[data-theme="light"] .app-header__mark {
  border-color: rgba(17, 24, 39, 0.12);

  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.26),
      rgba(0, 0, 0, 0.04)
    ),
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--accent) 28%, var(--panel)),
      color-mix(in srgb, var(--primary) 18%, var(--panel))
    );

  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.24),
    0 0.35rem 0.8rem rgba(17, 24, 39, 0.12);
}

[data-theme="light"] .app-header__mark-letter {
  color: rgba(255, 255, 255, 0.94);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.22);
}

/* =============================================================================
   Project PlayDeck hero service ribbon mini rack
   Compact earned military-style ribbon rack under the hub stat boxes.
   ============================================================================= */

.hub-page .hub-summary {
  align-content: center;
}

.hub-page .service-ribbon-mini {
  display: grid;
  grid-column: 1 / -1;
  gap: 0.45rem;
  margin-top: 0.1rem;
  padding: 0.72rem;
  background: color-mix(in srgb, var(--surface-soft) 80%, transparent);
  border: 1px solid var(--border);
  border-radius: 0.9rem;
}

.hub-page .service-ribbon-mini__top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.15;
  text-transform: uppercase;
}

.hub-page .service-ribbon-mini__top span:last-child {
  letter-spacing: 0.02em;
  text-transform: none;
}

.hub-page .service-ribbon-mini__rack {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.18rem 0.22rem;
  min-height: 1.18rem;
  overflow: visible;
}

.hub-page .service-ribbon-mini__empty {
  margin: 0;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
}

.hub-page .pd-ribbon-link {
  display: inline-grid;
  place-items: center;
  position: relative;
  border-radius: 0.18rem;
  text-decoration: none;
}

.hub-page .pd-ribbon-link:focus-visible {
  outline: none;
  box-shadow: var(--ring);
}

.hub-page .pd-ribbon-link[data-tooltip]::before {
  content: attr(data-tooltip);
  position: absolute;
  inset-block-end: calc(100% + 0.6rem);
  inset-inline-start: 50%;
  z-index: 80;
  width: max-content;
  max-width: min(18rem, 76vw);
  padding: 0.5rem 0.62rem;
  border: 1px solid color-mix(in srgb, var(--primary) 35%, transparent);
  border-radius: 0.55rem;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.055), rgba(0,0,0,0.12)),
    var(--panel);
  color: var(--text);
  box-shadow: 0 14px 34px rgba(0,0,0,0.28);
  font-size: 0.72rem;
  font-weight: 850;
  letter-spacing: 0.01em;
  line-height: 1.35;
  text-align: center;
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 0.25rem) scale(0.98);
  transition:
    opacity 0.16s ease,
    transform 0.16s ease;
}

.hub-page .pd-ribbon-link[data-tooltip]::after {
  content: "";
  position: absolute;
  inset-block-end: calc(100% + 0.32rem);
  inset-inline-start: 50%;
  z-index: 81;
  width: 0.5rem;
  height: 0.5rem;
  background: var(--panel);
  border-right: 1px solid color-mix(in srgb, var(--primary) 35%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--primary) 35%, transparent);
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 0.25rem) rotate(45deg);
  transition:
    opacity 0.16s ease,
    transform 0.16s ease;
}

.hub-page .pd-ribbon-link[data-tooltip]:hover::before,
.hub-page .pd-ribbon-link[data-tooltip]:hover::after,
.hub-page .pd-ribbon-link[data-tooltip]:focus-visible::before,
.hub-page .pd-ribbon-link[data-tooltip]:focus-visible::after {
  opacity: 1;
}

.hub-page .pd-ribbon-link[data-tooltip]:hover::before,
.hub-page .pd-ribbon-link[data-tooltip]:focus-visible::before {
  transform: translate(-50%, 0) scale(1);
}

.hub-page .pd-ribbon-link[data-tooltip]:hover::after,
.hub-page .pd-ribbon-link[data-tooltip]:focus-visible::after {
  transform: translate(-50%, 0) rotate(45deg);
}

.hub-page .pd-ribbon {
  --ribbon-bg: linear-gradient(
    90deg,
    #1f2937 0 20%,
    #93c5fd 20% 26%,
    #111827 26% 74%,
    #93c5fd 74% 80%,
    #1f2937 80% 100%
  );

  position: relative;
  display: inline-grid;
  place-items: center;
  inline-size: 3.65rem;
  block-size: 1rem;
  overflow: hidden;
  background: var(--ribbon-bg);
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: 0.14rem;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.2),
    inset 0 -1px 0 rgba(0,0,0,0.22),
    0 3px 8px rgba(0,0,0,0.14);
}

.hub-page .pd-ribbon::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.16),
      transparent 48%,
      rgba(0,0,0,0.14)
    );
  pointer-events: none;
}

.hub-page .pd-ribbon__devices {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.04rem;
  line-height: 1;
}

.hub-page .pd-ribbon__device {
  position: relative;
  display: grid;
  place-items: center;
  min-inline-size: 0.46rem;
  block-size: 0.68rem;
  font-size: 0.58rem;
  line-height: 1;
  text-shadow:
    0 1px 1px rgba(0,0,0,0.75),
    0 0 5px rgba(0,0,0,0.35);
}

.hub-page .pd-ribbon__device--bronze-star::before { content: "★"; color: #cd7f32; }
.hub-page .pd-ribbon__device--silver-star::before { content: "★"; color: #e5e7eb; }
.hub-page .pd-ribbon__device--bronze-oak-leaf::before { content: "❧"; color: #cd7f32; }
.hub-page .pd-ribbon__device--silver-oak-leaf::before { content: "❧"; color: #e5e7eb; }
.hub-page .pd-ribbon__device--anchor::before { content: "⚓"; color: #dbeafe; }
.hub-page .pd-ribbon__device--flag::before { content: "⚑"; color: #f97316; }
.hub-page .pd-ribbon__device--eod-citation::before { content: "✦"; color: #facc15; }
.hub-page .pd-ribbon__device--lightning::before { content: "⚡"; color: #facc15; }

/* Campaign count ribbons — Minesweeper */
.hub-page .pd-ribbon--campaign-one { --ribbon-bg: linear-gradient(90deg, #1e3a8a 0 24%, #f8fafc 24% 38%, #dc2626 38% 62%, #f8fafc 62% 76%, #1e3a8a 76% 100%); }
.hub-page .pd-ribbon--campaign-three { --ribbon-bg: linear-gradient(90deg, #334155 0 16%, #f59e0b 16% 30%, #f8fafc 30% 44%, #0f172a 44% 56%, #f8fafc 56% 70%, #f59e0b 70% 84%, #334155 84% 100%); }
.hub-page .pd-ribbon--campaign-five { --ribbon-bg: linear-gradient(90deg, #14532d 0 20%, #f8fafc 20% 32%, #facc15 32% 44%, #166534 44% 56%, #facc15 56% 68%, #f8fafc 68% 80%, #14532d 80% 100%); }
.hub-page .pd-ribbon--campaign-ten { --ribbon-bg: linear-gradient(90deg, #134e4a 0 18%, #14b8a6 18% 32%, #e2e8f0 32% 42%, #020617 42% 58%, #e2e8f0 58% 68%, #14b8a6 68% 82%, #134e4a 82% 100%); }
.hub-page .pd-ribbon--campaign-fifteen { --ribbon-bg: linear-gradient(90deg, #422006 0 18%, #f97316 18% 32%, #fef3c7 32% 44%, #111827 44% 56%, #fef3c7 56% 68%, #f97316 68% 82%, #422006 82% 100%); }
.hub-page .pd-ribbon--campaign-twenty-five { --ribbon-bg: linear-gradient(90deg, #581c87 0 18%, #a855f7 18% 30%, #facc15 30% 42%, #f8fafc 42% 58%, #facc15 58% 70%, #a855f7 70% 82%, #581c87 82% 100%); }
.hub-page .pd-ribbon--campaign-thirty-five { --ribbon-bg: linear-gradient(90deg, #0f172a 0 15%, #64748b 15% 28%, #f8fafc 28% 38%, #ef4444 38% 50%, #facc15 50% 62%, #f8fafc 62% 72%, #64748b 72% 85%, #0f172a 85% 100%); }
.hub-page .pd-ribbon--campaign-fifty { --ribbon-bg: linear-gradient(90deg, #111827 0 16%, #7f1d1d 16% 30%, #cd7f32 30% 42%, #fef3c7 42% 58%, #cd7f32 58% 70%, #7f1d1d 70% 84%, #111827 84% 100%); }
.hub-page .pd-ribbon--campaign-seventy-five { --ribbon-bg: linear-gradient(90deg, #082f49 0 16%, #0284c7 16% 30%, #bae6fd 30% 42%, #0f172a 42% 58%, #bae6fd 58% 70%, #0284c7 70% 84%, #082f49 84% 100%); }
.hub-page .pd-ribbon--campaign-hundred { --ribbon-bg: linear-gradient(90deg, #020617 0 16%, #38bdf8 16% 30%, #f8fafc 30% 42%, #facc15 42% 58%, #f8fafc 58% 70%, #38bdf8 70% 84%, #020617 84% 100%); }
.hub-page .pd-ribbon--campaign-one-fifty { --ribbon-bg: linear-gradient(90deg, #052e16 0 14%, #16a34a 14% 26%, #facc15 26% 38%, #f8fafc 38% 50%, #111827 50% 62%, #f8fafc 62% 74%, #16a34a 74% 86%, #052e16 86% 100%); }
.hub-page .pd-ribbon--campaign-two-fifty { --ribbon-bg: linear-gradient(90deg, #030712 0 12%, #dc2626 12% 22%, #facc15 22% 34%, #f8fafc 34% 46%, #1d4ed8 46% 54%, #f8fafc 54% 66%, #facc15 66% 78%, #dc2626 78% 88%, #030712 88% 100%); }

/* Citation ribbons — Minesweeper */
.hub-page .pd-ribbon--citation-deployment { --ribbon-bg: linear-gradient(90deg, #111827 0 18%, #60a5fa 18% 34%, #f8fafc 34% 46%, #1d4ed8 46% 54%, #f8fafc 54% 66%, #60a5fa 66% 82%, #111827 82% 100%); }
.hub-page .pd-ribbon--citation-safe-lane { --ribbon-bg: linear-gradient(90deg, #064e3b 0 18%, #d1fae5 18% 30%, #22c55e 30% 44%, #0f172a 44% 56%, #22c55e 56% 70%, #d1fae5 70% 82%, #064e3b 82% 100%); }
.hub-page .pd-ribbon--citation-flag-discipline { --ribbon-bg: linear-gradient(90deg, #111827 0 12%, #f97316 12% 28%, #166534 28% 44%, #f8fafc 44% 56%, #166534 56% 72%, #f97316 72% 88%, #111827 88% 100%); }
.hub-page .pd-ribbon--citation-instinctive { --ribbon-bg: linear-gradient(90deg, #172554 0 16%, #e5e7eb 16% 28%, #0f172a 28% 44%, #a855f7 44% 56%, #0f172a 56% 72%, #e5e7eb 72% 84%, #172554 84% 100%); }
.hub-page .pd-ribbon--citation-intermediate { --ribbon-bg: linear-gradient(90deg, #052e16 0 14%, #84cc16 14% 28%, #f8fafc 28% 40%, #1d4ed8 40% 60%, #f8fafc 60% 72%, #84cc16 72% 86%, #052e16 86% 100%); }
.hub-page .pd-ribbon--citation-expert { --ribbon-bg: linear-gradient(90deg, #030712 0 12%, #dc2626 12% 24%, #facc15 24% 36%, #111827 36% 64%, #facc15 64% 76%, #dc2626 76% 88%, #030712 88% 100%); }
.hub-page .pd-ribbon--citation-streak { --ribbon-bg: linear-gradient(90deg, #312e81 0 16%, #818cf8 16% 30%, #f8fafc 30% 42%, #16a34a 42% 58%, #f8fafc 58% 70%, #818cf8 70% 84%, #312e81 84% 100%); }
.hub-page .pd-ribbon--citation-rapid { --ribbon-bg: linear-gradient(90deg, #030712 0 14%, #facc15 14% 26%, #ef4444 26% 38%, #f8fafc 38% 50%, #ef4444 50% 62%, #facc15 62% 74%, #030712 74% 100%); }

/* Naval ribbons and devices for Battleships. */
.hub-page .pd-ribbon__device--naval-anchor::before,
.hub-page .pd-ribbon__device--naval-compass::before,
.hub-page .pd-ribbon__device--naval-trident::before,
.hub-page .pd-ribbon__device--naval-shield::before,
.hub-page .pd-ribbon__device--naval-wake::before { content: "\2693"; color: #dbeafe; }
.hub-page .pd-ribbon__device--naval-cannon::before,
.hub-page .pd-ribbon__device--naval-shell::before,
.hub-page .pd-ribbon__device--naval-crosshair::before,
.hub-page .pd-ribbon__device--naval-pennant::before,
.hub-page .pd-ribbon__device--naval-lightning::before { content: "\25AC"; color: #f8fafc; }
.hub-page .pd-ribbon__device--naval-bronze-star::before { content: "\2605"; color: #cd7f32; }
.hub-page .pd-ribbon__device--naval-silver-star::before,
.hub-page .pd-ribbon__device--naval-crown::before { content: "\2605"; color: #e5e7eb; }

.hub-page .pd-ribbon--naval-patrol { --ribbon-bg: linear-gradient(90deg, #06111f 0 18%, #0ea5e9 18% 30%, #e0f2fe 30% 40%, #1e3a8a 40% 60%, #e0f2fe 60% 70%, #0ea5e9 70% 82%, #06111f 82% 100%); }
.hub-page .pd-ribbon--naval-harbour { --ribbon-bg: linear-gradient(90deg, #0f172a 0 16%, #14b8a6 16% 28%, #f59e0b 28% 40%, #334155 40% 60%, #f59e0b 60% 72%, #14b8a6 72% 84%, #0f172a 84% 100%); }
.hub-page .pd-ribbon--naval-convoy { --ribbon-bg: linear-gradient(90deg, #082f49 0 17%, #38bdf8 17% 29%, #f8fafc 29% 41%, #f97316 41% 59%, #f8fafc 59% 71%, #38bdf8 71% 83%, #082f49 83% 100%); }
.hub-page .pd-ribbon--naval-silent-wake { --ribbon-bg: linear-gradient(90deg, #020617 0 20%, #22c55e 20% 30%, #67e8f9 30% 42%, #020617 42% 58%, #67e8f9 58% 70%, #22c55e 70% 80%, #020617 80% 100%); }
.hub-page .pd-ribbon--naval-grey-horizon { --ribbon-bg: linear-gradient(90deg, #111827 0 16%, #94a3b8 16% 32%, #e5e7eb 32% 44%, #1d4ed8 44% 56%, #e5e7eb 56% 68%, #94a3b8 68% 84%, #111827 84% 100%); }
.hub-page .pd-ribbon--naval-iron-horizon { --ribbon-bg: linear-gradient(90deg, #1f2937 0 15%, #64748b 15% 28%, #fbbf24 28% 42%, #0f172a 42% 58%, #fbbf24 58% 72%, #64748b 72% 85%, #1f2937 85% 100%); }
.hub-page .pd-ribbon--naval-wolfpack { --ribbon-bg: linear-gradient(90deg, #030712 0 14%, #ef4444 14% 26%, #cbd5e1 26% 38%, #1e3a8a 38% 62%, #cbd5e1 62% 74%, #ef4444 74% 86%, #030712 86% 100%); }
.hub-page .pd-ribbon--naval-bronze-command { --ribbon-bg: linear-gradient(90deg, #082f49 0 14%, #92400e 14% 28%, #fef3c7 28% 42%, #020617 42% 58%, #fef3c7 58% 72%, #92400e 72% 86%, #082f49 86% 100%); }
.hub-page .pd-ribbon--naval-deep-command { --ribbon-bg: linear-gradient(90deg, #020617 0 14%, #0891b2 14% 28%, #a78bfa 28% 42%, #e0f2fe 42% 58%, #a78bfa 58% 72%, #0891b2 72% 86%, #020617 86% 100%); }
.hub-page .pd-ribbon--naval-silver-command { --ribbon-bg: linear-gradient(90deg, #030712 0 14%, #e5e7eb 14% 26%, #38bdf8 26% 38%, #facc15 38% 62%, #38bdf8 62% 74%, #e5e7eb 74% 86%, #030712 86% 100%); }
.hub-page .pd-ribbon--naval-vanguard { --ribbon-bg: linear-gradient(90deg, #172554 0 12%, #2563eb 12% 24%, #fbbf24 24% 36%, #f8fafc 36% 50%, #020617 50% 64%, #f8fafc 64% 76%, #fbbf24 76% 88%, #172554 88% 100%); }
.hub-page .pd-ribbon--naval-admiralty { --ribbon-bg: linear-gradient(90deg, #020617 0 12%, #b91c1c 12% 22%, #facc15 22% 34%, #f8fafc 34% 46%, #1d4ed8 46% 54%, #f8fafc 54% 66%, #facc15 66% 78%, #b91c1c 78% 88%, #020617 88% 100%); }

.hub-page .pd-ribbon--naval-citation-deployment { --ribbon-bg: linear-gradient(90deg, #0f172a 0 16%, #38bdf8 16% 30%, #f8fafc 30% 44%, #2563eb 44% 56%, #f8fafc 56% 70%, #38bdf8 70% 84%, #0f172a 84% 100%); }
.hub-page .pd-ribbon--naval-citation-gunnery { --ribbon-bg: linear-gradient(90deg, #111827 0 14%, #f97316 14% 28%, #fbbf24 28% 42%, #020617 42% 58%, #fbbf24 58% 72%, #f97316 72% 86%, #111827 86% 100%); }
.hub-page .pd-ribbon--naval-citation-strike { --ribbon-bg: linear-gradient(90deg, #030712 0 14%, #ef4444 14% 28%, #f8fafc 28% 40%, #0ea5e9 40% 60%, #f8fafc 60% 72%, #ef4444 72% 86%, #030712 86% 100%); }
.hub-page .pd-ribbon--naval-citation-preservation { --ribbon-bg: linear-gradient(90deg, #052e16 0 15%, #22c55e 15% 30%, #d1fae5 30% 42%, #0f172a 42% 58%, #d1fae5 58% 70%, #22c55e 70% 85%, #052e16 85% 100%); }
.hub-page .pd-ribbon--naval-citation-accuracy { --ribbon-bg: linear-gradient(90deg, #172554 0 14%, #93c5fd 14% 28%, #e0f2fe 28% 40%, #facc15 40% 60%, #e0f2fe 60% 72%, #93c5fd 72% 86%, #172554 86% 100%); }
.hub-page .pd-ribbon--naval-citation-decisive { --ribbon-bg: linear-gradient(90deg, #020617 0 12%, #7c3aed 12% 26%, #67e8f9 26% 38%, #f8fafc 38% 62%, #67e8f9 62% 74%, #7c3aed 74% 88%, #020617 88% 100%); }
.hub-page .pd-ribbon--naval-citation-streak { --ribbon-bg: linear-gradient(90deg, #0f172a 0 14%, #22d3ee 14% 26%, #2563eb 26% 38%, #f8fafc 38% 50%, #2563eb 50% 62%, #22d3ee 62% 74%, #0f172a 74% 100%); }
.hub-page .pd-ribbon--naval-citation-rapid { --ribbon-bg: linear-gradient(90deg, #020617 0 14%, #fde047 14% 26%, #fb7185 26% 38%, #f8fafc 38% 50%, #fb7185 50% 62%, #fde047 62% 74%, #020617 74% 100%); }

@media (max-width: 1050px) {
  .hub-page .service-ribbon-mini {
    max-width: 680px;
  }
}

@media (max-width: 650px) {
  .hub-page .service-ribbon-mini__top {
    align-items: start;
    flex-direction: column;
    gap: 0.25rem;
  }
}

/* =============================================================================
   End Project PlayDeck hero service ribbon mini rack
   ============================================================================= */

/* =============================================================================
   Project PlayDeck hero service ribbon pager
   Compact pager below the right-column hero ribbon rack.
   ============================================================================= */

.hub-page .service-ribbon-mini__pager {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.35rem;
  padding-top: 0.15rem;
}

.hub-page .service-ribbon-mini__page {
  appearance: none;
  min-height: 1.65rem;
  padding: 0.22rem 0.52rem;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.055), rgba(0,0,0,0.08)),
    var(--panel);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 999px;
  color: var(--muted);
  cursor: pointer;
  font: inherit;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  line-height: 1;
  text-transform: uppercase;
}

.hub-page .service-ribbon-mini__page:hover,
.hub-page .service-ribbon-mini__page:focus-visible {
  border-color: rgba(124,58,237,0.42);
  color: var(--text);
  outline: none;
  box-shadow: var(--ring);
}

.hub-page .service-ribbon-mini__page.is-active {
  background:
    linear-gradient(135deg, rgba(96,165,250,0.2), rgba(124,58,237,0.18)),
    var(--panel);
  border-color: rgba(96,165,250,0.44);
  color: var(--text);
}

/* =============================================================================
   End Project PlayDeck hero service ribbon pager
   ============================================================================= */

/* =============================================================================
   Project PlayDeck subtle service ribbon pager
   Replaces labelled page pills with compact dots under the hero ribbon rack.
   ============================================================================= */

.hub-page .service-ribbon-mini__pager--dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.42rem;
  min-height: 1.1rem;
  padding-top: 0.12rem;
}

.hub-page .service-ribbon-mini__dot {
  appearance: none;
  inline-size: 0.58rem;
  block-size: 0.58rem;
  min-inline-size: 0;
  min-block-size: 0;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--muted) 42%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--muted) 20%, transparent);
  cursor: pointer;
  opacity: 0.72;
  transition:
    opacity 0.14s ease,
    transform 0.14s ease,
    background 0.14s ease,
    border-color 0.14s ease,
    box-shadow 0.14s ease;
}

.hub-page .service-ribbon-mini__dot:hover,
.hub-page .service-ribbon-mini__dot:focus-visible {
  opacity: 1;
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--primary) 68%, transparent);
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 20%, transparent);
}

.hub-page .service-ribbon-mini__dot.is-active,
.hub-page .service-ribbon-mini__dot[aria-pressed="true"] {
  inline-size: 1.15rem;
  background: linear-gradient(90deg, var(--primary), var(--accent));
  border-color: color-mix(in srgb, var(--primary) 76%, transparent);
  opacity: 1;
}

/* Neutralise the old labelled pill style if the old class remains anywhere. */
.hub-page .service-ribbon-mini__pager--dots .service-ribbon-mini__page {
  inline-size: 0.58rem;
  block-size: 0.58rem;
  min-height: 0;
  padding: 0;
  overflow: hidden;
  color: transparent;
  text-indent: -999px;
  border-radius: 999px;
}

/* Keep the rack compact when more games are added. */
.hub-page .service-ribbon-mini__pager--dots .service-ribbon-mini__dot:nth-child(n + 7) {
  inline-size: 0.5rem;
  block-size: 0.5rem;
}

@media (prefers-reduced-motion: reduce) {
  .hub-page .service-ribbon-mini__dot {
    transition: none;
  }

  .hub-page .service-ribbon-mini__dot:hover,
  .hub-page .service-ribbon-mini__dot:focus-visible {
    transform: none;
  }
}

/* =============================================================================
   End Project PlayDeck subtle service ribbon pager
   ============================================================================= */

/* =============================================================================
   Project PlayDeck ribbon row precedence
   Incomplete ribbon row sits at the top; full rows stack underneath.
   ============================================================================= */

.hub-page .service-ribbon-mini__rack {
  display: grid;
  justify-items: center;
  gap: 0.16rem;
}

.hub-page .service-ribbon-mini__row {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 0.18rem 0.22rem;
  max-inline-size: 100%;
}

.hub-page .service-ribbon-mini__row .pd-ribbon-link {
  flex: 0 0 auto;
}

/* Keep the rack compact and balanced under the stat boxes. */
.hub-page .service-ribbon-mini {
  align-self: start;
}

/* =============================================================================
   End Project PlayDeck ribbon row precedence
   ============================================================================= */

/* =============================================================================
   Project PlayDeck ribbon row display repair
   Full rows sit underneath; incomplete row sits at the top.
   ============================================================================= */

.hub-page .service-ribbon-mini__rack {
  display: grid;
  justify-items: center;
  align-items: start;
  gap: 0.16rem;
}

.hub-page .service-ribbon-mini__row {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 0.18rem 0.22rem;
  max-inline-size: 100%;
}

.hub-page .service-ribbon-mini__row .pd-ribbon-link {
  flex: 0 0 auto;
}

/* =============================================================================
   End Project PlayDeck ribbon row display repair
   ============================================================================= */

/* =============================================================================
   Project PlayDeck hero ribbon row repair v2
   Incomplete top row; full rows underneath.
   ============================================================================= */

.hub-page .service-ribbon-mini__rack {
  display: grid;
  justify-items: center;
  align-items: start;
  gap: 0.16rem;
}

.hub-page .service-ribbon-mini__row {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 0.18rem 0.22rem;
  max-inline-size: 100%;
}

.hub-page .service-ribbon-mini__row .pd-ribbon-link {
  flex: 0 0 auto;
}

.hub-page .service-ribbon-mini,
.hub-page .service-ribbon-mini__rack,
.hub-page .service-ribbon-mini__row {
  overflow: visible;
}

/* =============================================================================
   End Project PlayDeck hero ribbon row repair v2
   ============================================================================= */

/* =============================================================================
   Project PlayDeck service ribbon CLS lock
   Reserve a stable two-row rack so earned awards do not shift the hero panel.
   ============================================================================= */

.hub-page .service-ribbon-mini {
  --service-ribbon-row-h: 1rem;
  --service-ribbon-row-gap: 0.16rem;
  --service-ribbon-rack-h: calc((var(--service-ribbon-row-h) * 2) + var(--service-ribbon-row-gap));

  align-content: start;
  min-block-size: 8.6rem;
}

.hub-page .service-ribbon-mini__rack {
  min-block-size: var(--service-ribbon-rack-h);
  align-content: start;
}

.hub-page .service-ribbon-mini__empty {
  min-block-size: 2.15rem;
  display: grid;
  place-items: center;
}

.hub-page .service-ribbon-mini__dotr,
.hub-page .service-ribbon-mini__pager,
.hub-page .service-ribbon-mini__pager--dots {
  min-block-size: 1.1rem;
}

@media (max-width: 650px) {
  .hub-page .service-ribbon-mini {
    min-block-size: 9.35rem;
  }
}

/* =============================================================================
   End Project PlayDeck service ribbon CLS lock
   ============================================================================= */

/* =============================================================================
   Project PlayDeck Privacy & Legal page refinement
   Brings the legal page in line with the hub/game visual language.
   ============================================================================= */

body.legal-page {
  background:
    radial-gradient(900px 520px at 12% -10%, var(--accent-glow), transparent 62%),
    radial-gradient(840px 560px at 100% 4%, var(--primary-glow), transparent 64%),
    radial-gradient(700px 520px at 50% 110%, color-mix(in srgb, var(--primary) 5%, transparent), transparent 68%),
    var(--bg);
  background-attachment: fixed;
}

.legal-layout--playdeck {
  display: grid;
  gap: clamp(1rem, 2.5vw, 1.5rem);
  width: min(1180px, 100%);
  max-width: none;
  margin-inline: auto;
  padding: 0 clamp(0.85rem, 3vw, 2rem) clamp(2rem, 4vw, 3rem);
}

.legal-hero {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(260px, 0.75fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: stretch;
  padding: clamp(1.2rem, 3.6vw, 2.4rem);
  background:
    radial-gradient(600px 360px at 100% 0%, var(--primary-glow), transparent 68%),
    radial-gradient(520px 340px at 0% 100%, var(--accent-glow), transparent 70%),
    var(--panel);
  border: 1px solid var(--border);
  border-radius: 1.35rem;
  box-shadow: 0 18px 50px rgba(0,0,0,.12);
}

.legal-hero::before {
  content: "";
  position: absolute;
  inset: auto -10% -45% 42%;
  block-size: 70%;
  background:
    radial-gradient(circle, color-mix(in srgb, var(--primary) 12%, transparent), transparent 64%);
  pointer-events: none;
}

.legal-hero__copy {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: 0.9rem;
}

.legal-hero h1 {
  max-width: 12ch;
  margin: 0;
  color: var(--text);
  font-size: clamp(2rem, 5vw, 4rem);
  line-height: 1.02;
  letter-spacing: -0.045em;
  -webkit-text-fill-color: currentColor;
  background: none;
}

.legal-hero__copy > p:not(.section-kicker) {
  max-width: 66ch;
  margin: 0;
  color: var(--muted);
  font-size: clamp(1rem, 1.8vw, 1.12rem);
}

.legal-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 0.2rem;
}

.legal-summary {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.65rem;
}

.legal-summary__item {
  display: grid;
  gap: 0.35rem;
  align-content: center;
  min-height: 100px;
  padding: 0.95rem;
  background:
    linear-gradient(155deg, color-mix(in srgb, var(--primary) 7%, transparent), transparent 58%),
    var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 1rem;
}

.legal-summary__item strong {
  color: var(--text);
  font-size: clamp(1rem, 2vw, 1.18rem);
  line-height: 1.15;
}

.legal-summary__item span {
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1.35;
}

.legal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.85rem, 2vw, 1rem);
}

.legal-layout--playdeck .legal-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.85rem;
  margin: 0;
  padding: 1rem;
  background:
    var(--card-wash),
    var(--panel);
  border: 1px solid var(--border);
  border-left: 0;
  border-radius: 1rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}

.legal-layout--playdeck .legal-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  inline-size: 4px;
  background: linear-gradient(180deg, var(--primary), var(--accent));
}

.legal-card__icon {
  display: grid;
  place-items: center;
  inline-size: 2.35rem;
  block-size: 2.35rem;
  margin-top: 0.1rem;
  color: var(--text);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--primary) 16%, transparent), color-mix(in srgb, var(--accent) 13%, transparent)),
    var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  font-size: 1rem;
  font-weight: 950;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}

.legal-card__content {
  display: grid;
  gap: 0.65rem;
  min-width: 0;
}

.legal-layout--playdeck .legal-card h2 {
  margin: 0;
  color: var(--text);
  font-size: 1.05rem;
  font-weight: 900;
  line-height: 1.18;
  letter-spacing: -0.015em;
  -webkit-text-fill-color: currentColor;
  background: none;
}

.legal-layout--playdeck .legal-card p {
  margin: 0;
  color: color-mix(in srgb, var(--text) 78%, var(--muted));
  line-height: 1.58;
}

.legal-layout--playdeck .legal-card ul {
  display: grid;
  gap: 0.42rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.legal-layout--playdeck .legal-card li {
  position: relative;
  margin: 0;
  padding-inline-start: 1.05rem;
  color: var(--muted);
  line-height: 1.45;
}

.legal-layout--playdeck .legal-card li::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  inset-block-start: 0.62em;
  inline-size: 0.42rem;
  block-size: 0.42rem;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  border-radius: 999px;
  transform: translateY(-50%);
}

.legal-layout--playdeck code {
  padding: 0.08rem 0.32rem;
  color: var(--text);
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 0.35rem;
  font-size: 0.9em;
}

.legal-card--privacy::before { background: linear-gradient(180deg, var(--ok), var(--primary)); }
.legal-card--disclaimer::before { background: linear-gradient(180deg, var(--warn), var(--danger)); }
.legal-card--ip::before { background: linear-gradient(180deg, var(--primary), var(--accent)); }
.legal-card--credits::before { background: linear-gradient(180deg, var(--accent), var(--primary)); }
.legal-card--law::before { background: linear-gradient(180deg, var(--warn), var(--accent)); }
.legal-card--contact::before { background: linear-gradient(180deg, var(--ok), var(--accent)); }

.legal-card--privacy,
.legal-card--disclaimer {
  min-height: 100%;
}

@media (max-width: 900px) {
  .legal-hero {
    grid-template-columns: 1fr;
  }

  .legal-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .legal-grid {
    grid-template-columns: 1fr;
  }

  .legal-hero h1 {
    max-width: none;
  }
}

@media (max-width: 650px) {
  .legal-layout--playdeck {
    padding-inline: 0.75rem;
  }

  .legal-hero {
    padding: 1.1rem;
    border-radius: 1rem;
  }

  .legal-summary {
    grid-template-columns: 1fr;
  }

  .legal-layout--playdeck .legal-card {
    grid-template-columns: 1fr;
    padding: 0.9rem;
  }

  .legal-card__icon {
    inline-size: 2.1rem;
    block-size: 2.1rem;
  }

  .legal-hero__actions .btn {
    justify-content: center;
    width: 100%;
  }
}

/* =============================================================================
   End Project PlayDeck Privacy & Legal page refinement
   ============================================================================= */

/* =============================================================================
   Project PlayDeck Privacy & Legal page — forced refinement
   Scoped to body.legal-page so hub/game pages are unaffected.
   ============================================================================= */

body.legal-page {
  background:
    radial-gradient(900px 520px at 12% -10%, var(--accent-glow), transparent 62%),
    radial-gradient(840px 560px at 100% 4%, var(--primary-glow), transparent 64%),
    radial-gradient(700px 520px at 50% 110%, color-mix(in srgb, var(--primary) 5%, transparent), transparent 68%),
    var(--bg);
  background-attachment: fixed;
}

body.legal-page .legal-layout--playdeck {
  display: grid;
  gap: clamp(1rem, 2.5vw, 1.5rem);
  width: min(1180px, 100%);
  max-width: none;
  margin-inline: auto;
  padding: 0 clamp(0.85rem, 3vw, 2rem) clamp(2rem, 4vw, 3rem);
}

body.legal-page .legal-hero {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(260px, 0.75fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: stretch;
  padding: clamp(1.2rem, 3.6vw, 2.4rem);
  background:
    radial-gradient(600px 360px at 100% 0%, var(--primary-glow), transparent 68%),
    radial-gradient(520px 340px at 0% 100%, var(--accent-glow), transparent 70%),
    var(--panel);
  border: 1px solid var(--border);
  border-radius: 1.35rem;
  box-shadow: 0 18px 50px rgba(0,0,0,.12);
}

body.legal-page .legal-hero__copy {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: 0.9rem;
}

body.legal-page .legal-hero h1 {
  max-width: 12ch;
  margin: 0;
  color: var(--text);
  background: none;
  font-size: clamp(2rem, 5vw, 4rem);
  line-height: 1.02;
  letter-spacing: -0.045em;
  -webkit-text-fill-color: currentColor;
}

body.legal-page .legal-hero__copy > p:not(.section-kicker) {
  max-width: 66ch;
  margin: 0;
  color: var(--muted);
  font-size: clamp(1rem, 1.8vw, 1.12rem);
}

body.legal-page .legal-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 0.2rem;
}

body.legal-page .legal-summary {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.65rem;
}

body.legal-page .legal-summary__item {
  display: grid;
  gap: 0.35rem;
  align-content: center;
  min-height: 100px;
  padding: 0.95rem;
  background:
    linear-gradient(155deg, color-mix(in srgb, var(--primary) 7%, transparent), transparent 58%),
    var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 1rem;
}

body.legal-page .legal-summary__item strong {
  color: var(--text);
  font-size: clamp(1rem, 2vw, 1.18rem);
  line-height: 1.15;
}

body.legal-page .legal-summary__item span {
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1.35;
}

body.legal-page .legal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.85rem, 2vw, 1rem);
}

body.legal-page .legal-layout--playdeck .legal-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.85rem;
  margin: 0;
  padding: 1rem;
  background:
    var(--card-wash),
    var(--panel);
  border: 1px solid var(--border);
  border-left: 0;
  border-radius: 1rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}

body.legal-page .legal-layout--playdeck .legal-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  inline-size: 4px;
  background: linear-gradient(180deg, var(--primary), var(--accent));
}

body.legal-page .legal-card__icon {
  display: grid;
  place-items: center;
  inline-size: 2.35rem;
  block-size: 2.35rem;
  margin-top: 0.1rem;
  color: var(--text);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--primary) 16%, transparent), color-mix(in srgb, var(--accent) 13%, transparent)),
    var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  font-size: 1rem;
  font-weight: 950;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}

body.legal-page .legal-card__content {
  display: grid;
  gap: 0.65rem;
  min-width: 0;
}

body.legal-page .legal-layout--playdeck .legal-card h2 {
  margin: 0;
  color: var(--text);
  background: none;
  font-size: 1.05rem;
  font-weight: 900;
  line-height: 1.18;
  letter-spacing: -0.015em;
  -webkit-text-fill-color: currentColor;
}

body.legal-page .legal-layout--playdeck .legal-card p {
  margin: 0;
  color: color-mix(in srgb, var(--text) 78%, var(--muted));
  line-height: 1.58;
}

body.legal-page .legal-layout--playdeck .legal-card ul {
  display: grid;
  gap: 0.42rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

body.legal-page .legal-layout--playdeck .legal-card li {
  position: relative;
  margin: 0;
  padding-inline-start: 1.05rem;
  color: var(--muted);
  line-height: 1.45;
}

body.legal-page .legal-layout--playdeck .legal-card li::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  inset-block-start: 0.62em;
  inline-size: 0.42rem;
  block-size: 0.42rem;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  border-radius: 999px;
  transform: translateY(-50%);
}

body.legal-page .legal-layout--playdeck code {
  padding: 0.08rem 0.32rem;
  color: var(--text);
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 0.35rem;
  font-size: 0.9em;
}

body.legal-page .legal-card--privacy::before { background: linear-gradient(180deg, var(--ok), var(--primary)); }
body.legal-page .legal-card--disclaimer::before { background: linear-gradient(180deg, var(--warn), var(--danger)); }
body.legal-page .legal-card--ip::before { background: linear-gradient(180deg, var(--primary), var(--accent)); }
body.legal-page .legal-card--credits::before { background: linear-gradient(180deg, var(--accent), var(--primary)); }
body.legal-page .legal-card--law::before { background: linear-gradient(180deg, var(--warn), var(--accent)); }
body.legal-page .legal-card--contact::before { background: linear-gradient(180deg, var(--ok), var(--accent)); }

@media (max-width: 900px) {
  body.legal-page .legal-hero {
    grid-template-columns: 1fr;
  }

  body.legal-page .legal-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.legal-page .legal-grid {
    grid-template-columns: 1fr;
  }

  body.legal-page .legal-hero h1 {
    max-width: none;
  }
}

@media (max-width: 650px) {
  body.legal-page .legal-layout--playdeck {
    padding-inline: 0.75rem;
  }

  body.legal-page .legal-hero {
    padding: 1.1rem;
    border-radius: 1rem;
  }

  body.legal-page .legal-summary {
    grid-template-columns: 1fr;
  }

  body.legal-page .legal-layout--playdeck .legal-card {
    grid-template-columns: 1fr;
    padding: 0.9rem;
  }

  body.legal-page .legal-card__icon {
    inline-size: 2.1rem;
    block-size: 2.1rem;
  }

  body.legal-page .legal-hero__actions .btn {
    justify-content: center;
    width: 100%;
  }
}

/* =============================================================================
   End Project PlayDeck Privacy & Legal page — forced refinement
   ============================================================================= */

/* =============================================================================
   Project PlayDeck Privacy header alignment
   Brings Privacy & Legal header into line with the hub/game page standard.
   ============================================================================= */

body.legal-page .app-header.hub-header {
  width: min(1440px, 100%);
  margin-inline: auto;
  margin-bottom: 1rem;
  padding-block: 0.85rem;
}

body.legal-page .brand-link > span:not(.app-header__mark) {
  display: grid;
  gap: 0.18rem;
}

body.legal-page .brand-subtitle {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
}

body.legal-page .game-title {
  color: var(--muted);
  font-size: 1.13rem;
  font-weight: 800;
}

body.legal-page .hub-controls {
  justify-content: flex-end;
}

body.legal-page .hub-controls .btn {
  white-space: nowrap;
}

@media (max-width: 650px) {
  body.legal-page .app-header.hub-header {
    padding-inline: 0.75rem;
  }

  body.legal-page .hub-controls {
    justify-content: flex-start;
    width: 100%;
  }

  body.legal-page .hub-controls .btn {
    flex: 1 1 auto;
    justify-content: center;
  }
}

/* =============================================================================
   End Project PlayDeck Privacy header alignment
   ============================================================================= */

/* =============================================================================
   Project PlayDeck Privacy options alignment
   Uses the same Options dialog design language as the hub.
   ============================================================================= */

body.legal-page .hub-options {
  width: min(760px, calc(100vw - 2rem));
  max-height: min(760px, calc(100dvh - 2rem));
}

body.legal-page .legal-options .personalisation-panel {
  grid-template-columns: 1fr;
  gap: 1rem;
  padding: 0;
  background: transparent;
  border: 0;
}

body.legal-page .legal-options .personalisation-copy {
  display: none;
}

body.legal-page .legal-options .mode-switcher,
body.legal-page .legal-options .skin-switcher {
  padding: .85rem;
  background: color-mix(in srgb, var(--surface-soft) 72%, transparent);
  border: 1px solid var(--border);
  border-radius: .9rem;
}

body.legal-page .legal-options .skin-switcher {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.legal-page .legal-options .skin-switcher legend {
  grid-column: 1 / -1;
}

body.legal-page .legal-options .personalisation-privacy {
  margin-top: 0;
}

body.legal-page .hub-controls {
  justify-content: flex-end;
}

body.legal-page .hub-options-btn {
  min-width: 6.75rem;
  justify-content: center;
}

@media (max-width: 650px) {
  body.legal-page .hub-options {
    width: min(100vw - 1rem, 680px);
    max-height: calc(100dvh - 1rem);
  }

  body.legal-page .legal-options .skin-switcher {
    grid-template-columns: 1fr;
  }

  body.legal-page .hub-controls {
    justify-content: stretch;
    width: 100%;
  }

  body.legal-page .hub-controls .btn {
    flex: 1 1 auto;
    justify-content: center;
  }
}

/* =============================================================================
   End Project PlayDeck Privacy options alignment
   ============================================================================= */

/* =============================================================================
   Project PlayDeck Privacy options open fix
   Robust fallback for the Privacy & Legal Options dialog.
   ============================================================================= */

body.legal-page .hub-options {
  width: min(760px, calc(100vw - 2rem));
  max-height: min(760px, calc(100dvh - 2rem));
  padding: 0;
  overflow: auto;
  color: var(--text);
  background:
    radial-gradient(520px 260px at 12% 0%, var(--primary-glow, rgba(96,165,250,.15)), transparent 62%),
    linear-gradient(180deg, color-mix(in srgb, var(--panel) 96%, var(--surface, var(--panel))), var(--panel));
  border: 1px solid var(--border, rgba(255,255,255,.10));
  border-radius: 1rem;
  box-shadow: 0 28px 90px rgba(0,0,0,.42);
}

body.legal-page .hub-options::backdrop {
  background:
    radial-gradient(900px 520px at 50% 10%, color-mix(in srgb, var(--primary) 14%, transparent), transparent 62%),
    rgba(0,0,0,.62);
  backdrop-filter: blur(5px);
}

body.legal-page .hub-options__header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1rem .85rem;
  border-bottom: 1px solid var(--border, rgba(255,255,255,.10));
}

body.legal-page .hub-options__header h2,
body.legal-page .hub-options__header p {
  margin: 0;
}

body.legal-page .hub-options__header h2 {
  font-size: 1.24rem;
  line-height: 1.1;
}

body.legal-page .hub-options__header p:last-child {
  margin-top: .35rem;
  color: var(--muted);
  font-size: .88rem;
}

body.legal-page .hub-options__body {
  display: grid;
  gap: 1rem;
  padding: 1rem;
}

body.legal-page .legal-options .personalisation-panel {
  grid-template-columns: 1fr;
  gap: 1rem;
  padding: 0;
  background: transparent;
  border: 0;
}

body.legal-page .legal-options .personalisation-copy {
  display: none;
}

body.legal-page .legal-options .mode-switcher,
body.legal-page .legal-options .skin-switcher {
  padding: .85rem;
  background: color-mix(in srgb, var(--surface-soft, rgba(255,255,255,.035)) 72%, transparent);
  border: 1px solid var(--border, rgba(255,255,255,.10));
  border-radius: .9rem;
}

body.legal-page .legal-options .skin-switcher {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.legal-page .legal-options .skin-switcher legend {
  grid-column: 1 / -1;
}

body.legal-page .hub-options-btn {
  min-width: 6.75rem;
  justify-content: center;
}

@media (max-width: 650px) {
  body.legal-page .hub-options {
    width: min(100vw - 1rem, 680px);
    max-height: calc(100dvh - 1rem);
  }

  body.legal-page .hub-options__header {
    flex-direction: column;
  }

  body.legal-page .hub-options__close {
    width: 100%;
    justify-content: center;
  }

  body.legal-page .legal-options .skin-switcher {
    grid-template-columns: 1fr;
  }
}

/* =============================================================================
   End Project PlayDeck Privacy options open fix
   ============================================================================= */

/* =============================================================================
   Project PlayDeck Privacy content and delete controls
   ============================================================================= */

body.legal-page .legal-hero__meta {
  display: inline-flex;
  width: fit-content;
  margin: 0;
  padding: 0.42rem 0.62rem;
  color: var(--muted);
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 0.84rem;
  font-weight: 800;
}

body.legal-page .legal-hero__meta strong {
  color: var(--text);
}

body.legal-page .legal-card--operator::before { background: linear-gradient(180deg, var(--primary), var(--ok)); }
body.legal-page .legal-card--local-storage::before { background: linear-gradient(180deg, var(--primary), var(--accent)); }
body.legal-page .legal-card--cookies::before { background: linear-gradient(180deg, var(--warn), var(--primary)); }
body.legal-page .legal-card--children::before { background: linear-gradient(180deg, var(--ok), var(--accent)); }
body.legal-page .legal-card--external::before { background: linear-gradient(180deg, var(--accent), var(--primary)); }
body.legal-page .legal-card--accessibility::before { background: linear-gradient(180deg, var(--ok), var(--primary)); }
body.legal-page .legal-card--removal::before { background: linear-gradient(180deg, var(--warn), var(--accent)); }
body.legal-page .legal-card--data-loss::before { background: linear-gradient(180deg, var(--danger), var(--warn)); }
body.legal-page .legal-card--open-source::before { background: linear-gradient(180deg, var(--primary), var(--muted)); }
body.legal-page .legal-card--danger-zone::before { background: linear-gradient(180deg, var(--danger), var(--warn)); }

body.legal-page .danger-btn {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--danger) 24%, transparent), color-mix(in srgb, var(--warn) 13%, transparent)),
    var(--panel);
  border-color: color-mix(in srgb, var(--danger) 52%, var(--border));
  color: var(--text);
}

body.legal-page .danger-btn:hover,
body.legal-page .danger-btn:focus-visible {
  border-color: color-mix(in srgb, var(--danger) 78%, var(--border));
  color: var(--text);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--danger) 24%, transparent);
}

body.legal-page .legal-danger-dialog {
  width: min(620px, calc(100vw - 2rem));
}

body.legal-page .legal-warning-panel {
  display: grid;
  gap: 0.45rem;
  padding: 1rem;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--warn) 12%, transparent), transparent 58%),
    var(--surface-soft);
  border: 1px solid color-mix(in srgb, var(--warn) 42%, var(--border));
  border-radius: 0.9rem;
}

body.legal-page .legal-warning-panel strong {
  color: var(--text);
  font-size: 1rem;
}

body.legal-page .legal-warning-panel p {
  margin: 0;
  color: var(--muted);
}

body.legal-page .legal-warning-panel--danger {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--danger) 14%, transparent), transparent 58%),
    var(--surface-soft);
  border-color: color-mix(in srgb, var(--danger) 48%, var(--border));
}

body.legal-page .legal-dialog-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.65rem;
}

body.legal-page .legal-dialog-actions .btn {
  min-width: 11rem;
  justify-content: center;
}

@media (max-width: 650px) {
  body.legal-page .legal-dialog-actions {
    flex-direction: column;
  }

  body.legal-page .legal-dialog-actions .btn {
    width: 100%;
  }
}

/* =============================================================================
   End Project PlayDeck Privacy content and delete controls
   ============================================================================= */


/* =============================================================================
   Hub Memory achievement badge page
   - Adds Memory badge icons as a third page in the service ribbon rack.
   ============================================================================= */

.hub-page .service-ribbon-mini__row--memory {
  gap: 0.28rem;
  align-items: center;
  justify-content: center;
}

.hub-page .pd-memory-badge-link {
  inline-size: 1.8rem;
  block-size: 1.8rem;
  border-radius: 0.45rem;
}

.hub-page .pd-memory-badge {
  display: grid;
  place-items: center;
  inline-size: 1.8rem;
  block-size: 1.8rem;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 0.45rem;
  background:
    radial-gradient(circle at 50% 35%, rgba(255,255,255,0.08), transparent 62%),
    rgba(255,255,255,0.025);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.09),
    0 0.25rem 0.65rem rgba(0,0,0,0.16);
}

.hub-page .pd-memory-badge img {
  display: block;
  inline-size: 2rem;
  block-size: 2rem;
  max-inline-size: none;
  object-fit: contain;
  filter: drop-shadow(0 0.16rem 0.22rem rgba(0,0,0,0.34));
}

.hub-page .pd-memory-badge--proven {
  border-color: rgba(52,211,153,.28);
}

.hub-page .pd-memory-badge--distinguished {
  border-color: rgba(96,165,250,.30);
}

.hub-page .pd-memory-badge--elite {
  border-color: rgba(167,139,250,.32);
}

.hub-page .pd-memory-badge--legendary {
  border-color: rgba(250,204,21,.38);
}

@media (max-width: 520px) {
  .hub-page .pd-memory-badge-link,
  .hub-page .pd-memory-badge {
    inline-size: 1.65rem;
    block-size: 1.65rem;
  }

  .hub-page .pd-memory-badge img {
    inline-size: 1.86rem;
    block-size: 1.86rem;
  }
}



/* =============================================================================
   Hub service rack: compact ribbons + large Memory badges
   ============================================================================= */

/* Keep the whole rack height stable to prevent CLS */
.hub-page #serviceRibbonRack,
#serviceRibbonRack {
  min-block-size: 6.1rem !important;
  align-content: center !important;
}

/* Undo the earlier row-height rule for normal ribbon rows */
.hub-page .service-ribbon-mini__row,
.service-ribbon-mini__row {
  min-block-size: auto !important;
  margin-block: 0 !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Normal ribbon rows: compact again */
.hub-page .service-ribbon-mini__row:not(.service-ribbon-mini__row--memory),
.service-ribbon-mini__row:not(.service-ribbon-mini__row--memory) {
  gap: 0.12rem !important;
  row-gap: 0 !important;
}

/* Memory badge rows: keep the larger badge-friendly spacing */
.hub-page .service-ribbon-mini__row--memory,
.service-ribbon-mini__row--memory {
  min-block-size: 2.65rem !important;
  gap: 0.42rem !important;
}

/* Keep the larger Memory badge size */
.hub-page .pd-memory-badge-link,
.pd-memory-badge-link,
.hub-page .pd-memory-badge,
.pd-memory-badge {
  inline-size: 2.35rem !important;
  block-size: 2.35rem !important;
}

.hub-page .pd-memory-badge img,
.pd-memory-badge img {
  inline-size: 2.7rem !important;
  block-size: 2.7rem !important;
  max-inline-size: none !important;
  object-fit: contain !important;
}

@media (max-width: 520px) {
  .hub-page #serviceRibbonRack,
  #serviceRibbonRack {
    min-block-size: 5.55rem !important;
  }

  .hub-page .service-ribbon-mini__row,
  .service-ribbon-mini__row {
    min-block-size: auto !important;
    margin-block: 0 !important;
  }

  .hub-page .service-ribbon-mini__row--memory,
  .service-ribbon-mini__row--memory {
    min-block-size: 2.42rem !important;
    gap: 0.32rem !important;
  }

  .hub-page .pd-memory-badge-link,
  .pd-memory-badge-link,
  .hub-page .pd-memory-badge,
  .pd-memory-badge {
    inline-size: 2.12rem !important;
    block-size: 2.12rem !important;
  }

  .hub-page .pd-memory-badge img,
  .pd-memory-badge img {
    inline-size: 2.42rem !important;
    block-size: 2.42rem !important;
  }
}



/* =============================================================================
   Hub Memory marks/badge section: hard centre alignment
   ============================================================================= */

/* Centre the whole rack content */
#serviceRibbonRack {
  display: grid !important;
  justify-items: center !important;
  align-items: center !important;
}

/* Centre Memory badge rows regardless of earlier row/grid rules */
#serviceRibbonRack .service-ribbon-mini__row--memory,
.service-ribbon-mini__row--memory {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: center !important;

  width: 100% !important;
  max-width: 100% !important;
  margin-inline: auto !important;
  padding-inline: 0 !important;

  text-align: center !important;
}

/* Ensure each Memory badge item does not create left-biased spacing */
#serviceRibbonRack .pd-memory-badge-link,
.pd-memory-badge-link {
  flex: 0 0 auto !important;
  margin-inline: 0 !important;
}

/* If rows are split into two rows, centre each one independently */
#serviceRibbonRack .service-ribbon-mini__row--memory + .service-ribbon-mini__row--memory,
.service-ribbon-mini__row--memory + .service-ribbon-mini__row--memory {
  justify-content: center !important;
  margin-inline: auto !important;
}

/* Keep image-only badge styling */
#serviceRibbonRack .pd-memory-badge,
.pd-memory-badge {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Hub-only placeholder marks for games awaiting their specific image sets. */
#serviceRibbonRack .pd-generic-award {
  display: grid !important;
  place-items: center !important;
  border: 1px solid currentColor !important;
  border-radius: 50% !important;
  background: color-mix(in srgb, currentColor 12%, var(--panel)) !important;
  box-shadow: inset 0 0 0 0.22rem color-mix(in srgb, currentColor 8%, transparent), 0 0.16rem 0.22rem rgba(0,0,0,.34) !important;
  font-size: 1rem !important;
  font-weight: 950 !important;
  line-height: 1 !important;
}

#serviceRibbonRack .pd-generic-award span {
  display: block;
}

#serviceRibbonRack .pd-memory-badge--proven { color: #34d399 !important; }
#serviceRibbonRack .pd-memory-badge--distinguished { color: #60a5fa !important; }
#serviceRibbonRack .pd-memory-badge--elite { color: #a78bfa !important; }
#serviceRibbonRack .pd-memory-badge--legendary { color: #facc15 !important; }

.hub-page .service-ribbon-mini__dotr {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.42rem;
}

/* Match the hub frame exactly to the standard game-page frame. */
.hub-page .hub-header,
.hub-page .hub-dashboard {
  width: min(1440px, calc(100vw - 2rem)) !important;
  margin-inline: auto !important;
  padding-inline: 0 !important;
}

@media (max-width: 650px) {
  .hub-page .hub-header,
  .hub-page .hub-dashboard {
    width: min(100% - 1rem, 760px) !important;
    padding-inline: 0 !important;
  }
}

/* Tooltips may escape the fixed rack without affecting its reserved layout size. */
.hub-page #serviceRibbonRack {
  overflow: visible !important;
}

/* Shared game-page award tooltips. */
body:not(.hub-page) [data-award-tooltip] {
  position: relative;
}

body:not(.hub-page) [data-award-tooltip]::after {
  content: attr(data-award-tooltip);
  position: absolute;
  left: 50%;
  bottom: calc(100% + .58rem);
  z-index: 10000;
  width: max-content;
  min-width: 11rem;
  max-width: min(18rem, 82vw);
  padding: .6rem .72rem;
  transform: translateX(-50%);
  color: #fff;
  background: #0b0f19;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: .62rem;
  box-shadow: 0 .75rem 1.6rem rgba(0,0,0,.42);
  font-size: .72rem;
  font-weight: 800;
  line-height: 1.42;
  text-align: left;
  white-space: pre-line;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

body:not(.hub-page) [data-award-tooltip]:hover::after,
body:not(.hub-page) [data-award-tooltip]:focus-visible::after {
  opacity: 1;
  visibility: visible;
}

/* Final shared award tooltip style. Overrides earlier page-specific suppression. */
.hub-page #serviceRibbonRack {
  overflow: visible !important;
}

.hub-page #serviceRibbonRack [data-tooltip] {
  position: relative !important;
  isolation: isolate !important;
}

.hub-page #serviceRibbonRack [data-tooltip]::after {
  content: attr(data-tooltip) !important;
  position: absolute !important;
  left: 50% !important;
  bottom: calc(100% + .65rem) !important;
  z-index: 10000 !important;
  display: block !important;
  box-sizing: border-box !important;
  width: 17rem !important;
  min-width: 17rem !important;
  max-width: min(17rem, 82vw) !important;
  height: auto !important;
  padding: .7rem .85rem !important;
  transform: translateX(-50%) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  border-radius: .7rem !important;
  background: linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02)),#0b0f19 !important;
  box-shadow: 0 .85rem 1.8rem rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.08) !important;
  color: #fff !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
  line-height: 1.45 !important;
  text-align: left !important;
  white-space: pre-line !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.hub-page #serviceRibbonRack [data-tooltip]::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  bottom: calc(100% + .34rem) !important;
  z-index: 9999 !important;
  display: block !important;
  width: .6rem !important;
  height: .6rem !important;
  transform: translateX(-50%) rotate(45deg) !important;
  background: #0b0f19 !important;
  border-right: 1px solid rgba(255,255,255,.18) !important;
  border-bottom: 1px solid rgba(255,255,255,.18) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.hub-page #serviceRibbonRack [data-tooltip]:hover::after,
.hub-page #serviceRibbonRack [data-tooltip]:focus-visible::after,
.hub-page #serviceRibbonRack [data-tooltip]:hover::before,
.hub-page #serviceRibbonRack [data-tooltip]:focus-visible::before {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Final hub/game header parity and awards-rack CLS lock. */
.hub-page .app-header.hub-header {
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: .75rem !important;
  min-block-size: var(--hdr-h) !important;
  margin: 0 auto .45rem !important;
  padding: 8px 0 !important;
}

.hub-page .hub-header .brand,
.hub-page .hub-header .brand-link {
  display: inline-flex !important;
  align-items: center !important;
  gap: .6rem !important;
  min-width: 0 !important;
}

.hub-page .hub-header .brand {
  min-height: var(--ctrl-h) !important;
}

.hub-page .hub-header .brand-copy {
  display: grid !important;
  gap: .12rem !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

.hub-page .hub-header .brand-title {
  margin: 0 !important;
  font-size: 1.24rem !important;
  font-weight: 800 !important;
  letter-spacing: .03em !important;
  line-height: 1 !important;
}

.hub-page .hub-header .brand-subtitle {
  margin-top: .12rem !important;
  font-size: .76rem !important;
  font-weight: 750 !important;
  line-height: 1 !important;
}

.hub-page .service-ribbon-mini {
  grid-template-rows: auto 6.1rem 2.15rem 2.1rem !important;
  align-content: start !important;
  block-size: 14.4rem !important;
  min-block-size: 14.4rem !important;
  max-block-size: 14.4rem !important;
  overflow: visible !important;
}

.hub-page .service-ribbon-mini__top {
  block-size: 1rem !important;
  min-block-size: 1rem !important;
  max-block-size: 1rem !important;
  white-space: nowrap !important;
  overflow: hidden !important;
}

.hub-page .service-ribbon-mini__top span:last-child {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.hub-page #serviceRibbonRack {
  block-size: 8.5rem !important;
  min-block-size: 6.1rem !important;
  max-block-size: 9rem !important;
  overflow: hidden !important;
}

.hub-page #serviceRibbonEmpty,
.hub-page #serviceRibbonEmpty[hidden] {
  display: grid !important;
  min-block-size: 2.15rem !important;
  block-size: 2.15rem !important;
  margin: 0 !important;
}

.hub-page #serviceRibbonEmpty[hidden] {
  visibility: hidden !important;
}

.hub-page #serviceRibbonPager {
  align-content: center !important;
  block-size: 2.1rem !important;
  min-block-size: 2.1rem !important;
  max-block-size: 2.1rem !important;
  margin-bottom: .3rem !important;
  overflow: hidden !important;
}

@media (max-width: 650px) {
  .hub-page .app-header.hub-header {
    grid-template-columns: 1fr !important;
  }

  .hub-page .hub-header .hub-controls {
    justify-self: start !important;
  }

  .hub-page .service-ribbon-mini {
    grid-template-rows: auto 5.55rem 2.15rem 3rem !important;
    block-size: 14.85rem !important;
    min-block-size: 14.85rem !important;
    max-block-size: 14.85rem !important;
  }

  .hub-page #serviceRibbonRack {
    block-size: 5.55rem !important;
    min-block-size: 5.55rem !important;
    max-block-size: 5.55rem !important;
  }

  .hub-page #serviceRibbonPager {
    block-size: 3rem !important;
    min-block-size: 3rem !important;
    max-block-size: 3rem !important;
  }
}

/* Final cascade guard: fixed rack dimensions, visible overlay tooltips. */
.hub-page #serviceRibbonRack {
  overflow: visible !important;
}

/* =============================================================================
   Continue Playing empty card animated portfolio border
   Uses the same moving gradient language as the main portfolio scroll border.
   ============================================================================= */

.hub-page .continue-empty-card {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid transparent;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--primary) 5%, transparent), transparent 55%),
    var(--panel);
}

.hub-page .continue-empty-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  padding: 5px;
  border-radius: inherit;
  background: linear-gradient(
    to right,
    #1976d2, #007acc, #7b61ff, #d473d4, #9c27b0,
    #e26d5c, #ff9800, #ffa600, #ffae42, #92b25a,
    #2e7d32, #3aa76d, #1976d2
  );
  background-size: 200% auto;
  animation: continueBorderScrollHorizontal 20s linear infinite;
  pointer-events: none;

  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  mask-composite: exclude;
}

@keyframes continueBorderScrollHorizontal {
  0% {
    background-position: 200% center;
  }

  100% {
    background-position: 0% center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hub-page .continue-empty-card::before {
    animation: none;
  }
}

/* =============================================================================
   PlayDeck pagination arrows — final real-glyph arrow pass
   Keeps circular controls. Uses the actual ‹ › text generated by JS.
   Removes pseudo-element chevrons that caused poor alignment/shape.
   ============================================================================= */

.service-ribbon-mini__arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  inline-size: 1.48rem;
  block-size: 1.48rem;
  flex: 0 0 1.48rem;

  margin: 0 0.28rem;
  padding: 0 0 0.08rem;

  border: 1px solid color-mix(in srgb, var(--border) 72%, var(--text));
  border-radius: 999px;

  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,.13), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.085), rgba(0,0,0,.12)),
    var(--surface);

  color: var(--muted);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.28rem;
  font-weight: 700;
  line-height: 1;

  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.035),
    0 0.18rem 0.55rem rgba(0,0,0,.22);

  opacity: 0.92;
  cursor: pointer;

  transform: translateY(0);
  transition:
    border-color .16s ease,
    background .16s ease,
    box-shadow .16s ease,
    color .16s ease,
    opacity .16s ease,
    transform .16s ease;
}

.service-ribbon-mini__arrow::before,
.service-ribbon-mini__arrow::after {
  content: none !important;
}

.service-ribbon-mini__arrow:hover,
.service-ribbon-mini__arrow:focus-visible {
  border-color: var(--border-strong);
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,.16), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.12), rgba(0,0,0,.10)),
    color-mix(in srgb, var(--primary) 13%, var(--surface));

  color: var(--primary);
  opacity: 1;
  outline: none;
  transform: translateY(-1px);
}

.service-ribbon-mini__arrow:focus-visible {
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.05),
    0 0 0 3px color-mix(in srgb, var(--primary) 20%, transparent),
    0 0.22rem 0.7rem rgba(0,0,0,.26);
}

.service-ribbon-mini__arrow:active {
  transform: translateY(0);
}

/* =============================================================================
   Hub summary stat balance
   Keeps the stat cards visually even after shortening labels.
   ============================================================================= */

.hub-page .summary-stat {
  justify-items: center;
  text-align: center;
}

.hub-page .summary-stat strong,
.hub-page .summary-stat span {
  width: 100%;
  text-align: center;
}

/* =============================================================================
   Hub summary stat colour roles
   Played = green/charcoal, Playable = amber/charcoal, Coming = red/charcoal.
   ============================================================================= */

.hub-page .hub-summary .summary-stat {
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(0,0,0,.08)),
    #1a1a1a;
  border-color: rgba(255,255,255,.12);
}

/* Played */
.hub-page .hub-summary .summary-stat:nth-of-type(1) {
  background:
    radial-gradient(180px 120px at 20% 0%, rgba(52, 211, 153, .18), transparent 68%),
    linear-gradient(180deg, rgba(52, 211, 153, .08), rgba(0,0,0,.10)),
    #1a1a1a;
  border-color: rgba(52, 211, 153, .34);
}

.hub-page .hub-summary .summary-stat:nth-of-type(1) strong {
  color: #d1fae5;
}

/* Playable */
.hub-page .hub-summary .summary-stat:nth-of-type(2) {
  background:
    radial-gradient(180px 120px at 20% 0%, rgba(245, 158, 11, .20), transparent 68%),
    linear-gradient(180deg, rgba(245, 158, 11, .09), rgba(0,0,0,.10)),
    #1a1a1a;
  border-color: rgba(245, 158, 11, .38);
}

.hub-page .hub-summary .summary-stat:nth-of-type(2) strong {
  color: #fde68a;
}

/* Coming */
.hub-page .hub-summary .summary-stat:nth-of-type(3) {
  background:
    radial-gradient(180px 120px at 20% 0%, rgba(239, 68, 68, .20), transparent 68%),
    linear-gradient(180deg, rgba(239, 68, 68, .09), rgba(0,0,0,.10)),
    #1a1a1a;
  border-color: rgba(239, 68, 68, .38);
}

.hub-page .hub-summary .summary-stat:nth-of-type(3) strong {
  color: #fecaca;
}

/* =============================================================================
   Hub summary stat light-mode colour roles
   Light-mode equivalents for Played / Playable / Coming summary cards.
   Keeps each card readable while preserving the green, amber, and red status logic.
   ============================================================================= */

[data-theme="light"] .hub-page .hub-summary .summary-stat {
  background:
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(17,24,39,.035)),
    #f7f7f7;
  border-color: rgba(17,24,39,.12);
  box-shadow: 0 0.35rem 1rem rgba(17,24,39,.055);
}

/* Played — green / light neutral */
[data-theme="light"] .hub-page .hub-summary .summary-stat:nth-of-type(1) {
  background:
    radial-gradient(180px 120px at 20% 0%, rgba(4, 120, 87, .16), transparent 68%),
    linear-gradient(180deg, rgba(4, 120, 87, .075), rgba(255,255,255,.82)),
    #f8faf9;
  border-color: rgba(4, 120, 87, .34);
}

[data-theme="light"] .hub-page .hub-summary .summary-stat:nth-of-type(1) strong {
  color: #047857;
}

/* Playable — amber / light neutral */
[data-theme="light"] .hub-page .hub-summary .summary-stat:nth-of-type(2) {
  background:
    radial-gradient(180px 120px at 20% 0%, rgba(180, 83, 9, .17), transparent 68%),
    linear-gradient(180deg, rgba(180, 83, 9, .08), rgba(255,255,255,.82)),
    #fffaf0;
  border-color: rgba(180, 83, 9, .36);
}

[data-theme="light"] .hub-page .hub-summary .summary-stat:nth-of-type(2) strong {
  color: #92400e;
}

/* Coming — red / light neutral */
[data-theme="light"] .hub-page .hub-summary .summary-stat:nth-of-type(3) {
  background:
    radial-gradient(180px 120px at 20% 0%, rgba(185, 28, 28, .16), transparent 68%),
    linear-gradient(180deg, rgba(185, 28, 28, .075), rgba(255,255,255,.82)),
    #fff7f7;
  border-color: rgba(185, 28, 28, .34);
}

[data-theme="light"] .hub-page .hub-summary .summary-stat:nth-of-type(3) strong {
  color: #991b1b;
}

/* =============================================================================
   Status badge — Beta purple treatment
   Final override for hub status pills.
   ============================================================================= */

.hub-page .status-badge.status-beta {
  color: #f0abfc;
  background: rgba(168, 85, 247, 0.14);
  border-color: rgba(240, 171, 252, 0.62);
}

[data-theme="light"] .hub-page .status-badge.status-beta {
  color: #86198f;
  background: #fae8ff;
  border-color: #d946ef;
}

/* =============================================================================
   Project PlayDeck Ideas Backlog
   Visual prompt board for possible future games.
   Not part of Live/Beta/Development/Coming Soon status counts.
   ============================================================================= */

.ideas-section {
  position: relative;
}

.section-note {
  max-width: 72ch;
  margin: 0.3rem 0 0;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 600;
  line-height: 1.45;
}

.ideas-grid {
  --idea-min: 230px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, var(--idea-min)), 1fr));
  gap: 0.85rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.idea-card {
  position: relative;
  overflow: hidden;
  display: grid;
  align-content: start;
  gap: 0.62rem;
  min-height: 145px;
  padding: 0.9rem;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--accent) 6%, transparent), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,0.035), rgba(0,0,0,0.06)),
    color-mix(in srgb, var(--panel) 82%, var(--surface));
  border: 1px solid color-mix(in srgb, var(--border) 78%, var(--muted));
  border-radius: 0.95rem;
  opacity: 0.86;
  box-shadow: 0 6px 18px rgba(0,0,0,0.075);
}

.idea-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  inline-size: 3px;
  background: linear-gradient(180deg, var(--muted), color-mix(in srgb, var(--accent) 55%, var(--muted)));
  opacity: 0.55;
}

.idea-card__top {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.65rem;
}

.idea-card h3 {
  margin: 0;
  color: var(--text);
  font-size: 0.98rem;
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.idea-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.83rem;
  font-weight: 600;
  line-height: 1.42;
}

.idea-chip {
  flex: 0 0 auto;
  padding: 0.16rem 0.42rem;
  border: 1px solid color-mix(in srgb, var(--muted) 38%, transparent);
  border-radius: 999px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 58%, transparent);
  font-size: 0.64rem;
  font-weight: 900;
  letter-spacing: 0.045em;
  line-height: 1.2;
  text-transform: uppercase;
}

.idea-card:hover {
  opacity: 1;
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border));
}

[data-theme="light"] .idea-card {
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--accent) 5%, transparent), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,0.82), rgba(17,24,39,0.025)),
    #f8fafc;
  box-shadow: 0 6px 18px rgba(17,24,39,0.055);
}

@media (max-width: 650px) {
  .ideas-grid {
    --idea-min: 100%;
  }

  .idea-card {
    min-height: 0;
  }

  .idea-card__top {
    align-items: center;
  }
}

/* =============================================================================
   End Project PlayDeck Ideas Backlog
   ============================================================================= */

/* Final responsive hardening for the hub awards rack and Options dialog. */
.hub-page .service-ribbon-mini__rack--scroll {
  align-content: start !important;
  scrollbar-width: thin;
}

.hub-page #serviceRibbonPager {
  flex-wrap: wrap !important;
  justify-content: center !important;
  row-gap: .38rem !important;
  padding-bottom: .3rem !important;
}

.hub-page .service-ribbon-mini__arrow {
  touch-action: manipulation;
}

@media (max-width: 650px) {
  .hub-page .service-ribbon-mini {
    grid-template-rows: auto minmax(5.55rem, 8.5rem) 2.15rem auto !important;
    block-size: auto !important;
    min-block-size: 14.85rem !important;
    max-block-size: none !important;
  }

  .hub-page #serviceRibbonRack {
    block-size: auto !important;
    min-block-size: 5.55rem !important;
    max-block-size: 8.5rem !important;
  }

  .hub-page #serviceRibbonRack.service-ribbon-mini__rack--scroll {
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  .hub-page #serviceRibbonPager {
    block-size: auto !important;
    min-block-size: 3rem !important;
    max-block-size: none !important;
    overflow: visible !important;
  }

  .hub-page .hub-options {
    width: min(calc(100vw - 1rem), 760px);
    max-height: calc(100dvh - 1rem);
  }

  .hub-page .hub-options__header,
  .hub-page .hub-options__body {
    padding-inline: .75rem;
  }

  .hub-page .hub-options .skin-switcher {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 390px) {
  .hub-page .app-header.hub-header {
    width: calc(100% - .75rem) !important;
  }

  .hub-page .hub-controls > *,
  .hub-page .hub-search,
  .hub-page .hub-sort {
    min-width: 0;
    width: 100%;
  }

  .hub-page .service-ribbon-mini {
    padding-inline: .55rem;
  }

  .hub-page .service-ribbon-mini__dotr {
    gap: .34rem;
  }

  .hub-page .service-ribbon-mini__arrow {
    inline-size: 1.65rem;
    block-size: 1.65rem;
    flex-basis: 1.65rem;
    margin-inline: .12rem;
  }

  .hub-page .hub-options .skin-switcher {
    grid-template-columns: 1fr;
  }

  .hub-page .hub-options .setting-pill,
  .hub-page .hub-options .skin-option {
    min-width: 0;
  }
}

/* One shared, viewport-clamped award tooltip for the hub and every game. */
[data-award-tooltip]::before,
[data-award-tooltip]::after {
  content: none !important;
  display: none !important;
}

.playdeck-award-tooltip {
  position: fixed;
  z-index: 100000;
  width: max-content;
  max-width: min(18rem, calc(100vw - 1.25rem));
  padding: .58rem .68rem;
  border: 1px solid var(--border-strong);
  border-radius: .55rem;
  background: color-mix(in srgb, var(--panel) 96%, #000);
  box-shadow: 0 .55rem 1.35rem rgba(0, 0, 0, .38);
  color: var(--text);
  font-size: .76rem;
  font-weight: 700;
  line-height: 1.4;
  text-align: left;
  white-space: pre-line;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(2px);
  transition: opacity .12s ease, transform .12s ease, visibility .12s ease;
}

.playdeck-award-tooltip.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
