:root {
  --bg: #101014;
  --bg-elevated: #15161c;
  --surface: #17181f;
  --surface-strong: #1d1f27;
  --surface-soft: #23252f;
  --surface-hover: #2a2d38;
  --ink: #f4f4f5;
  --ink-soft: #e4e4e7;
  --muted: #a1a1aa;
  --line: rgba(255, 255, 255, 0.08);
  --line-strong: rgba(255, 255, 255, 0.14);
  --accent: #ffd54a;
  --accent-strong: #ffe27a;
  --accent-2: #a78bfa;
  --shadow-soft: 0 14px 28px rgba(0, 0, 0, 0.16);
  --radius-xl: 8px;
  --radius-lg: 18px;
  --radius-md: 8px;
  --tier-poor: #70737d;
  --tier-common: #f3f4f6;
  --tier-uncommon: #4ade80;
  --tier-rare: #60a5fa;
  --tier-epic: #c084fc;
  --tier-legendary: #fbbf24;
}


* {
  box-sizing: border-box;
}

html {
  color-scheme: dark;
  scroll-behavior: smooth;
}


body {
  margin: 0;
  min-height: 100vh;
  font-family: "Inter", sans-serif;
  color: var(--ink);
  background: linear-gradient(180deg, #0f1015 0%, var(--bg) 100%);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}


a,
button {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
}

.app-shell {
  width: min(1360px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 0.6rem 0 2rem;
}

.site-header {
  position: sticky;
  top: 0.55rem;
  z-index: 40;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  padding: 0.55rem 0.72rem;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  backdrop-filter: blur(18px);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
}

.brand {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  min-width: 0;
}

.brand-wordmark {
  display: inline-flex;
  align-items: baseline;
  gap: 0.3rem;
  font-size: clamp(1.28rem, 1.5vw, 1.65rem);
  font-weight: 800;
  letter-spacing: -0.08em;
  line-height: 1;
}

.brand-wordmark-main {
  color: var(--ink);
}

.brand-wordmark-accent {
  color: var(--accent);
}

.site-header-actions {
  display: flex;
  align-items: center;
  flex: 1 1 auto;
  justify-content: flex-end;
  gap: 0.55rem;
  min-width: 0;
}

.site-nav {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
  gap: 0.35rem;
  flex-wrap: nowrap;
  justify-content: flex-start;
  max-width: 100%;
  margin-left: auto;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: none;
}

.site-nav::-webkit-scrollbar {
  display: none;
}

.site-nav a,
.site-nav-toggle {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.05rem;
  padding: 0.46rem 0.72rem;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--muted);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1;
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}
.vote-page,
.home-page,
.leaderboard-page,
.dashboard-page {
  display: grid;
  gap: 1rem;
  margin-top: 1rem;
}

.message-panel,
.leaderboard-list,
.chart-header,
.panel,
.stats-grid,
.vote-stage,
.hero-panel {
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: var(--surface-strong);
  box-shadow: var(--shadow-soft);
}

.hero-panel {
  padding: 1.2rem 1.3rem;
}

.hero-panel h1,
.hero-panel p {
  margin: 0;
}

.hero-panel h1,
.panel h2,
.leaderboard-main strong,
.card-title,
.stat-card strong,
.mini-title {
  letter-spacing: -0.04em;
}

.hero-panel h1 {
  font-size: clamp(1.55rem, 2.2vw, 2.2rem);
  line-height: 1;
  max-width: 14ch;
}

.hero-copy,
.panel-header span,
.mini-meta,
.leaderboard-main span,
.stat-card > span:last-child,
.vs-banner,
.genre-copy span {
  color: var(--muted);
}

.home-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(1.4rem, 4vw, 2.3rem);
  background:
    radial-gradient(circle at top right, rgba(255, 213, 74, 0.18), transparent 30%),
    linear-gradient(135deg, color-mix(in srgb, var(--surface-strong) 90%, black 10%), var(--surface));
}

.home-hero-copy {
  display: grid;
  gap: 0.85rem;
  max-width: 40rem;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 0.42rem 0.68rem;
  border: 1px solid rgba(255, 213, 74, 0.22);
  border-radius: 999px;
  background: rgba(255, 213, 74, 0.08);
  color: var(--accent);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-hero .hero-copy {
  max-width: 34rem;
  font-size: 1rem;
  line-height: 1.6;
}

.home-category-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.category-card {
  position: relative;
  display: block;
  min-height: 16.5rem;
  border: 1px solid var(--line);
  border-radius: 1.3rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), transparent 38%),
    var(--surface-strong);
  box-shadow: var(--shadow-soft);
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
}

.category-card-inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.88rem;
  height: 100%;
  padding: 1.25rem;
}

.category-card-inner > .category-title:first-of-type {
  margin-top: 0.55rem;
}

.category-card.is-active:hover,
.category-card.is-active:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(255, 213, 74, 0.3);
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.24);
}

.category-card.is-disabled {
  opacity: 0.88;
}

.category-card-topline {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.category-media {
  position: relative;
  width: 100%;
  min-height: 8.4rem;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)),
    rgba(11, 14, 20, 0.74);
}

.category-media-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
}

.category-media-poster {
  aspect-ratio: 1.42;
}

.category-media-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.category-media-logo .category-media-image {
  width: min(86%, 22rem);
  height: auto;
  max-height: 5rem;
  object-fit: contain;
}

.category-title {
  font-size: clamp(1.2rem, 2vw, 1.55rem);
  line-height: 1.12;
}

.category-status {
  color: var(--muted);
  line-height: 1.5;
}

.category-badge {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 0.75rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--ink-soft);
  font-size: 0.85rem;
  font-weight: 700;
}

.category-card-xbox {
  background:
    radial-gradient(circle at top right, rgba(16, 185, 129, 0.22), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), transparent 38%),
    var(--surface-strong);
}

.category-card-xbox .category-media {
  background:
    radial-gradient(circle at 22% 18%, rgba(52, 211, 153, 0.18), transparent 34%),
    radial-gradient(circle at 84% 24%, rgba(16, 185, 129, 0.16), transparent 28%),
    linear-gradient(145deg, rgba(8, 26, 18, 0.94), rgba(14, 64, 43, 0.88));
}

.category-card-steam {
  background:
    radial-gradient(circle at top right, rgba(96, 165, 250, 0.2), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), transparent 38%),
    var(--surface-strong);
}

.category-card-steam .category-media {
  background:
    radial-gradient(circle at 18% 22%, rgba(96, 165, 250, 0.2), transparent 30%),
    radial-gradient(circle at 82% 20%, rgba(59, 130, 246, 0.18), transparent 24%),
    linear-gradient(150deg, rgba(8, 17, 31, 0.96), rgba(15, 37, 64, 0.9));
}

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

@media (max-width: 640px) {
  .site-header {
    align-items: center;
    flex-direction: row;
    gap: 0.3rem;
    padding: 0.46rem 0.52rem;
  }

  .site-header-actions {
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
    gap: 0.2rem;
    justify-content: flex-end;
  }

  .home-category-grid {
    grid-template-columns: 1fr;
  }

  .category-card {
    min-height: 14.5rem;
  }

  .category-media {
    min-height: 7.4rem;
  }
}

.hero-copy {
  margin-top: 0.68rem;
  max-width: 58ch;
  line-height: 1.55;
}

.eyebrow,
.stat-label,
.fallback-kicker {
  display: inline-block;
  margin-bottom: 0.42rem;
  color: var(--accent-2);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.vote-stage {
  display: grid;
  gap: 0.9rem;
  padding: 0.95rem;
  border-radius: 16px;
}

@media (min-width: 1100px) {
  .vote-stage {
    width: 100%;
    margin-inline: 0;
  }

  .card-grid {
    display: grid;
    grid-template-columns: repeat(2, 332px);
    justify-content: center;
    gap: clamp(1.5rem, 2.4vw, 2.5rem);
    align-items: start;
  }

  .card-grid > .game-card {
    width: 332px;
    max-width: 332px;
  }

  .card-frame {
    grid-template-rows: auto minmax(82px, auto);
  }

  .card-body {
    gap: 0.28rem;
    padding: 0.58rem;
  }

  .card-chip-row {
    gap: 0.22rem;
  }

  .card-chip-row span {
    min-height: 1.42rem;
    padding: 0.16rem 0.38rem;
    font-size: 0.6rem;
  }

  .card-title {
    font-size: clamp(0.9rem, 1.05vw, 1rem);
    min-height: 1.9em;
  }
}

@media (min-width: 1100px) and (max-height: 820px) {
  .app-shell {
    padding: 0.25rem 0 0.45rem;
  }

  .site-header {
    top: 0.25rem;
    padding: 0.44rem 0.64rem;
  }

  .brand-wordmark {
    font-size: clamp(1.14rem, 1.2vw, 1.42rem);
  }

  .site-nav a,
  .site-nav-toggle {
    min-height: 2rem;
    padding: 0.42rem 0.68rem;
    font-size: 0.8rem;
  }

  .vote-page {
    margin-top: 0.5rem;
    gap: 0.55rem;
  }

  .vote-stage {
    gap: 0.72rem;
    padding: 0.72rem;
  }

  .card-grid {
    grid-template-columns: repeat(2, 300px);
    justify-content: center;
    gap: 1.5rem;
  }

  .card-grid > .game-card {
    width: 300px;
    max-width: 300px;
  }

  .card-frame {
    grid-template-rows: auto minmax(72px, auto);
  }

  .card-body {
    gap: 0.22rem;
    padding: 0.5rem;
  }

  .card-chip-row {
    gap: 0.18rem;
  }

  .card-chip-row span {
    min-height: 1.28rem;
    padding: 0.12rem 0.32rem;
    font-size: 0.56rem;
  }

  .card-title {
    font-size: 0.9rem;
    min-height: 1.8em;
  }

  .vote-actions {
    margin-top: -0.1rem;
  }

  .group-bar-shell {
    gap: 0.35rem;
    margin-top: 0.5rem;
  }

  .group-bar,
  .group-drawer {
    padding: 0.56rem 0.7rem;
  }

  .group-bar-label,
  .group-chip {
    font-size: 0.7rem;
  }
}

.vote-stage.is-transitioning {
  border-color: rgba(167, 139, 250, 0.2);
}

.vs-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.vs-banner span:first-child {
  color: var(--ink);
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
  align-items: stretch;
}

.game-card {
  appearance: none;
  border: 0;
  padding: 0;
  background: transparent;
  display: block;
  height: 100%;
  text-align: left;
  cursor: pointer;
  min-width: 0;
}

.game-card:disabled {
  cursor: wait;
}

.card-frame {
  display: grid;
  grid-template-rows: auto minmax(118px, auto);
  height: 100%;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: #1b1c24;
  transition:
    border-color 180ms ease,
    transform 180ms ease,
    opacity 180ms ease,
    filter 180ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease;
}


.game-card:hover .card-frame,
.game-card:focus-visible .card-frame {
  transform: translateY(-2px);
  border-color: rgba(167, 139, 250, 0.3);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.12);
}

.game-card.is-picked .card-frame {
  transform: translateY(-4px);
  border-color: rgba(255, 213, 74, 0.36);
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.16);
}

.game-card.is-fading .card-frame {
  opacity: 0.42;
  filter: saturate(0.8);
}

.tier-poor .card-frame,
.tier-poor .leaderboard-art {
  border-color: color-mix(in srgb, var(--tier-poor) 62%, var(--line));
  box-shadow: 0 0 0 1px rgba(112, 115, 125, 0.12);
}

.tier-common .card-frame,
.tier-common .leaderboard-art {
  border-color: color-mix(in srgb, var(--tier-common) 28%, var(--line));
  box-shadow: 0 0 0 1px rgba(243, 244, 246, 0.08);
}

.tier-uncommon .card-frame,
.tier-uncommon .leaderboard-art {
  border-color: color-mix(in srgb, var(--tier-uncommon) 56%, var(--line));
  box-shadow: 0 0 0 1px rgba(74, 222, 128, 0.12), 0 0 18px rgba(74, 222, 128, 0.08);
}

.tier-rare .card-frame,
.tier-rare .leaderboard-art {
  border-color: color-mix(in srgb, var(--tier-rare) 58%, var(--line));
  box-shadow: 0 0 0 1px rgba(96, 165, 250, 0.14), 0 0 20px rgba(96, 165, 250, 0.09);
}

.tier-epic .card-frame,
.tier-epic .leaderboard-art {
  border-color: color-mix(in srgb, var(--tier-epic) 58%, var(--line));
  box-shadow: 0 0 0 1px rgba(192, 132, 252, 0.14), 0 0 22px rgba(192, 132, 252, 0.1);
}

.tier-legendary .card-frame,
.tier-legendary .leaderboard-art {
  border-color: color-mix(in srgb, var(--tier-legendary) 62%, var(--line));
  box-shadow: 0 0 0 1px rgba(251, 191, 36, 0.16), 0 0 24px rgba(251, 191, 36, 0.11);
}

.card-art {
  display: block;
  aspect-ratio: 0.72;
  overflow: hidden;
  background: #111216;
}

.card-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

body[data-category-slug="uk-fruits"] .card-art {
  background: rgba(255, 255, 255, 0.03);
}

body[data-category-slug="uk-fruits"] .card-art img {
  object-fit: cover;
  object-position: center center;
}

.card-body {
  display: grid;
  align-content: start;
  gap: 0.52rem;
  padding: 0.9rem;
}

.developer-dock {
  display: grid;
  gap: 0.75rem;
  padding: 1rem 0 0;
  border-top: 1px solid var(--line);
}

.developer-dock[hidden] {
  display: none;
}

.developer-dock-header {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  gap: 0.18rem;
}

.developer-dock-header strong,
.developer-dock-game strong {
  letter-spacing: -0.03em;
}

.developer-dock-header strong {
  font-size: 0.92rem;
}

.developer-dock-header span,
.developer-dock-label {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.developer-dock-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.72rem;
}

.developer-dock-column {
  display: grid;
  gap: 0.45rem;
  min-width: 0;
}

.developer-dock-game {
  display: grid;
  gap: 0.14rem;
}

.developer-dock-game strong {
  font-size: 0.92rem;
  line-height: 1.15;
}

.developer-metric-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.36rem;
}

.developer-metric {
  display: grid;
  gap: 0.14rem;
  align-content: start;
  min-height: 3.1rem;
  padding: 0.45rem 0.5rem;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--muted);
  font-size: 0.64rem;
  line-height: 1.1;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.developer-metric strong {
  color: var(--ink);
  font-size: 0.96rem;
  letter-spacing: -0.03em;
  text-transform: none;
  font-variant-numeric: tabular-nums;
  white-space: normal;
}

.developer-metric .metric-positive {
  color: #3ddc84;
}

.developer-metric .metric-negative {
  color: #ff6b6b;
}

.developer-metric-trend strong {
  color: var(--accent);
}

.developer-metric-trend {
  grid-column: 1 / -1;
  min-height: auto;
}

.developer-form {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.28rem;
  padding-top: 0.18rem;
}

.developer-form-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.48rem;
  height: 1.48rem;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.developer-form-pill-w {
  border-color: rgba(61, 220, 132, 0.28);
  background: rgba(61, 220, 132, 0.16);
  color: #3ddc84;
}

.developer-form-pill-l {
  border-color: rgba(255, 107, 107, 0.28);
  background: rgba(255, 107, 107, 0.14);
  color: #ff6b6b;
}

.developer-form-pill-s {
  border-color: rgba(161, 161, 170, 0.22);
  background: rgba(161, 161, 170, 0.12);
  color: #a1a1aa;
}

.card-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.38rem;
  align-items: flex-start;
}

.card-chip-row span {
  display: inline-flex;
  align-items: center;
  min-height: 1.8rem;
  padding: 0.3rem 0.55rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.04);
  background: #262833;
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1;
}


.card-title {
  font-size: clamp(1.1rem, 1.7vw, 1.38rem);
  line-height: 1.06;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  min-height: 2.15em;
}

.fallback-art {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 1rem;
  color: white;
}

.fallback-art strong {
  font-size: clamp(1.35rem, 2.8vw, 1.85rem);
  line-height: 1.04;
}

.fallback-art.small {
  aspect-ratio: 0.72;
  padding: 0.8rem;
}

.fallback-art.small strong {
  font-size: 0.95rem;
}

.vote-actions {
  display: flex;
  justify-content: center;
}

.vote-page {
  padding-bottom: 0;
}

.group-bar-shell {
  display: grid;
  gap: 0.55rem;
  margin-top: 1rem;
  position: relative;
}

.group-bar,
.group-drawer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.72rem 0.85rem;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  backdrop-filter: blur(14px);
}

.group-drawer {
  align-items: stretch;
  justify-content: flex-start;
}

@media (min-width: 761px) {
  .group-drawer {
    position: absolute;
    left: 50%;
    top: calc(100% + 0.4rem);
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
    gap: 1.05rem;
    width: min(52rem, calc(100vw - 3rem));
    transform: translateX(-50%);
    z-index: 20;
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.24);
  }

  .group-bar-actions {
    position: relative;
  }

  .group-form,
  .group-share {
    justify-items: stretch;
    min-width: 0;
  }

  .group-input-row {
    width: 100%;
    max-width: none;
    justify-self: stretch;
  }

  .group-share button[data-group-share-native] {
    align-self: flex-end;
    margin-top: 0.35rem;
  }
}

.group-drawer[hidden],
.group-share[hidden] {
  display: none;
}

.group-bar-state,
.group-bar-actions {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.group-bar-label {
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-subtle);
}

.group-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.38rem 0.68rem;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  max-width: min(42vw, 32rem);
  border-radius: 999px;
  font-size: 0.76rem;
}

.group-chip-active {
  border-color: color-mix(in srgb, #5ecf97 48%, var(--line));
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--surface-soft) 78%, #58d68d 22%),
    color-mix(in srgb, var(--surface) 84%, #3ebd78 16%)
  );
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.group-chip-active strong,
.group-chip-active .group-exit {
  color: #d8f8e7;
}



.group-chip strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.group-chip-global {
  opacity: 0.82;
}

.group-exit,
.group-bar-button,
.group-form-actions button,
.group-share button,
.group-form button {
  appearance: none;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--ink);
  font: inherit;
  cursor: pointer;
  padding: 0.55rem 0.8rem;
}

.group-bar-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
}

.group-exit {
  padding: 0.2rem 0.45rem;
}

.group-form,
.group-share {
  display: grid;
  gap: 0.6rem;
  flex: 1 1 24rem;
}

.group-panel-label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ink);
  text-align: left;
  width: 100%;
}

.group-input-row {
  display: flex;
  align-items: stretch;
  gap: 0.6rem;
  width: min(100%, 32rem);
  justify-self: center;
}

.group-share input,
.group-form input {
  min-width: 16rem;
  max-width: 100%;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--ink);
  padding: 0.55rem 0.7rem;
  font: inherit;
}

.group-input-row input {
  flex: 1 1 auto;
  border-radius: 1rem;
  border-color: color-mix(in srgb, var(--line) 65%, transparent);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--surface-soft) 76%, var(--accent) 24%),
    color-mix(in srgb, var(--surface) 84%, var(--accent) 16%)
  );
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  padding: 0.85rem 1rem;
  min-height: 3.25rem;
}

.group-input-row button {
  display: inline-flex;
  flex: 0 0 8.5rem;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-width: 8rem;
  border-radius: 1rem;
  border-color: color-mix(in srgb, var(--line) 50%, var(--accent) 50%);
  background: linear-gradient(180deg, #d6f9ec 0%, #bfeeda 100%);
  color: #12362d;
  font-weight: 700;
  white-space: nowrap;
  min-height: 3.25rem;
}

.group-input-row button:hover,
.group-input-row button:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 68%, var(--line) 32%);
  background: linear-gradient(180deg, #e7fff5 0%, #cff6e6 100%);
}

.group-share button[data-group-share-native] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  align-self: center;
  margin-top: 0.35rem;
  min-width: 8.25rem;
  border-radius: 1rem;
  border-color: color-mix(in srgb, var(--line) 50%, var(--accent) 50%);
  background: linear-gradient(180deg, #d6f9ec 0%, #bfeeda 100%);
  color: #12362d;
  font-weight: 700;
}

.group-share button[data-group-share-native]:hover,
.group-share button[data-group-share-native]:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 68%, var(--line) 32%);
  background: linear-gradient(180deg, #e7fff5 0%, #cff6e6 100%);
}

.skip-button,
.pager-link {
  appearance: none;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--ink);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    transform 160ms ease;
}

.skip-button {
  padding: 0.9rem 1.24rem;
}

.skip-button:hover,
.skip-button:focus-visible,
.pager-link:hover,
.pager-link:focus-visible {
  background: var(--surface-hover);
  border-color: var(--line-strong);
  transform: translateY(-1px);
}

.skip-button:disabled {
  opacity: 0.55;
  cursor: wait;
}

.leaderboard-list,
.panel {
  padding: 0.95rem;
}

.chart-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.9rem;
  align-items: end;
  padding: 0.9rem 1rem;
}

.chart-header h1,
.chart-header p {
  margin: 0;
}

.chart-header-copy {
  display: grid;
  gap: 0.24rem;
}

.chart-header h1 {
  font-size: clamp(1.35rem, 1.8vw, 1.85rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
}

.chart-header .hero-copy {
  max-width: 32rem;
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.35;
}

.chart-header-meta {
  display: grid;
  gap: 0.14rem;
  justify-items: end;
  color: var(--muted);
  text-align: right;
}

.table-header-meta {
  align-content: start;
}

.table-header-group {
  min-width: 0;
  display: flex;
  align-items: center;
}

.table-header-group .group-chip {
  max-width: min(18rem, 26vw);
}

.chart-header-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.45rem;
  margin-top: 0.35rem;
}

.chart-header-meta strong {
  color: var(--ink);
  font-size: 0.84rem;
  letter-spacing: -0.02em;
}

.chart-count {
  font-size: 0.78rem;
  letter-spacing: 0.01em;
}

.leaderboard-toolbar {
  padding: 0.85rem 0.95rem;
}

.leaderboard-filter-toggle,
.table-mobile-toggle,
.table-mobile-details {
  display: none;
}

.leaderboard-filters {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(180px, 0.8fr) auto;
  gap: 0.8rem;
  align-items: end;
}

.leaderboard-filter {
  display: grid;
  gap: 0.34rem;
}

.leaderboard-filter span {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.leaderboard-filter input,
.leaderboard-filter select {
  min-height: 2.65rem;
  padding: 0.7rem 0.78rem;
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--ink);
  font: inherit;
}

.leaderboard-filter-actions {
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.leaderboard-table-wrap {
  padding: 0.4rem 0.95rem 0.95rem;
  overflow-x: auto;
}

.leaderboard-football-head,
.leaderboard-football-row {
  display: grid;
  grid-template-columns: 58px minmax(300px, 1.7fr) 78px 62px 62px 78px 78px 138px;
  gap: 0.55rem;
  align-items: center;
}

.leaderboard-football-head {
  padding: 0.2rem 0 0.6rem;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font-size: 0.63rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.table-sort-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.18rem;
  color: inherit;
  text-decoration: none;
  width: 100%;
  min-width: 0;
  white-space: nowrap;
}

.table-sort-link.is-active {
  color: var(--ink);
}

.leaderboard-football-head .table-sort-link:nth-child(1),
.leaderboard-football-head .table-sort-link:nth-child(2) {
  justify-content: flex-start;
}

.leaderboard-football-table {
  display: grid;
}

.leaderboard-football-row {
  padding: 0.72rem 0;
  border-bottom: 1px solid var(--line);
}

.leaderboard-football-row:last-child {
  border-bottom: 0;
}

.table-pos,
.table-stat {
  font-variant-numeric: tabular-nums;
}

.table-pos {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--accent);
}

.table-game {
  display: grid;
  grid-template-columns: 60px minmax(0, 1fr);
  gap: 0.72rem;
  align-items: center;
  min-width: 0;
}

.table-game .leaderboard-art {
  width: 60px;
  border-radius: 10px;
}

.table-game-copy {
  display: grid;
  gap: 0.2rem;
  min-width: 0;
}

.table-game-copy strong {
  line-height: 1.08;
}

.table-game-copy span {
  color: var(--muted);
  font-size: 0.82rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.table-stat {
  text-align: center;
  font-weight: 700;
}

.table-stat-elo {
  font-weight: 800;
}

.table-form {
  display: flex;
  justify-content: flex-start;
  gap: 0.28rem;
  flex-wrap: wrap;
}

.form-pill {
  min-width: 1.45rem;
  min-height: 1.45rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  font-size: 0.72rem;
  font-weight: 800;
}

.form-pill-w {
  color: #4ade80;
  border-color: rgba(74, 222, 128, 0.35);
  background: rgba(74, 222, 128, 0.08);
}

.form-pill-l {
  color: #f87171;
  border-color: rgba(248, 113, 113, 0.35);
  background: rgba(248, 113, 113, 0.08);
}

.form-pill-s {
  color: #cbd5e1;
  border-color: rgba(148, 163, 184, 0.35);
  background: rgba(148, 163, 184, 0.1);
}

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

.leaderboard-column {
  display: grid;
  gap: 0.08rem;
}

.leaderboard-row,
.mini-row {
  display: grid;
  align-items: center;
  gap: 0.95rem;
}

.leaderboard-row {
  grid-template-columns: 48px 96px minmax(0, 1fr);
  padding: 0.9rem 0.15rem;
  border-bottom: 1px solid var(--line);
}

.chart-table-head {
  display: grid;
  grid-template-columns: 64px 64px minmax(0, 1fr) 64px;
  gap: 0.85rem;
  padding: 0 0.15rem 0.55rem;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.chart-table {
  display: grid;
}

.leaderboard-row-chart {
  grid-template-columns: 64px 64px minmax(0, 1fr) 64px;
  gap: 0.85rem;
  padding: 0.78rem 0.15rem;
}

.leaderboard-row:last-child,
.mini-row:last-child {
  border-bottom: 0;
}

.leaderboard-rank {
  width: 2.8rem;
  min-height: 2.8rem;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0.04rem;
  font-weight: 800;
  color: var(--accent);
  background: transparent;
  font-variant-numeric: tabular-nums;
}

.leaderboard-rank-number {
  font-size: 1.72rem;
  line-height: 0.92;
  letter-spacing: -0.08em;
}

.leaderboard-rank-suffix {
  margin-top: 0.18rem;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-transform: lowercase;
}

.chart-move,
.chart-peak {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.04rem;
  min-width: 0;
}

.chart-move-arrow,
.chart-peak strong {
  font-size: 1.04rem;
  font-weight: 800;
  line-height: 1;
}

.chart-move-value,
.chart-stat-label {
  color: var(--muted);
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.chart-move-up .chart-move-arrow,
.chart-move-up .chart-move-value {
  color: #4ade80;
}

.chart-move-down .chart-move-arrow,
.chart-move-down .chart-move-value {
  color: #f87171;
}

.chart-move-new .chart-move-arrow,
.chart-move-new .chart-move-value {
  color: var(--accent);
}

.chart-move-steady .chart-move-arrow,
.chart-move-steady .chart-move-value {
  color: var(--muted);
}

.leaderboard-art {
  width: 88px;
  aspect-ratio: 0.72;
  overflow: hidden;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #111216;
}

.leaderboard-entry {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 0.85rem;
  align-items: center;
  min-width: 0;
}

.leaderboard-art img,
.leaderboard-art .fallback-art.small {
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  object-fit: cover;
  border-radius: inherit;
}

body[data-category-slug="uk-fruits"] .leaderboard-art {
  background: rgba(255, 255, 255, 0.03);
}

body[data-category-slug="uk-fruits"] .leaderboard-art img {
  object-fit: cover;
  object-position: center center;
}

.leaderboard-main {
  display: grid;
  gap: 0.26rem;
  min-width: 0;
}

.leaderboard-main strong,
.mini-title {
  min-width: 0;
  overflow-wrap: anywhere;
}

.leaderboard-main strong {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  line-height: 1.08;
  min-height: 2.08em;
}

.leaderboard-main span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 0.82rem;
}

.pager-link {
  padding: 0.62rem 0.84rem;
  font-size: 0.78rem;
}

.pager-link.is-active {
  background: #2b2e39;
  border-color: rgba(167, 139, 250, 0.28);
}


.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
  padding: 0.95rem;
}

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

.stat-card {
  display: grid;
  gap: 0.36rem;
  align-content: start;
  min-height: 10.6rem;
  padding: 1rem;
  border-radius: 8px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
}

.stat-card strong {
  font-size: 1.38rem;
  line-height: 1.04;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.dashboard-columns {
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  gap: 1rem;
}

.panel-header {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: baseline;
}

.panel-header h2 {
  margin: 0;
}

.dashboard-page-analytics {
  gap: 1rem;
  padding-bottom: 1rem;
}

.dashboard-page-simple {
  gap: 1rem;
  padding-bottom: 1rem;
}

.dashboard-page-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.1rem;
}

.dashboard-page-header-copy {
  display: grid;
  gap: 0.35rem;
}

.dashboard-page-header-copy h1 {
  margin: 0;
  letter-spacing: -0.05em;
  font-size: clamp(1.85rem, 3.2vw, 3rem);
}

.dashboard-page-header-copy p {
  margin: 0;
  max-width: 54rem;
  color: var(--muted);
}

.dashboard-page-header-meta {
  display: grid;
  gap: 0.65rem;
  justify-items: end;
}

.dashboard-page-updated {
  display: grid;
  gap: 0.18rem;
  text-align: right;
}

.dashboard-page-updated span,
.dashboard-summary-card span:last-child,
.dashboard-item-copy span:last-child,
.dashboard-comparison-simple span:last-child,
.dashboard-community-row p,
.dashboard-table-row span {
  color: var(--muted);
}

.dashboard-page-updated span,
.dashboard-community-votes {
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dashboard-summary-strip,
.dashboard-item-leaders,
.dashboard-comparison-grid-simple,
.dashboard-critics-grid {
  display: grid;
  gap: 0.8rem;
}

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

.dashboard-comparison-grid-simple,
.dashboard-critics-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dashboard-summary-card,
.dashboard-item-card,
.dashboard-comparison-simple,
.dashboard-community-row {
  padding: 1rem;
}

.dashboard-summary-card,
.dashboard-comparison-simple {
  display: grid;
  gap: 0.32rem;
}

.dashboard-summary-card strong,
.dashboard-comparison-simple strong,
.dashboard-item-value {
  font-size: 1.8rem;
  line-height: 0.95;
  letter-spacing: -0.05em;
}

.dashboard-item-card {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 0.8rem;
  align-items: center;
}

.dashboard-item-art {
  width: 76px;
  aspect-ratio: 0.72;
  overflow: hidden;
  border-radius: 12px;
  background: #111216;
}

.dashboard-item-art img,
.dashboard-item-art .fallback-art.small {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body[data-category-slug="uk-fruits"] .dashboard-item-art {
  background: rgba(255, 255, 255, 0.03);
}

body[data-category-slug="uk-fruits"] .dashboard-item-art img {
  object-fit: contain;
  object-position: center center;
}

.dashboard-item-copy {
  display: grid;
  gap: 0.18rem;
  min-width: 0;
}

.dashboard-item-copy strong {
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.dashboard-section {
  display: grid;
  gap: 0.8rem;
}

.dashboard-table {
  overflow: hidden;
}

.dashboard-table-head,
.dashboard-table-row {
  display: grid;
  gap: 0.7rem;
  align-items: center;
  padding: 0.85rem 1rem;
}

.dashboard-table-head {
  border-bottom: 1px solid var(--line);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-subtle);
}

.dashboard-table-row + .dashboard-table-row {
  border-top: 1px solid var(--line);
}

.dashboard-tags-table {
  grid-template-columns: minmax(180px, 1.2fr) repeat(5, minmax(0, 0.8fr));
}

.dashboard-community-list {
  display: grid;
  gap: 0.75rem;
}

.dashboard-community-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.dashboard-community-row-main {
  display: grid;
  gap: 0.22rem;
  min-width: 0;
}

.dashboard-community-row-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.dashboard-community-row-top strong {
  font-size: 1rem;
  letter-spacing: -0.03em;
}

.dashboard-community-row p {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.45;
}

.dashboard-community-chip {
  flex: 0 0 auto;
  text-decoration: none;
  max-width: min(22rem, 100%);
}

.dashboard-hero,
.dashboard-kpi-card,
.dashboard-headline-card,
.dashboard-mini-card,
.dashboard-coverage-card,
.dashboard-tier-row,
.dashboard-genre-row {
  border: 1px solid var(--line);
  background: var(--surface-strong);
}

.dashboard-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(240px, 0.72fr);
  gap: 0.8rem;
  padding: 1.2rem;
  border-radius: 28px;
  box-shadow: var(--shadow-soft);
}

.dashboard-hero-wrapped {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 80% 12%, rgba(74, 255, 184, 0.34), transparent 20%),
    radial-gradient(circle at 12% 18%, rgba(255, 189, 61, 0.2), transparent 24%),
    radial-gradient(circle at 70% 76%, rgba(255, 104, 162, 0.18), transparent 26%),
    linear-gradient(135deg, #0d1514 0%, #11211f 42%, #1c1931 100%);
  border: 1px solid rgba(179, 255, 212, 0.16);
}

.dashboard-hero-wrapped::after {
  content: "";
  position: absolute;
  inset: auto -10% -36% auto;
  width: 360px;
  aspect-ratio: 1;
  border-radius: 38% 62% 56% 44% / 42% 43% 57% 58%;
  background: linear-gradient(135deg, rgba(255, 214, 89, 0.22), rgba(74, 255, 184, 0.04));
  pointer-events: none;
  transform: rotate(-18deg);
}

.dashboard-hero-wrapped::before {
  content: "";
  position: absolute;
  inset: 1.2rem auto auto 55%;
  width: 120px;
  height: 120px;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0));
  transform: rotate(18deg);
  pointer-events: none;
}

.dashboard-hero-copy {
  display: grid;
  gap: 0.46rem;
  align-content: start;
  position: relative;
  z-index: 1;
}

.dashboard-hero-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  min-height: 2rem;
}

.dashboard-hero .eyebrow {
  margin-bottom: 0;
  padding: 0.46rem 0.78rem;
  font-size: 0.72rem;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  width: fit-content;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.dashboard-group-chip {
  display: flex;
  align-items: center;
  min-width: 0;
  margin-top: 0;
  justify-content: flex-end;
  flex: 0 1 auto;
}

.dashboard-group-chip .group-chip {
  max-width: min(22rem, 100%);
}

.dashboard-hero-copy h1,
.dashboard-section-head h2 {
  margin: 0;
  letter-spacing: -0.05em;
}

.dashboard-hero-copy h1 {
  font-size: clamp(2.2rem, 4.3vw, 4.15rem);
  line-height: 0.9;
  max-width: 8.5ch;
  text-wrap: balance;
}

.dashboard-hero-copy .hero-copy {
  max-width: 34rem;
  font-size: 0.94rem;
  line-height: 1.45;
  color: rgba(240, 244, 242, 0.82);
}

.dashboard-hero-meta {
  display: grid;
  gap: 0.65rem;
  position: relative;
  z-index: 1;
}

.dashboard-wrapped-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.35rem;
}

.dashboard-wrapped-badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.8rem;
  padding: 0.32rem 0.64rem;
  border-radius: 999px;
  background: rgba(240, 255, 230, 0.14);
  border: 1px solid rgba(240, 255, 230, 0.18);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.dashboard-wrapped-badge-soft {
  background: rgba(255, 255, 255, 0.06);
}

.dashboard-hero-stat,
.dashboard-coverage-card {
  display: grid;
  gap: 0.22rem;
  padding: 0.82rem;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02));
  border: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.dashboard-hero-stat span,
.dashboard-coverage-card span,
.dashboard-headline-card span:last-child,
.dashboard-kpi-card span:last-child,
.dashboard-section-head p,
.dashboard-mini-copy span,
.dashboard-tier-percent {
  color: var(--muted);
}

.dashboard-hero-stat span,
.dashboard-coverage-card span {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dashboard-hero-stat strong,
.dashboard-coverage-card strong,
.dashboard-kpi-card strong,
.dashboard-headline-card strong {
  font-size: 1.18rem;
  line-height: 1.04;
  letter-spacing: -0.04em;
}

.dashboard-story-grid,
.dashboard-kpi-grid,
.dashboard-headline-grid {
  display: grid;
  gap: 0.85rem;
}

.dashboard-story-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  align-items: stretch;
  grid-auto-rows: minmax(24rem, auto);
}

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

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

.dashboard-kpi-card,
.dashboard-headline-card {
  display: grid;
  gap: 0.34rem;
  padding: 1rem;
  border-radius: 14px;
}

.dashboard-story-card {
  display: grid;
  gap: 0.5rem;
  padding: 1.65rem;
  border-radius: 32px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.26);
  min-height: 24rem;
  align-content: end;
  overflow: hidden;
  position: relative;
  grid-column: span 4;
}

.dashboard-slide-index {
  position: absolute;
  top: 1rem;
  right: 1rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  color: rgba(255, 255, 255, 0.5);
}

.dashboard-slide-kicker {
  position: absolute;
  left: 1rem;
  top: 1rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.68);
}

.dashboard-story-card::before {
  content: "";
  position: absolute;
  inset: auto -10% 54% auto;
  width: 160px;
  height: 160px;
  border-radius: 32px;
  transform: rotate(16deg);
  background: rgba(255, 255, 255, 0.09);
  pointer-events: none;
}

.dashboard-story-card::after,
.dashboard-comparison-card::after {
  content: "";
  position: absolute;
  inset: auto auto -10% -8%;
  width: 52%;
  aspect-ratio: 1;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0));
  pointer-events: none;
}

.dashboard-story-card-1 {
  grid-column: span 12;
  min-height: 34rem;
  background:
    radial-gradient(circle at top right, rgba(250, 255, 156, 0.34), transparent 24%),
    radial-gradient(circle at 18% 25%, rgba(255, 168, 64, 0.3), transparent 28%),
    linear-gradient(140deg, #2a180f 0%, #3f1258 52%, #111826 100%);
}

.dashboard-story-card-2 {
  grid-column: span 6;
  min-height: 26rem;
  background:
    radial-gradient(circle at top right, rgba(84, 255, 190, 0.28), transparent 24%),
    linear-gradient(145deg, #082226 0%, #0d5148 100%);
}

.dashboard-story-card-3 {
  grid-column: span 6;
  min-height: 26rem;
  background:
    radial-gradient(circle at bottom left, rgba(255, 102, 163, 0.3), transparent 22%),
    linear-gradient(145deg, #25102a 0%, #662241 100%);
}

.dashboard-story-card strong,
.dashboard-comparison-card strong {
  font-size: 2.2rem;
  line-height: 0.84;
  letter-spacing: -0.06em;
  max-width: 8ch;
}

.dashboard-story-card .stat-label,
.dashboard-comparison-card .stat-label {
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.dashboard-story-card h2,
.dashboard-comparison-card h2 {
  margin: 0;
  font-size: 1.08rem;
  letter-spacing: -0.03em;
  max-width: 12ch;
}

.dashboard-story-card p {
  margin: 0;
  color: rgba(242, 245, 244, 0.78);
  font-size: 0.96rem;
  line-height: 1.5;
  max-width: 24ch;
}

.dashboard-story-card:first-child strong {
  font-size: clamp(5.4rem, 8vw, 8.5rem);
  max-width: 4.5ch;
}

.dashboard-story-card:first-child h2 {
  font-size: 2.1rem;
  max-width: 9ch;
}

.dashboard-comparison-card {
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015));
  min-height: 26rem;
  align-content: end;
  grid-column: span 6;
  position: relative;
  padding: 1.45rem;
  overflow: hidden;
}

.dashboard-comparison-card-1 {
  background:
    radial-gradient(circle at top right, rgba(165, 255, 203, 0.12), transparent 42%),
    linear-gradient(180deg, rgba(165, 255, 203, 0.05), rgba(255, 255, 255, 0)),
    var(--surface-strong);
}

.dashboard-comparison-card-2 {
  background:
    radial-gradient(circle at top right, rgba(255, 188, 86, 0.14), transparent 42%),
    linear-gradient(180deg, rgba(255, 188, 86, 0.05), rgba(255, 255, 255, 0)),
    var(--surface-strong);
}

.dashboard-comparison-card-3 {
  background:
    radial-gradient(circle at top right, rgba(255, 111, 168, 0.14), transparent 42%),
    linear-gradient(180deg, rgba(255, 111, 168, 0.05), rgba(255, 255, 255, 0)),
    var(--surface-strong);
}

.dashboard-layout-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  gap: 1rem;
  align-items: start;
}

.dashboard-panel {
  display: grid;
  gap: 0.95rem;
  align-content: start;
}

.dashboard-panel-wide {
  grid-column: 1 / -1;
}

.dashboard-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
}

.dashboard-section-head p {
  margin: 0;
  max-width: 34rem;
  font-size: 0.84rem;
  line-height: 1.4;
  text-align: right;
}

.dashboard-collapsible-summary {
  display: none;
}

.dashboard-collapsible-body {
  display: grid;
  gap: 0.95rem;
  padding-top: 0.2rem;
}

.dashboard-health-grid {
  display: grid;
  grid-template-columns: minmax(240px, 0.8fr) minmax(0, 1.2fr);
  gap: 1rem;
}

.dashboard-coverage-stack,
.dashboard-tier-list,
.dashboard-mini-list,
.dashboard-tabular-stack,
.dashboard-dual-list,
.dashboard-triple-list {
  display: grid;
  gap: 0.7rem;
}

.dashboard-mini-card {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 0.65rem;
  align-items: center;
  padding: 0.62rem;
  border-radius: 8px;
}

.dashboard-mini-art {
  width: 58px;
  aspect-ratio: 0.72;
  overflow: hidden;
  border-radius: 10px;
  background: #111216;
}

.dashboard-mini-art img,
.dashboard-mini-art .fallback-art.small {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body[data-category-slug="uk-fruits"] .dashboard-mini-art {
  background: rgba(255, 255, 255, 0.03);
}

body[data-category-slug="uk-fruits"] .dashboard-mini-art img {
  object-fit: contain;
  object-position: center center;
}

.dashboard-mini-copy {
  display: grid;
  gap: 0.12rem;
  min-width: 0;
}

.dashboard-mini-copy strong {
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.dashboard-mini-copy span {
  font-size: 0.78rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dashboard-group-list {
  display: grid;
  gap: 0.72rem;
}

.dashboard-community-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 0.75rem;
}

.dashboard-community-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.9rem;
  align-items: start;
  padding: 1.35rem;
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.03);
  grid-column: span 4;
  min-height: 18rem;
  align-content: space-between;
  overflow: hidden;
  position: relative;
}

.dashboard-community-card-1 {
  background:
    radial-gradient(circle at top right, rgba(74, 255, 184, 0.14), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.03);
}

.dashboard-community-card-2 {
  background:
    radial-gradient(circle at top right, rgba(255, 180, 71, 0.14), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.03);
}

.dashboard-community-card-3 {
  background:
    radial-gradient(circle at top right, rgba(255, 106, 165, 0.14), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.03);
}

.dashboard-meta-grid {
  opacity: 0.72;
  margin-top: 0;
}

.dashboard-meta-grid .dashboard-kpi-card {
  min-height: auto;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
  padding: 0.95rem 1rem;
}

.dashboard-meta-grid .dashboard-kpi-card strong {
  font-size: 1.04rem;
}

.dashboard-meta-grid .dashboard-kpi-card span:last-child {
  font-size: 0.74rem;
}

.dashboard-community-copy {
  display: grid;
  gap: 0.28rem;
  min-width: 0;
}

.dashboard-community-label {
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.68);
}

.dashboard-community-copy strong {
  line-height: 1.08;
  letter-spacing: -0.04em;
  font-size: 1.85rem;
  max-width: 11ch;
}

.dashboard-community-copy span:last-child {
  color: rgba(242, 245, 244, 0.76);
  font-size: 0.86rem;
  line-height: 1.4;
}

.dashboard-community-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 6.5rem;
  min-height: 2.6rem;
  padding: 0.48rem 1rem;
  border-radius: 999px;
  background: rgba(163, 255, 196, 0.12);
  border: 1px solid rgba(163, 255, 196, 0.18);
  color: inherit;
  text-decoration: none;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: transform 160ms ease, background-color 160ms ease, border-color 160ms ease;
  justify-self: start;
}

.dashboard-community-cta:hover {
  transform: translateY(-1px);
  background: rgba(163, 255, 196, 0.18);
  border-color: rgba(163, 255, 196, 0.28);
}

.dashboard-story-card,
.dashboard-kpi-card,
.dashboard-headline-card,
.dashboard-community-card,
.dashboard-coverage-card,
.dashboard-tier-row,
.dashboard-mini-card,
.dashboard-genre-row {
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.dashboard-story-card:hover,
.dashboard-kpi-card:hover,
.dashboard-headline-card:hover,
.dashboard-community-card:hover {
  transform: translateY(-2px);
  border-color: rgba(182, 255, 216, 0.2);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.18);
}

.dashboard-community-cta-active {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.12);
}

.dashboard-group-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.8rem;
  padding: 0.78rem 0.9rem;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface-soft);
}

.dashboard-group-copy {
  display: grid;
  gap: 0.12rem;
  min-width: 0;
}

.dashboard-group-copy strong {
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.dashboard-group-copy span {
  color: var(--muted);
  font-size: 0.8rem;
}

.dashboard-group-chip-join {
  max-width: min(22rem, 100%);
}

.dashboard-group-chip-join strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dashboard-group-chip-join .dashboard-group-join {
  text-decoration: none;
}

.dashboard-dual-list,
.dashboard-triple-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

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

.dashboard-dual-list h3,
.dashboard-tabular-stack h3,
.dashboard-triple-list h3 {
  margin: 0 0 0.55rem;
  font-size: 0.9rem;
  letter-spacing: -0.02em;
}

.dashboard-tier-row {
  display: grid;
  grid-template-columns: minmax(0, 140px) minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.8rem;
  padding: 0.72rem 0.8rem;
  border-radius: 8px;
}

.dashboard-tier-meta {
  display: grid;
  gap: 0.08rem;
}

.dashboard-tier-meta strong {
  line-height: 1.06;
}

.dashboard-tier-meta span {
  color: var(--muted);
  font-size: 0.78rem;
}

.dashboard-tier-bar {
  height: 0.7rem;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface-soft) 86%, transparent);
}

.dashboard-tier-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
}

.dashboard-tier-row.tier-poor .dashboard-tier-fill {
  background: linear-gradient(90deg, #70737d, #8b909b);
}

.dashboard-tier-row.tier-common .dashboard-tier-fill {
  background: linear-gradient(90deg, #d7dbe1, #f3f4f6);
}

.dashboard-tier-row.tier-uncommon .dashboard-tier-fill {
  background: linear-gradient(90deg, #34d399, #4ade80);
}

.dashboard-tier-row.tier-rare .dashboard-tier-fill {
  background: linear-gradient(90deg, #38bdf8, #60a5fa);
}

.dashboard-tier-row.tier-epic .dashboard-tier-fill {
  background: linear-gradient(90deg, #a855f7, #c084fc);
}

.dashboard-tier-row.tier-legendary .dashboard-tier-fill {
  background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

.dashboard-genre-table-wrap {
  overflow-x: auto;
}

.dashboard-genre-table {
  display: grid;
  min-width: 760px;
}

.dashboard-genre-head,
.dashboard-genre-row {
  display: grid;
  grid-template-columns: minmax(220px, 1.3fr) 88px 96px 110px 110px 96px;
  gap: 0.7rem;
  align-items: center;
}

.dashboard-genre-head {
  padding: 0 0.05rem 0.6rem;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dashboard-genre-row {
  padding: 0.72rem 0.05rem;
  border-bottom: 1px solid var(--line);
}

.dashboard-genre-row:last-child {
  border-bottom: 0;
}

.dashboard-genre-row span {
  font-variant-numeric: tabular-nums;
}

.mini-list,
.genre-bars {
  display: grid;
  gap: 0.8rem;
  margin-top: 1rem;
}

.mini-row {
  grid-template-columns: 36px minmax(0, 1fr) auto;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--line);
}

.mini-rank {
  font-weight: 800;
  color: var(--accent);
}

.genre-row {
  display: grid;
  gap: 0.45rem;
}

.genre-copy {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
}

.genre-copy strong {
  min-width: 0;
}

.genre-bar-track {
  height: 0.82rem;
  border-radius: 10px;
  background: #252733;
  overflow: hidden;
}


.genre-bar-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  transition: width 240ms ease;
}

.error-panel {
  padding: 1.2rem 1.4rem;
}

.message-panel h2,
.message-panel p {
  margin: 0;
}

.message-panel p + p {
  margin-top: 0.55rem;
}

@keyframes stageSweep {
  0% {
    opacity: 0.8;
  }
  100% {
    opacity: 1;
  }
}

@media (max-width: 980px) {
  .app-shell {
    width: min(100% - 1.2rem, 100%);
  }

  .stats-grid,
  .stats-grid-expanded,
  .dashboard-columns,
  .leaderboard-grid,
  .chart-header,
  .dashboard-kpi-grid,
  .dashboard-headline-grid,
  .dashboard-layout-grid,
  .dashboard-health-grid,
  .dashboard-tabular-stack,
  .dashboard-dual-list,
  .dashboard-triple-list,
  .dashboard-hero {
    grid-template-columns: 1fr;
  }

  .chart-header-meta {
    justify-items: start;
    text-align: left;
  }

  .chart-header-actions {
    justify-content: flex-start;
  }

  .dashboard-section-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .dashboard-section-head p {
    max-width: none;
    text-align: left;
  }

  .leaderboard-filters {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .app-shell {
    padding-top: 0.62rem;
  }

  .site-header {
    top: 0.62rem;
    gap: 0.55rem;
    padding: 0.7rem 0.72rem;
  }

  .site-header-actions {
    flex: 1 1 auto;
    min-width: 0;
    gap: 0.28rem;
    justify-content: flex-end;
  }

  .site-nav {
    flex: 1 1 auto;
    width: auto;
    max-width: none;
    gap: 0.22rem;
    justify-content: flex-end;
  }

  .site-nav a {
    min-height: 2.45rem;
    padding: 0.62rem 0.72rem;
    font-size: 0.78rem;
  }

  .site-nav-toggle {
    min-height: 2.45rem;
    padding: 0.62rem 0.72rem;
    font-size: 0.78rem;
  }

  .vote-page,
  .leaderboard-page,
  .dashboard-page {
    gap: 0.9rem;
    margin-top: 0.95rem;
  }

  .leaderboard-list,
  .panel,
  .stats-grid,
  .hero-panel,
  .dashboard-hero,
  .dashboard-kpi-card,
  .dashboard-headline-card {
    border-radius: 8px;
  }

  .card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.72rem;
  }

  .vote-stage {
    padding: 0.88rem;
  }

  .card-frame {
    grid-template-rows: auto minmax(102px, auto);
  }

  .card-chip-row {
    gap: 0.36rem;
  }

  .card-chip-row span {
    min-height: 1.74rem;
    padding: 0.28rem 0.52rem;
    font-size: 0.7rem;
  }

  .skip-button {
    width: 100%;
  }

  .group-bar,
  .group-drawer,
  .group-share,
  .group-form,
  .group-form-actions {
    align-items: stretch;
  }

  .group-bar,
  .group-bar-state,
  .group-bar-actions,
  .group-share,
  .group-form,
  .group-input-row {
    width: 100%;
  }

  .group-bar {
    flex-direction: column;
  }

  .group-bar-shell {
    gap: 0.1rem;
  }

  .group-bar-state,
  .group-bar-actions {
    justify-content: space-between;
  }

  .group-bar-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
  }

  .group-bar-button {
    width: 100%;
    text-align: center;
  }

  .group-drawer {
    display: grid;
    flex-direction: column;
    gap: 0.3rem;
    margin-top: 0;
    padding: 0.45rem 0.55rem;
  }

  .group-form,
  .group-share {
    gap: 0.3rem;
    margin: 0;
  }

  .group-share input,
  .group-form input {
    min-width: 0;
    width: 100%;
  }

  .group-input-row {
    gap: 0.45rem;
  }

  .group-input-row button {
    flex-basis: 8.25rem;
    min-width: 8.25rem;
    padding-inline: 0.85rem;
  }

  .group-share button[data-group-share-native] {
    width: 100%;
    align-self: stretch;
  }

  .group-panel-label {
    line-height: 1.1;
  }

  .leaderboard-row {
    grid-template-columns: 40px 74px minmax(0, 1fr);
    gap: 0.8rem;
  }

  .chart-table-head,
  .leaderboard-row-chart {
    grid-template-columns: 52px 52px minmax(0, 1fr) 54px;
    gap: 0.62rem;
  }

  .leaderboard-rank-number {
    font-size: 1.42rem;
  }

  .leaderboard-art {
    width: 70px;
  }

  .leaderboard-entry {
    grid-template-columns: 70px minmax(0, 1fr);
    gap: 0.72rem;
  }

  .leaderboard-football-head,
  .leaderboard-football-row {
    grid-template-columns: 46px minmax(230px, 1.7fr) 66px 50px 50px 66px 68px 108px;
    gap: 0.45rem;
  }

  .table-game {
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 0.6rem;
  }

  .table-game .leaderboard-art {
    width: 52px;
  }

  .dashboard-hero {
    padding: 1rem;
    border-radius: 22px;
  }

  .dashboard-hero-copy h1 {
    max-width: none;
  }

  .dashboard-story-grid,
  .dashboard-kpi-grid,
  .dashboard-headline-grid,
  .dashboard-community-grid,
  .dashboard-layout-grid {
    gap: 0.75rem;
  }

  .dashboard-story-card:first-child {
    grid-column: span 12;
  }

  .dashboard-story-card {
    grid-column: span 6;
    min-height: 24rem;
  }

  .dashboard-comparison-card {
    grid-column: span 6;
  }

  .dashboard-community-card {
    grid-column: span 6;
    min-height: 15rem;
  }

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

  .dashboard-collapsible {
    gap: 0;
    overflow: hidden;
  }

  .dashboard-collapsible-summary {
    display: grid;
    gap: 0.14rem;
    padding: 0.82rem 0.9rem;
    cursor: pointer;
    list-style: none;
    background: var(--surface-strong);
  }

  .dashboard-collapsible-summary::-webkit-details-marker {
    display: none;
  }

  .dashboard-collapsible-summary::after {
    content: "+";
    position: absolute;
    right: 0.9rem;
    top: 0.92rem;
    font-size: 1rem;
    color: var(--muted);
  }

  .dashboard-collapsible[open] .dashboard-collapsible-summary::after {
    content: "-";
  }

  .dashboard-collapsible-summary {
    position: relative;
    padding-right: 2.2rem;
  }

  .dashboard-collapsible-kicker {
    color: var(--muted);
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .dashboard-collapsible-summary strong {
    font-size: 0.95rem;
    letter-spacing: -0.03em;
  }

  .dashboard-collapsible-summary span:last-child {
    color: var(--muted);
    font-size: 0.76rem;
    line-height: 1.35;
  }

  .dashboard-collapsible-body {
    padding: 0 0.9rem 0.9rem;
  }

  .dashboard-collapsible:not([open]) .dashboard-collapsible-body {
    display: none;
  }

  .dashboard-collapsible .dashboard-section-head {
    display: none;
  }

  .dashboard-page-header {
    grid-template-columns: 1fr;
    display: grid;
  }

  .dashboard-page-header-meta {
    justify-items: start;
  }

  .dashboard-summary-strip,
  .dashboard-item-leaders {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-comparison-grid-simple,
  .dashboard-critics-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-tags-table {
    grid-template-columns: minmax(140px, 1.2fr) repeat(5, minmax(0, 0.8fr));
  }

  .dashboard-community-row {
    align-items: start;
    flex-direction: column;
  }
}

@media (max-width: 540px) {
  .app-shell {
    width: calc(100% - 0.75rem);
  }

  .site-header {
    padding: 0.62rem;
    gap: 0.45rem;
  }

  .brand-wordmark {
    font-size: 0.98rem;
  }

  .site-nav a {
    min-height: 2.28rem;
    padding-inline: 0.52rem;
    font-size: 0.72rem;
  }

  .site-nav-toggle {
    min-height: 2.28rem;
    padding-inline: 0.52rem;
    font-size: 0.72rem;
  }

  .site-header-actions {
    justify-content: flex-end;
  }

  .site-nav {
    justify-content: flex-end;
  }


  .dashboard-hero .eyebrow {
    display: none;
  }

  .dashboard-page-header {
    padding: 0.82rem;
  }

  .dashboard-page-header-copy h1 {
    font-size: 1.62rem;
    line-height: 0.96;
  }

  .dashboard-page-header-copy p {
    font-size: 0.88rem;
    line-height: 1.45;
  }

  .dashboard-summary-strip,
  .dashboard-item-leaders,
  .dashboard-comparison-grid-simple,
  .dashboard-critics-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-summary-card,
  .dashboard-item-card,
  .dashboard-comparison-simple,
  .dashboard-community-row {
    padding: 0.82rem;
  }

  .dashboard-item-card {
    grid-template-columns: 60px minmax(0, 1fr);
    gap: 0.65rem;
  }

  .dashboard-item-art {
    width: 60px;
    border-radius: 10px;
  }

  .dashboard-summary-card strong,
  .dashboard-comparison-simple strong,
  .dashboard-item-value {
    font-size: 1.48rem;
  }

  .dashboard-table {
    overflow-x: auto;
  }

  .dashboard-table-head,
  .dashboard-table-row {
    min-width: 640px;
  }

  .dashboard-community-chip {
    width: 100%;
    max-width: 100%;
    justify-content: space-between;
  }

  .dashboard-hero {
    padding: 0.82rem;
    gap: 0.82rem;
    border-radius: 16px;
  }

  .dashboard-hero-topline {
    gap: 0.55rem;
    min-height: 0;
  }

  .dashboard-hero-copy {
    gap: 0.28rem;
  }

  .dashboard-hero-copy h1 {
    font-size: 1.66rem;
    line-height: 0.96;
    max-width: none;
  }

  .dashboard-hero-copy .hero-copy {
    font-size: 0.84rem;
    line-height: 1.48;
  }

  .dashboard-wrapped-badge-row {
    gap: 0.4rem;
  }

  .dashboard-wrapped-badge {
    min-height: 1.85rem;
    padding: 0.34rem 0.64rem;
    font-size: 0.68rem;
  }

  .dashboard-group-chip .group-chip {
    max-width: 100%;
  }

  .dashboard-group-list {
    gap: 0.6rem;
  }

  .dashboard-group-card {
    padding: 0.72rem 0.78rem;
    gap: 0.68rem;
  }

  .dashboard-group-copy span {
    font-size: 0.76rem;
  }

  .dashboard-group-chip-join {
    max-width: 100%;
  }

  .dashboard-hero-meta {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.45rem;
  }

  .dashboard-hero-stat,
  .dashboard-coverage-card {
    padding: 0.72rem;
  }

  .dashboard-hero-stat strong,
  .dashboard-coverage-card strong,
  .dashboard-kpi-card strong,
  .dashboard-headline-card strong {
    font-size: 1.05rem;
  }

  .dashboard-hero-stat span,
  .dashboard-coverage-card span {
    font-size: 0.62rem;
  }

  .dashboard-kpi-card,
  .dashboard-headline-card {
    padding: 0.78rem;
  }

  .dashboard-story-card {
    padding: 1rem;
    border-radius: 18px;
    min-height: 72svh;
  }

  .dashboard-story-card strong,
  .dashboard-comparison-card strong {
    font-size: 1.58rem;
  }

  .dashboard-story-card:first-child strong {
    font-size: clamp(3.6rem, 18vw, 5rem);
  }

  .dashboard-story-card:first-child h2 {
    font-size: 1.5rem;
  }

  .dashboard-story-card h2,
  .dashboard-comparison-card h2 {
    font-size: 1rem;
  }

  .dashboard-mini-card {
    grid-template-columns: 50px minmax(0, 1fr);
    gap: 0.55rem;
    padding: 0.56rem;
  }

  .dashboard-mini-art {
    width: 50px;
  }

  .dashboard-mini-copy span {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }

  .dashboard-story-grid,
  .dashboard-kpi-grid,
  .dashboard-headline-grid,
  .dashboard-community-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-story-card:first-child {
    grid-column: auto;
  }

  .dashboard-story-card,
  .dashboard-comparison-card,
  .dashboard-community-card {
    grid-column: auto;
  }

  .dashboard-story-card-1,
  .dashboard-story-card-2,
  .dashboard-story-card-3 {
    min-height: 72svh;
  }

  .dashboard-comparison-card,
  .dashboard-community-card {
    min-height: 56svh;
  }

  .dashboard-meta-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-slide-index {
    top: 0.82rem;
    right: 0.82rem;
    font-size: 0.64rem;
  }

  .dashboard-community-card {
    padding: 0.9rem 0.92rem;
    border-radius: 16px;
  }

  .dashboard-community-cta {
    min-width: 3.1rem;
    min-height: 2rem;
    padding: 0.34rem 0.65rem;
    font-size: 0.7rem;
  }

  .hero-panel {
    padding: 1.1rem;
  }

  .hero-panel h1 {
    font-size: clamp(1.45rem, 8vw, 1.95rem);
    max-width: none;
  }

  .chart-header {
    padding: 0.68rem 0.76rem;
    gap: 0.38rem;
  }

  .chart-header-copy {
    gap: 0.08rem;
  }

  .chart-header .eyebrow,
  .chart-header .hero-copy {
    display: none;
  }

  .chart-header h1 {
    font-size: 1.04rem;
    line-height: 1.05;
    letter-spacing: -0.04em;
  }

  .chart-header-meta {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    justify-items: start;
    gap: 0.02rem 0.52rem;
    text-align: left;
  }

  .chart-header-actions {
    grid-column: 2;
    grid-row: 1 / span 2;
    width: 100%;
    margin-top: 0;
    gap: 0.28rem;
    justify-content: flex-end;
    flex-wrap: wrap;
    overflow: visible;
    padding-bottom: 0;
    scrollbar-width: none;
  }

  .table-header-group {
    width: 100%;
    justify-content: flex-end;
    order: -1;
    margin-bottom: 0.12rem;
  }

  .table-header-group .group-chip {
    max-width: 100%;
  }

  .chart-header-actions::-webkit-scrollbar {
    display: none;
  }

  .chart-header-actions .pager-link {
    padding: 0.42rem 0.56rem;
    font-size: 0.68rem;
    white-space: nowrap;
  }

  .chart-header-actions .pager-link:nth-child(2) {
    display: none;
  }

  .leaderboard-toolbar {
    padding: 0.56rem 0.72rem;
  }

  .leaderboard-filter-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.68rem;
    padding: 0.62rem 0.72rem;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.03);
    color: var(--ink);
    font: inherit;
    text-align: left;
  }

  .leaderboard-filter-toggle span:first-child {
    font-weight: 700;
    font-size: 0.92rem;
  }

  .leaderboard-filter-toggle-meta {
    color: var(--muted);
    font-size: 0.72rem;
  }

  .leaderboard-toolbar:not(.is-open) .leaderboard-filters {
    display: none;
  }

  .leaderboard-toolbar.is-open .leaderboard-filters {
    display: grid;
    margin-top: 0.56rem;
    gap: 0.62rem;
  }

  .leaderboard-table-wrap {
    padding: 0.35rem 0.72rem 0.72rem;
  }

  .leaderboard-football-head {
    display: none;
  }

  .leaderboard-football-row {
    grid-template-columns: 36px minmax(0, 1fr) 28px;
    gap: 0.55rem;
    align-items: start;
    padding: 0.82rem 0;
    cursor: pointer;
  }

  .table-pos {
    font-size: 1rem;
    padding-top: 0.18rem;
  }

  .table-game {
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 0.58rem;
    margin-bottom: 0;
  }

  .table-game-copy {
    gap: 0.1rem;
  }

  .table-game-copy strong {
    font-size: 0.95rem;
    line-height: 1.18;
  }

  .table-game-copy span,
  .table-stat,
  .table-stat-elo,
  .table-form {
    display: none;
  }

  .table-mobile-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    margin-top: 0.22rem;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.03);
    color: var(--muted);
    font: inherit;
    font-size: 1rem;
    line-height: 1;
  }

  .leaderboard-football-row.is-expanded .table-mobile-toggle {
    color: var(--ink);
    border-color: rgba(255, 255, 255, 0.2);
  }

  .table-mobile-details {
    display: none;
    grid-column: 2 / span 2;
    margin-top: 0.68rem;
    padding: 0.72rem 0.78rem;
    border-top: 1px solid var(--line);
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.62rem 0.72rem;
  }

  .leaderboard-football-row.is-expanded .table-mobile-details {
    display: grid;
  }

  .table-mobile-detail {
    display: grid;
    gap: 0.16rem;
  }

  .table-mobile-detail span {
    color: var(--muted);
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .table-mobile-detail strong {
    font-size: 0.95rem;
    line-height: 1.15;
  }

  .table-mobile-detail-form {
    grid-column: 1 / -1;
  }

  .table-mobile-form {
    display: flex;
    flex-wrap: wrap;
    gap: 0.28rem;
  }

  .chart-table-head {
    display: none;
  }

  .leaderboard-row-chart {
    grid-template-columns: 42px 46px minmax(0, 1fr);
    align-items: start;
    gap: 0.52rem;
    padding: 0.72rem 0;
  }

  .chart-peak {
    grid-column: 3;
    justify-items: start;
    justify-self: start;
    grid-template-columns: auto auto;
    gap: 0.35rem;
    align-items: baseline;
  }

  .chart-peak .chart-stat-label {
    font-size: 0.6rem;
  }

  .leaderboard-entry {
    grid-template-columns: 60px minmax(0, 1fr);
    gap: 0.58rem;
    align-items: start;
  }

  .leaderboard-art {
    width: 60px;
  }

  .chart-move {
    padding-top: 0.18rem;
  }

  .chart-move-arrow {
    font-size: 0.82rem;
  }

  .chart-move-value {
    font-size: 0.56rem;
  }

  .leaderboard-main strong {
    min-height: auto;
  }

  .leaderboard-main span {
    white-space: normal;
  }

  .chart-header-meta strong {
    font-size: 0.78rem;
  }

  .chart-header-meta span {
    font-size: 0.7rem;
  }

  .vs-banner {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.3rem;
  }

  .card-frame {
    border-radius: 16px;
  }

  .card-art {
    aspect-ratio: 0.72;
  }

  .card-body {
    gap: 0.5rem;
    padding: 0.68rem;
  }

  .developer-metric {
    font-size: 0.72rem;
  }

  .developer-metric strong {
    font-size: 0.8rem;
  }

  .developer-dock {
    padding-top: 0.85rem;
  }

  .developer-dock-header {
    align-items: flex-start;
    flex-direction: column;
    gap: 0.22rem;
  }

  .developer-dock-grid {
    gap: 0.5rem;
  }

  .developer-dock-column {
    gap: 0.38rem;
  }

  .developer-dock-game strong {
    font-size: 0.8rem;
  }

  .developer-metric-list {
    gap: 0.28rem;
  }

  .developer-metric {
    min-height: 2.7rem;
    padding: 0.34rem 0.38rem;
    font-size: 0.56rem;
  }

  .developer-metric strong {
    font-size: 0.8rem;
  }

  .developer-form {
    gap: 0.18rem;
    padding-top: 0.12rem;
  }

  .developer-form-pill {
    min-width: 1.16rem;
    height: 1.16rem;
    font-size: 0.54rem;
  }

  .card-title {
    font-size: 0.96rem;
    min-height: 2.35em;
  }

  .card-chip-row {
    gap: 0.28rem;
  }

  .card-chip-row span {
    min-height: 1.56rem;
    padding: 0.22rem 0.42rem;
    font-size: 0.64rem;
  }

  .stats-grid,
  .stats-grid-expanded {
    gap: 0.75rem;
    padding: 0.78rem;
  }

  .stat-card {
    min-height: 0;
    padding: 0.92rem;
  }

  .leaderboard-row {
    grid-template-columns: 36px 66px minmax(0, 1fr);
  }

  .leaderboard-rank {
    width: 2.5rem;
    min-height: 2.5rem;
  }

  .leaderboard-rank-number {
    font-size: 1.18rem;
  }

  .leaderboard-rank-suffix {
    font-size: 0.62rem;
  }

  .leaderboard-art {
    width: 66px;
  }

  .panel-header,
  .genre-copy {
    flex-direction: column;
    align-items: flex-start;
  }

  .dashboard-columns {
    gap: 0.75rem;
  }

  .dashboard-hero {
    padding: 0.82rem;
    gap: 0.8rem;
  }

  .dashboard-hero-copy {
    gap: 0.28rem;
  }

  .dashboard-hero-copy h1 {
    font-size: 1.26rem;
    line-height: 1.04;
  }

  .dashboard-hero-meta {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.45rem;
  }

  .dashboard-hero-stat,
  .dashboard-coverage-card,
  .dashboard-kpi-card,
  .dashboard-headline-card {
    padding: 0.75rem;
  }

  .dashboard-hero-stat strong,
  .dashboard-coverage-card strong,
  .dashboard-kpi-card strong,
  .dashboard-headline-card strong {
    font-size: 1.04rem;
  }

  .dashboard-mini-card {
    grid-template-columns: 50px minmax(0, 1fr);
    gap: 0.55rem;
    padding: 0.55rem;
  }

  .dashboard-mini-art {
    width: 50px;
  }

  .dashboard-mini-copy span {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }

  .dashboard-tier-row {
    grid-template-columns: 1fr;
    gap: 0.45rem;
  }

  .dashboard-tier-percent {
    justify-self: start;
  }

  .dashboard-genre-table {
    min-width: 620px;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
