/* Hall of Fame — arcade leaderboard with mesh gradient, glassmorphism, neon, particles */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&family=Press+Start+2P&family=VT323&display=swap');

/* Arcade — purple/cyan neon */
html[data-theme="arcade"] {
  --hof-bg:
    radial-gradient(ellipse 120% 80% at 10% 10%, rgba(88, 28, 135, 0.9) 0%, transparent 50%),
    radial-gradient(ellipse 80% 120% at 90% 90%, rgba(59, 7, 100, 0.85) 0%, transparent 50%),
    radial-gradient(ellipse 100% 60% at 50% 0%, rgba(67, 56, 202, 0.6) 0%, transparent 45%),
    linear-gradient(160deg, #0f0a1a 0%, #1a0a2e 30%, #0d0d1a 70%, #0a0a14 100%);
  --hof-accent-cyan: #06b6d4;
  --hof-accent-pink: #ec4899;
  --hof-accent-lime: #84cc16;
  --hof-title: #fbbf24;
  --hof-subtitle: rgba(255, 255, 255, 0.7);
  --hof-toggle-bg: rgba(0, 0, 0, 0.4);
  --hof-toggle-border: rgba(255, 255, 255, 0.1);
  --hof-toggle-text: rgba(255, 255, 255, 0.6);
  --hof-toggle-text-hover: rgba(255, 255, 255, 0.9);
  --hof-toggle-active-text: #ffffff;
  --hof-toggle-active-bg: linear-gradient(135deg, rgba(6, 182, 212, 0.4), rgba(236, 72, 153, 0.3));
  --hof-toggle-active-shadow: 0 0 20px rgba(6, 182, 212, 0.3);
  --hof-board-bg: rgba(255, 255, 255, 0.06);
  --hof-board-border: rgba(255, 255, 255, 0.12);
  --hof-board-glow: rgba(132, 204, 22, 0.08);
  --hof-row-hover-bg: rgba(255, 255, 255, 0.08);
  --hof-rank: #fbbf24;
  --hof-avatar-border: rgba(251, 191, 36, 0.5);
  --hof-avatar-placeholder-bg: rgba(255, 255, 255, 0.1);
  --hof-avatar-placeholder-border: rgba(255, 255, 255, 0.2);
  --hof-avatar-placeholder-text: rgba(255, 255, 255, 0.5);
  --hof-name: #ffffff;
  --hof-stat: #84cc16;
  --hof-empty-name: rgba(255, 255, 255, 0.3);
  --hof-empty-stat: rgba(255, 255, 255, 0.2);
  --hof-link: #06b6d4;
  --hof-link-hover: #22d3ee;
}

/* Retro — vector arcade / cab CRT (Asteroids, Galaga, Pac-Man vibes) */
html[data-theme="retro"] {
  --hof-bg:
    radial-gradient(ellipse 100% 80% at 50% 120%, rgba(0, 40, 20, 0.45) 0%, transparent 55%),
    radial-gradient(ellipse 80% 60% at 20% 10%, rgba(0, 255, 200, 0.06) 0%, transparent 45%),
    repeating-linear-gradient(
      0deg,
      transparent 0,
      transparent 2px,
      rgba(0, 255, 170, 0.03) 2px,
      rgba(0, 255, 170, 0.03) 3px
    ),
    linear-gradient(180deg, #020408 0%, #0a1620 45%, #050810 100%);
  --hof-accent-cyan: #00ffc8;
  --hof-accent-pink: #ff6b9d;
  --hof-accent-lime: #ccff00;
  --hof-title: #ffcc00;
  --hof-subtitle: rgba(0, 255, 200, 0.75);
  --hof-toggle-bg: rgba(0, 20, 30, 0.85);
  --hof-toggle-border: rgba(0, 255, 200, 0.35);
  --hof-toggle-text: rgba(0, 200, 180, 0.65);
  --hof-toggle-text-hover: rgba(255, 255, 200, 0.95);
  --hof-toggle-active-text: #0a0f0a;
  --hof-toggle-active-bg: linear-gradient(135deg, rgba(255, 204, 0, 0.95), rgba(255, 140, 0, 0.85));
  --hof-toggle-active-shadow: 0 0 14px rgba(255, 200, 0, 0.55);
  --hof-board-bg: rgba(0, 12, 8, 0.72);
  --hof-board-border: rgba(0, 255, 200, 0.28);
  --hof-board-glow: rgba(0, 255, 180, 0.15);
  --hof-row-hover-bg: rgba(0, 60, 45, 0.45);
  --hof-rank: #ffcc00;
  --hof-avatar-border: rgba(255, 204, 0, 0.55);
  --hof-avatar-placeholder-bg: rgba(0, 40, 30, 0.6);
  --hof-avatar-placeholder-border: rgba(0, 255, 200, 0.35);
  --hof-avatar-placeholder-text: rgba(0, 255, 200, 0.45);
  --hof-name: #e8fff8;
  --hof-stat: #7dff7d;
  --hof-empty-name: rgba(0, 180, 140, 0.35);
  --hof-empty-stat: rgba(0, 120, 100, 0.28);
  --hof-link: #00ffc8;
  --hof-link-hover: #ffff88;
}

html[data-theme="dark"] {
  --hof-bg:
    radial-gradient(ellipse 120% 80% at 10% 10%, rgba(51, 65, 85, 0.7) 0%, transparent 56%),
    radial-gradient(ellipse 95% 100% at 88% 14%, rgba(30, 41, 59, 0.72) 0%, transparent 58%),
    radial-gradient(ellipse 90% 110% at 84% 88%, rgba(71, 85, 105, 0.45) 0%, transparent 62%),
    linear-gradient(160deg, #0b1017 0%, #101826 38%, #0f1722 68%, #090f16 100%);
  --hof-accent-cyan: #0891b2;
  --hof-accent-pink: #a855f7;
  --hof-accent-lime: #65a30d;
  --hof-title: #c4b5fd;
  --hof-subtitle: rgba(226, 232, 240, 0.74);
  --hof-toggle-bg: rgba(8, 12, 20, 0.56);
  --hof-toggle-border: rgba(148, 163, 184, 0.2);
  --hof-toggle-text: rgba(226, 232, 240, 0.62);
  --hof-toggle-text-hover: rgba(241, 245, 249, 0.92);
  --hof-toggle-active-text: #f8fafc;
  --hof-toggle-active-bg: linear-gradient(135deg, rgba(56, 189, 248, 0.34), rgba(168, 85, 247, 0.28));
  --hof-toggle-active-shadow: 0 0 20px rgba(56, 189, 248, 0.22);
  --hof-board-bg: rgba(15, 23, 42, 0.5);
  --hof-board-border: rgba(148, 163, 184, 0.18);
  --hof-board-glow: rgba(56, 189, 248, 0.1);
  --hof-row-hover-bg: rgba(51, 65, 85, 0.36);
  --hof-rank: #c4b5fd;
  --hof-avatar-border: rgba(148, 163, 184, 0.4);
  --hof-avatar-placeholder-bg: rgba(51, 65, 85, 0.38);
  --hof-avatar-placeholder-border: rgba(148, 163, 184, 0.3);
  --hof-avatar-placeholder-text: rgba(203, 213, 225, 0.66);
  --hof-name: #f1f5f9;
  --hof-stat: #a3e635;
  --hof-empty-name: rgba(203, 213, 225, 0.45);
  --hof-empty-stat: rgba(148, 163, 184, 0.38);
  --hof-link: #38bdf8;
  --hof-link-hover: #67e8f9;
}

html[data-theme="default"] {
  --hof-bg:
    radial-gradient(ellipse 120% 80% at 8% 8%, rgba(196, 181, 253, 0.8) 0%, transparent 55%),
    radial-gradient(ellipse 100% 80% at 92% 12%, rgba(103, 232, 249, 0.45) 0%, transparent 55%),
    radial-gradient(ellipse 90% 100% at 88% 88%, rgba(244, 114, 182, 0.38) 0%, transparent 55%),
    linear-gradient(160deg, #f6f2ff 0%, #ebe8ff 38%, #e0f2ff 74%, #f8f5ff 100%);
  --hof-accent-cyan: #0891b2;
  --hof-accent-pink: #be185d;
  --hof-accent-lime: #4d7c0f;
  --hof-title: #7c3aed;
  --hof-subtitle: rgba(30, 41, 59, 0.74);
  --hof-toggle-bg: rgba(255, 255, 255, 0.7);
  --hof-toggle-border: rgba(124, 58, 237, 0.18);
  --hof-toggle-text: rgba(30, 41, 59, 0.7);
  --hof-toggle-text-hover: rgba(30, 41, 59, 0.95);
  --hof-toggle-active-text: #1e1b4b;
  --hof-toggle-active-bg: linear-gradient(135deg, rgba(103, 232, 249, 0.45), rgba(216, 180, 254, 0.55));
  --hof-toggle-active-shadow: 0 0 16px rgba(124, 58, 237, 0.2);
  --hof-board-bg: rgba(255, 255, 255, 0.58);
  --hof-board-border: rgba(124, 58, 237, 0.16);
  --hof-board-glow: rgba(124, 58, 237, 0.1);
  --hof-row-hover-bg: rgba(255, 255, 255, 0.65);
  --hof-rank: #7c3aed;
  --hof-avatar-border: rgba(124, 58, 237, 0.35);
  --hof-avatar-placeholder-bg: rgba(124, 58, 237, 0.12);
  --hof-avatar-placeholder-border: rgba(124, 58, 237, 0.24);
  --hof-avatar-placeholder-text: rgba(67, 56, 202, 0.55);
  --hof-name: #1e293b;
  --hof-stat: #166534;
  --hof-empty-name: rgba(30, 41, 59, 0.42);
  --hof-empty-stat: rgba(30, 41, 59, 0.28);
  --hof-link: #0e7490;
  --hof-link-hover: #0284c7;
}

.hof-page {
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  font-family: 'Inter', sans-serif;
}

/* Mesh gradient background */
.hof-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  background: var(--hof-bg);
}

/* Neon corner accents */
.hof-bg::before,
.hof-bg::after {
  content: '';
  position: absolute;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.5;
  pointer-events: none;
}
.hof-bg::before {
  top: -100px;
  left: -100px;
  background: var(--hof-accent-cyan);
  box-shadow: 0 0 120px var(--hof-accent-cyan);
}
.hof-bg::after {
  bottom: -100px;
  right: -100px;
  background: var(--hof-accent-pink);
  box-shadow: 0 0 120px var(--hof-accent-pink);
}

/* Floating particles */
.hof-particles {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}
.hof-particle {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  animation: hof-float 15s infinite ease-in-out;
}
.hof-particle:nth-child(1) { left: 10%; top: 20%; background: var(--hof-accent-cyan); animation-delay: 0s; }
.hof-particle:nth-child(2) { left: 85%; top: 15%; background: var(--hof-accent-pink); animation-delay: -2s; }
.hof-particle:nth-child(3) { left: 50%; top: 80%; background: var(--hof-accent-lime); animation-delay: -4s; }
.hof-particle:nth-child(4) { left: 25%; top: 60%; background: var(--hof-accent-cyan); animation-delay: -6s; }
.hof-particle:nth-child(5) { left: 70%; top: 40%; background: var(--hof-accent-pink); animation-delay: -8s; }
.hof-particle:nth-child(6) { left: 15%; top: 85%; background: var(--hof-accent-lime); animation-delay: -3s; }
.hof-particle:nth-child(7) { left: 90%; top: 70%; background: var(--hof-accent-cyan); animation-delay: -5s; }
.hof-particle:nth-child(8) { left: 40%; top: 10%; background: var(--hof-accent-pink); animation-delay: -7s; }
@keyframes hof-float {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.6; }
  25% { transform: translate(20px, -30px) scale(1.2); opacity: 1; }
  50% { transform: translate(-15px, 20px) scale(0.9); opacity: 0.7; }
  75% { transform: translate(30px, 10px) scale(1.1); opacity: 0.9; }
}

/* Content above bg — width constrained by .hof-cabinet */
.hof-content {
  position: relative;
  z-index: 2;
  padding: 2rem 2rem 4rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  margin: 0 auto;
}

/* Arcade title */
.hof-title {
  font-family: 'Press Start 2P', cursive;
  font-size: clamp(1rem, 4vw, 1.5rem);
  color: var(--hof-title);
  text-shadow: 0 0 20px rgba(251, 191, 36, 0.6);
  margin-bottom: 0.5rem;
  letter-spacing: 0.1em;
}

.hof-subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 1.1rem;
  color: var(--hof-subtitle);
  margin-bottom: 1.75rem;
}

/* Toggle */
.hof-toggle-wrap {
  display: flex;
  gap: 0;
  background: var(--hof-toggle-bg);
  border-radius: 14px;
  padding: 6px;
  border: 1px solid var(--hof-toggle-border);
  margin-bottom: 1.75rem;
}
.hof-toggle-btn {
  font-family: 'Press Start 2P', cursive;
  font-size: clamp(0.5rem, 1.8vw, 0.7rem);
  padding: 0.65rem 1rem;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  background: transparent;
  color: var(--hof-toggle-text);
  transition: all 0.2s ease;
}
.hof-toggle-btn:hover {
  color: var(--hof-toggle-text-hover);
}
.hof-toggle-btn.active {
  background: var(--hof-toggle-active-bg);
  color: var(--hof-toggle-active-text);
  box-shadow: var(--hof-toggle-active-shadow);
}

/* Glassmorphism leaderboard container — wider, more padding */
.hof-board {
  width: 100%;
  max-width: 100%;
  background: var(--hof-board-bg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--hof-board-border);
  border-radius: 20px;
  padding: 1.75rem 2rem;
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.4),
    0 0 40px var(--hof-board-glow),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

/* Row — bigger spacing and tap target */
.hof-row {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 0.9rem 1rem;
  margin-bottom: 8px;
  border-radius: 12px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  position: relative;
  overflow: hidden;
}
.hof-row:last-child { margin-bottom: 0; }
.hof-row.empty {
  opacity: 0.4;
}
.hof-row:not(.empty):hover {
  transform: scale(1.02) translateX(8px);
  background: var(--hof-row-hover-bg);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
  animation: hof-shake 0.4s ease;
}
.hof-row:not(.empty):hover::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 0%,
    rgba(255, 255, 255, 0.15) 45%,
    rgba(255, 255, 255, 0.25) 50%,
    rgba(255, 255, 255, 0.15) 55%,
    transparent 100%
  );
  animation: hof-sweep 0.5s ease;
  pointer-events: none;
}
@keyframes hof-shake {
  0%, 100% { transform: scale(1.02) translateX(8px); }
  20% { transform: scale(1.02) translateX(12px); }
  40% { transform: scale(1.02) translateX(4px); }
  60% { transform: scale(1.02) translateX(10px); }
  80% { transform: scale(1.02) translateX(6px); }
}
@keyframes hof-sweep {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

/* Rank */
.hof-rank {
  font-family: 'Press Start 2P', cursive;
  font-size: clamp(0.65rem, 2vw, 0.85rem);
  min-width: 3rem;
  color: var(--hof-rank);
  text-shadow: 0 0 10px rgba(251, 191, 36, 0.4);
}

/* Avatar — larger */
.hof-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--hof-avatar-border);
  flex-shrink: 0;
}
.hof-avatar-placeholder {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--hof-avatar-placeholder-bg);
  border: 2px solid var(--hof-avatar-placeholder-border);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Press Start 2P', cursive;
  font-size: 0.65rem;
  color: var(--hof-avatar-placeholder-text);
}

/* Name & stat — larger type */
.hof-name {
  flex: 1;
  font-weight: 600;
  font-size: clamp(1rem, 2vw, 1.2rem);
  color: var(--hof-name);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.hof-stat {
  font-weight: 700;
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  color: var(--hof-stat);
  text-shadow: 0 0 12px rgba(132, 204, 22, 0.5);
}

/* Empty slot */
.hof-row.empty .hof-name { color: var(--hof-empty-name); }
.hof-row.empty .hof-stat { color: var(--hof-empty-stat); }

/* Link to winners circle */
.hof-footer {
  margin-top: 2rem;
  text-align: center;
}
.hof-footer a {
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  color: var(--hof-link);
  text-decoration: none;
  transition: color 0.2s, text-shadow 0.2s;
}
.hof-footer a:hover {
  color: var(--hof-link-hover);
  text-shadow: 0 0 12px rgba(6, 182, 212, 0.5);
}

/* -------------------------------------------------------------------------- */
/* Cabinet shell + CRT (structure always present; Retro theme styles it)       */
/* -------------------------------------------------------------------------- */

.hof-cabinet {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: min(960px, 92vw);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.hof-cabinet-marquee,
.hof-cabinet-plinth {
  display: none;
}

.hof-crt {
  position: relative;
  width: 100%;
}

/* Pac-style bezel SVG (square); Retro theme sizes to viewport — see retro rules */
.hof-bezel-wrap {
  position: relative;
  width: 100%;
  margin: 0 auto;
}

.hof-bezel-art {
  display: none;
  width: 100%;
  height: auto;
  vertical-align: top;
  pointer-events: none;
  user-select: none;
}

.hof-crt-screen {
  position: relative;
  width: 100%;
  z-index: 1;
}

.hof-crt-overlay {
  display: none;
  pointer-events: none;
}

/* ========== Retro: full arcade cabinet + CRT glass + scanlines ========== */

html[data-theme="retro"] .hof-page {
  font-family: 'VT323', 'Inter', sans-serif;
  background: #0d0804;
}

html[data-theme="retro"] .hof-bg::before,
html[data-theme="retro"] .hof-bg::after {
  opacity: 0.22;
  filter: blur(60px);
}

html[data-theme="retro"] .hof-particle {
  width: 4px;
  height: 4px;
  border-radius: 0;
  image-rendering: pixelated;
  box-shadow: 0 0 6px currentColor;
}

/* Full bezel art includes marquee + plinth — hide our CSS-only strips */
html[data-theme="retro"] .hof-cabinet-marquee,
html[data-theme="retro"] .hof-cabinet-plinth {
  display: none !important;
}

/* Bezel fills available viewport; square matches SVG aspect — screen is large inset inside */
html[data-theme="retro"] .hof-cabinet {
  max-width: 100%;
  width: 100%;
  padding: 0.25rem 0.5rem 0.75rem;
}

html[data-theme="retro"] .hof-bezel-wrap {
  /* Largest square that fits in the viewport (below app bar) */
  width: min(96vw, calc(100vh - 5.5rem));
  max-width: 100%;
  aspect-ratio: 1 / 1;
  margin-left: auto;
  margin-right: auto;
  align-self: center;
}

html[data-theme="retro"] .hof-bezel-art {
  display: block;
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

html[data-theme="retro"] .hof-crt {
  transform-style: preserve-3d;
  perspective: 1200px;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  max-width: none;
  width: 100%;
}

/*
 * CRT layer must match the SVG viewBox 1800×1800 cutout (first compound path hole),
 * or the UI will sit outside the illustrated screen.
 */
html[data-theme="retro"] .hof-crt-screen {
  position: absolute;
  left: 23.742%;
  top: 20.461%;
  width: 52.305%;
  height: 66.493%;
  z-index: 2;
  overflow: hidden;
  border-radius: 3px;
  box-shadow:
    inset 0 0 80px rgba(0, 0, 0, 0.5),
    inset 0 0 24px rgba(0, 40, 30, 0.35);
}

html[data-theme="retro"] .hof-crt-screen::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  border-radius: 3px;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.45);
}

html[data-theme="retro"] .hof-content {
  position: relative;
  z-index: 2;
  max-height: 100%;
  overflow: auto;
  padding: 1rem 1rem 1.25rem;
  transform: rotateX(0.8deg);
  transform-origin: center top;
  filter: contrast(1.06) saturate(1.12);
  -webkit-overflow-scrolling: touch;
}

html[data-theme="retro"] .hof-crt-overlay {
  display: block;
  position: absolute;
  inset: 0;
  z-index: 4;
  border-radius: 3px;
  overflow: hidden;
  /* Scanlines + subtle RGB mask + glass glare + vignette */
  background:
    linear-gradient(
      rgba(18, 16, 16, 0) 50%,
      rgba(0, 0, 0, 0.22) 50%
    ),
    linear-gradient(
      90deg,
      rgba(255, 0, 0, 0.04),
      rgba(0, 255, 0, 0.02),
      rgba(0, 0, 255, 0.04)
    ),
    linear-gradient(
      115deg,
      rgba(255, 255, 255, 0) 40%,
      rgba(255, 255, 255, 0.07) 48%,
      rgba(255, 255, 255, 0) 56%
    ),
    radial-gradient(
      ellipse at center,
      transparent 45%,
      rgba(0, 0, 0, 0.55) 100%
    );
  background-size:
    100% 4px,
    100% 100%,
    180% 180%,
    100% 100%;
  animation: hof-crt-flicker 7s infinite;
  pointer-events: none;
}

html[data-theme="retro"] .hof-crt-overlay::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    rgba(0, 0, 0, 0) 0px,
    rgba(0, 0, 0, 0) 1px,
    rgba(0, 0, 0, 0.13) 1px,
    rgba(0, 0, 0, 0.13) 2px
  );
  opacity: 0.45;
  pointer-events: none;
}

@keyframes hof-crt-flicker {
  0%,
  96%,
  100% {
    opacity: 1;
  }
  97% {
    opacity: 0.97;
  }
  98% {
    opacity: 0.99;
  }
}

html[data-theme="retro"] .hof-title {
  color: var(--hof-title);
  font-size: clamp(0.65rem, 3.2vmin, 1.05rem);
  line-height: 1.45;
  margin-bottom: 0.5rem;
  text-shadow:
    0 0 2px #fff,
    0 0 12px rgba(255, 200, 0, 0.85),
    3px 3px 0 #b45309;
  filter: drop-shadow(0 0 6px rgba(255, 200, 0, 0.4));
}

html[data-theme="retro"] .hof-subtitle {
  font-family: 'VT323', sans-serif;
  font-size: 1.35rem;
  letter-spacing: 0.06em;
  text-shadow: 0 0 8px rgba(0, 255, 200, 0.45);
}

html[data-theme="retro"] .hof-board {
  border-radius: 4px;
  border-width: 2px;
  box-shadow:
    0 0 0 1px rgba(0, 255, 200, 0.15),
    inset 0 0 40px rgba(0, 30, 20, 0.35),
    0 6px 20px rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(8px);
}

html[data-theme="retro"] .hof-name {
  font-family: 'VT323', sans-serif;
  font-size: clamp(1.15rem, 2.4vw, 1.45rem);
  font-weight: 400;
  letter-spacing: 0.04em;
  text-shadow: 0 0 6px rgba(0, 255, 200, 0.25);
}

html[data-theme="retro"] .hof-stat {
  font-family: 'VT323', sans-serif;
  font-size: clamp(1.2rem, 2.5vw, 1.5rem);
  text-shadow:
    0 0 8px rgba(100, 255, 100, 0.55),
    0 0 2px rgba(0, 80, 0, 0.8);
}

html[data-theme="retro"] .hof-footer a {
  font-family: 'VT323', sans-serif;
  font-size: 1.2rem;
  letter-spacing: 0.04em;
}
