:root {
  --shell-width: 1440px;
  --shell-gutter: 32px;
  --bg: #f4f6fb;
  --panel: rgba(255, 255, 255, 0.78);
  --panel-strong: rgba(255, 255, 255, 0.92);
  --line: rgba(114, 142, 255, 0.16);
  --text: #1d2842;
  --muted: #72809d;
  --accent: #6f7fff;
  --accent-2: #6ed9c8;
  --danger: #ff6f7e;
  --warning: #ffb54d;
  --shadow: 0 24px 60px rgba(103, 129, 210, 0.15);
  --stage-bg: #09111f;
  --stage-bg-2: #101a2e;
  --stage-panel: rgba(12, 20, 37, 0.88);
  --stage-panel-2: rgba(19, 30, 52, 0.9);
  --stage-line: rgba(118, 150, 255, 0.18);
  --stage-text: #eef4ff;
  --stage-muted: #95a6c6;
  --stage-shadow-strong: 0 24px 60px rgba(3, 8, 19, 0.38);
  --stage-shadow-soft: 0 16px 40px rgba(3, 8, 19, 0.24);
  --home-shell-bg: linear-gradient(180deg, rgba(8, 14, 29, 0.86), rgba(14, 22, 40, 0.78));
  --home-shell-border: rgba(118, 150, 255, 0.14);
  --hero-bg:
    radial-gradient(circle at 18% 18%, rgba(123, 140, 255, 0.36), transparent 26%),
    radial-gradient(circle at 88% 16%, rgba(39, 211, 162, 0.16), transparent 18%),
    linear-gradient(135deg, rgba(8, 14, 29, 0.96), rgba(14, 22, 40, 0.94));
}

:root[data-theme="light"] {
  --bg: #f4f6fb;
  --panel: rgba(255, 255, 255, 0.78);
  --panel-strong: rgba(255, 255, 255, 0.92);
  --line: rgba(114, 142, 255, 0.16);
  --text: #1d2842;
  --muted: #72809d;
  --shadow: 0 24px 60px rgba(103, 129, 210, 0.15);
  --stage-panel: rgba(255, 255, 255, 0.78);
  --stage-panel-2: rgba(239, 244, 251, 0.92);
  --stage-line: rgba(114, 142, 255, 0.16);
  --stage-text: #1d2842;
  --stage-muted: #72809d;
  --stage-shadow-strong: 0 24px 60px rgba(103, 129, 210, 0.15);
  --stage-shadow-soft: 0 14px 34px rgba(103, 129, 210, 0.1);
  --home-shell-bg: linear-gradient(180deg, rgba(255, 255, 255, 0.52), rgba(239, 244, 251, 0.4));
  --home-shell-border: rgba(114, 142, 255, 0.1);
  --hero-bg:
    radial-gradient(circle at 18% 18%, rgba(123, 140, 255, 0.16), transparent 26%),
    radial-gradient(circle at 88% 16%, rgba(39, 211, 162, 0.1), transparent 18%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(239, 244, 251, 0.96));
}

:root[data-theme="dark"] {
  --bg: #09111f;
  --panel: rgba(12, 20, 37, 0.82);
  --panel-strong: rgba(19, 30, 52, 0.92);
  --line: rgba(118, 150, 255, 0.18);
  --text: #eef4ff;
  --muted: #95a6c6;
  --shadow: 0 24px 60px rgba(3, 8, 19, 0.38);
}

* {
  box-sizing: border-box;
}

button,
input,
textarea,
select,
.hero-login-embed .nav-auth,
.hero-login-embed .nav-auth-logged,
.nav-auth-drawer,
.status-badge,
.tag,
.pill,
.budget-chip,
.theme-toggle-button,
.music-panel {
  transition:
    background 220ms ease,
    background-color 220ms ease,
    color 180ms ease,
    border-color 220ms ease,
    box-shadow 220ms ease,
    opacity 180ms ease;
}

@media (prefers-reduced-motion: reduce) {
  button,
  input,
  textarea,
  select,
  .hero-login-embed .nav-auth,
  .hero-login-embed .nav-auth-logged,
  .nav-auth-drawer,
  .status-badge,
  .tag,
  .pill,
  .budget-chip,
  .theme-toggle-button,
  .music-panel {
    transition: none;
  }

  .spotlight-event-card,
  .spotlight-event-card::before,
  .spotlight-event-card::after {
    transition: none !important;
    animation: none !important;
  }

  .spotlight-event-card::before,
  .spotlight-event-card::after,
  .spotlight-event-card-clickable .community-info-head strong {
    transition: none !important;
    animation: none !important;
  }
}

.theme-transition-overlay {
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: none;
  opacity: 1;
  transition:
    opacity 900ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 900ms cubic-bezier(0.22, 1, 0.36, 1);
}

.theme-transition-overlay.theme-from-dark {
  background:
    radial-gradient(circle at top left, rgba(72, 101, 210, 0.24), transparent 20%),
    radial-gradient(circle at top right, rgba(39, 211, 162, 0.12), transparent 18%),
    linear-gradient(180deg, #08111f 0%, #0d1627 42%, #101a2e 100%);
}

.theme-transition-overlay.theme-from-light {
  background:
    radial-gradient(circle at top left, rgba(191, 240, 255, 0.8), transparent 22%),
    radial-gradient(circle at top right, rgba(214, 255, 238, 0.9), transparent 26%),
    linear-gradient(180deg, #fbfcff 0%, #eff4fb 100%);
}

.theme-transition-overlay.is-fading-out {
  opacity: 0;
  filter: saturate(0.96);
}

body {
  margin: 0;
  color: var(--text);
  font-family: "PingFang SC", "Noto Sans SC", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(191, 240, 255, 0.8), transparent 22%),
    radial-gradient(circle at top right, rgba(214, 255, 238, 0.9), transparent 26%),
    linear-gradient(180deg, #fbfcff 0%, #eff4fb 100%);
}

:root[data-theme="dark"] body {
  background:
    radial-gradient(circle at top left, rgba(72, 101, 210, 0.24), transparent 20%),
    radial-gradient(circle at top right, rgba(39, 211, 162, 0.12), transparent 18%),
    linear-gradient(180deg, #08111f 0%, #0d1627 42%, #101a2e 100%);
}

:root[data-theme="light"] body {
  background:
    radial-gradient(circle at top left, rgba(191, 240, 255, 0.8), transparent 22%),
    radial-gradient(circle at top right, rgba(214, 255, 238, 0.9), transparent 26%),
    linear-gradient(180deg, #fbfcff 0%, #eff4fb 100%);
}

button,
input,
textarea,
select {
  font: inherit;
}

button,
.pill,
.budget-chip,
.tag,
.notice,
.check-card,
.pick-option,
.mini-player-card,
.table-row,
.history-row,
.price-box,
.team-card,
.top-shell,
.glass,
.auth-panel,
.auction-topbar,
.center-stage,
.side-panel,
.inhouse-shell,
.admin-card {
  backdrop-filter: blur(14px);
}

.page-shell {
  width: min(var(--shell-width), calc(100vw - var(--shell-gutter)));
  margin: 0 auto;
  padding: 6px 0 20px;
}

.page-shell-home {
  color: var(--stage-text);
  border-radius: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 126px 0 14px;
}

.page-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 6px 10px;
  border-radius: 16px;
  margin-bottom: 8px;
}

.page-nav-system {
  position: sticky;
  top: 2px;
  z-index: 40;
  background: color-mix(in srgb, var(--panel-strong) 88%, transparent);
  border: 1px solid color-mix(in srgb, var(--line) 85%, transparent);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.07);
  backdrop-filter: blur(16px);
}

#app-top,
#featured-event-spotlight,
#community-activities,
#live-auction-scene,
#live-inhouse-scene {
  scroll-margin-top: 78px;
}

.topbar-compact-switcher {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
  flex-wrap: nowrap;
}

.topbar-compact-switcher select {
  min-width: 180px;
  max-width: 240px;
  height: 34px;
  padding: 0 10px;
}

.page-nav-on-home {
  background: color-mix(in srgb, var(--stage-panel-2) 84%, transparent);
  border-color: rgba(118, 150, 255, 0.14);
}

.page-nav-main,
.nav-auth,
.nav-auth-logged,
.nav-login-form,
.nav-admin-form {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.page-nav-main {
  justify-content: flex-start;
  flex: 1;
  min-width: 0;
  gap: 12px;
}

.page-nav-brand {
  display: grid;
  gap: 1px;
  line-height: 1;
  flex: 0 0 auto;
}

.page-nav-brand strong {
  font-size: 13px;
  letter-spacing: 0.04em;
}

.page-nav-brand span {
  font-size: 10px;
  color: var(--muted);
}

.page-nav-on-home .page-nav-brand strong,
.page-nav-on-home .page-nav-brand span {
  color: var(--stage-text);
}

.page-nav-links {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
  margin-inline: auto;
}

.page-nav-link {
  padding: 5px 9px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  box-shadow: none;
  font-size: 12px;
}

.page-nav-link:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.08);
}

.page-nav-on-home .page-nav-link {
  color: var(--stage-muted);
}

.nav-auth,
.nav-auth-logged {
  justify-content: flex-end;
  flex: 0 0 auto;
}

.nav-auth-drawer-shell {
  width: auto;
  min-width: 0;
}

.nav-user-label {
  font-size: 13px;
}

.nav-auth-drawer-shell {
  position: relative;
  display: grid;
  gap: 8px;
  width: min(360px, 100%);
  overflow: visible;
  z-index: 160;
}

.nav-auth-entry-row {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.nav-auth-entry-row .secondary-button {
  transition: background 360ms ease, border-color 360ms ease, color 360ms ease, opacity 360ms ease;
  min-height: 32px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1;
}

.nav-profile-avatar-btn {
  width: 40px;
  min-width: 40px;
  height: 40px;
  padding: 0;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: visible;
  border: 1px solid rgba(118, 150, 255, 0.48);
  box-shadow: none;
  background: transparent;
}

.nav-auth-entry-row .nav-profile-avatar-btn {
  min-height: 40px;
  width: 40px;
  min-width: 40px;
  height: 40px;
  padding: 0;
  border-radius: 999px;
}

.nav-profile-avatar-btn::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 999px;
  border: 1px solid rgba(126, 165, 255, 0.7);
  opacity: 0.88;
  animation: navAvatarPulse 1.9s ease-in-out infinite;
  pointer-events: none;
}

.nav-profile-avatar-btn:hover::after,
.nav-profile-avatar-btn.nav-btn-active::after {
  border-color: rgba(126, 165, 255, 0.95);
  opacity: 1;
}

.nav-profile-avatar-btn:hover,
.nav-auth-drawer-shell:focus-within .nav-profile-avatar-btn,
.nav-auth-drawer-shell.is-open .nav-profile-avatar-btn {
  background: rgba(137, 163, 255, 0.12);
  border-color: rgba(137, 163, 255, 0.32);
}

.nav-profile-avatar {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.nav-profile-avatar.image-avatar img {
  border-radius: 999px;
  object-fit: cover;
}

@keyframes navAvatarPulse {
  0% {
    transform: scale(0.93);
    opacity: 0.5;
  }
  50% {
    transform: scale(1.08);
    opacity: 1;
  }
  100% {
    transform: scale(0.93);
    opacity: 0.5;
  }
}

.nav-btn-active {
  background: rgba(137, 163, 255, 0.12);
  border-color: rgba(137, 163, 255, 0.32);
  color: #a0b4ff;
}

:root[data-theme="light"] .nav-btn-active {
  background: rgba(114, 142, 255, 0.1);
  border-color: rgba(114, 142, 255, 0.3);
  color: #5566dd;
}

.nav-auth-drawer {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 220;
  padding: 10px;
  border-radius: 16px;
  background: rgba(12, 20, 37, 0.96);
  border: 1px solid rgba(137, 163, 255, 0.14);
  box-shadow: var(--stage-shadow-soft);
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px) scale(0.985);
  transform-origin: top center;
}

.nav-auth-drawer.opening,
.nav-auth-drawer.open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  animation: authDrawerSlideIn 520ms cubic-bezier(0.22, 1, 0.36, 1);
}

.nav-auth-drawer-shell:focus-within .nav-profile-drawer,
.nav-auth-drawer-shell.is-open .nav-profile-drawer {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.nav-auth-drawer.closing {
  opacity: 0;
  visibility: visible;
  pointer-events: none;
  transform: translateY(-10px) scale(0.985);
  animation: authDrawerSlideOut 520ms cubic-bezier(0.22, 1, 0.36, 1);
}

.nav-drawer-form {
  display: grid;
  gap: 8px;
}

.nav-drawer-form label {
  color: var(--stage-muted);
}

.nav-drawer-actions {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

.nav-login-form input,
.nav-admin-form input {
  min-width: 152px;
  padding: 10px 12px;
  border-radius: 14px;
}

.nav-admin-entry {
  color: var(--muted);
}

.nav-admin-entry summary {
  cursor: pointer;
  font-size: 14px;
}

.nav-user-label {
  color: var(--muted);
  font-weight: 700;
}

.page-nav-hub {
  background: linear-gradient(135deg, rgba(8, 15, 30, 0.92), rgba(18, 28, 50, 0.92));
  border-color: rgba(123, 140, 255, 0.18);
}

.page-nav-hub .secondary-button,
.page-nav-hub .nav-user-label,
.page-nav-hub .nav-admin-entry,
.page-nav-hub .nav-admin-entry summary {
  color: var(--stage-text);
}

.page-nav-hub .nav-login-form input,
.page-nav-hub .nav-admin-form input {
  color: var(--stage-text);
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(130, 156, 255, 0.14);
}

.page-nav-hub .nav-login-form input::placeholder,
.page-nav-hub .nav-admin-form input::placeholder {
  color: rgba(228, 236, 255, 0.52);
}

.nav-active {
  background: rgba(111, 127, 255, 0.14);
  border-color: rgba(111, 127, 255, 0.28);
  color: var(--text);
  box-shadow: none;
}

.page-nav-on-home .nav-active {
  color: var(--stage-text);
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(118, 150, 255, 0.18);
}

.glass {
  background: var(--panel);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

.top-shell {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 20px;
}

.brand-panel,
.auth-panel,
.admin-card,
.auction-topbar,
.center-stage,
.side-panel,
.inhouse-shell {
  border-radius: 28px;
  padding: 18px;
}

.inhouse-shell {
  padding: 18px 20px 20px;
}

.admin-card {
  display: flex;
  flex-direction: column;
  min-height: 0;
  height: min(82vh, 1120px);
  overflow: hidden;
}

.admin-card.collapsed-card {
  height: auto;
  min-height: 0;
}

.admin-card-body {
  display: grid;
  gap: 14px;
  flex: 1;
  min-height: 0;
  overflow: auto;
  padding-right: 4px;
  overscroll-behavior: contain;
}

.collapsed-body {
  display: none;
}

.player-library-card .admin-card-body {
  align-content: start;
}

.event-management-card .admin-card-body,
.auction-management-card .admin-card-body {
  align-content: start;
}

.eyebrow,
.stage-kicker,
.session-role {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: #ffad6f;
  font-size: 12px;
}

h1,
h2,
h3,
h4,
p {
  margin-top: 0;
}

.brand-panel h1 {
  margin-bottom: 10px;
  font-size: clamp(34px, 4vw, 54px);
}

.subcopy,
.muted-line,
.mini-player-main span,
.team-card span,
.helper-line,
.history-row,
.table-row span,
.check-card small,
.pick-option small {
  color: var(--muted);
}

.auth-grid,
.workspace-grid,
.auction-board,
.inhouse-grid {
  display: grid;
  gap: 20px;
}

.auth-grid {
  grid-template-columns: 1fr 1fr;
}

.stack,
.grid-form,
.bid-form {
  display: grid;
  gap: 12px;
}

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

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

.full {
  grid-column: 1 / -1;
}

label {
  display: grid;
  gap: 8px;
  color: var(--muted);
}

input,
textarea,
select {
  width: 100%;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.72);
  color: var(--text);
  border-radius: 16px;
  padding: 12px 14px;
}

button {
  border: 0;
  border-radius: 16px;
  padding: 12px 18px;
  cursor: pointer;
  color: white;
  background: linear-gradient(135deg, #7788ff, #57b8ff);
  transition: transform 120ms ease, opacity 160ms ease, box-shadow 160ms ease, filter 160ms ease;
  box-shadow: 0 10px 22px rgba(94, 132, 255, 0.2);
}

button:hover {
  transform: translateY(-1px);
}

button:active {
  transform: translateY(1px) scale(0.985);
  filter: brightness(0.96);
  box-shadow: 0 4px 10px rgba(94, 132, 255, 0.18);
}

button:disabled {
  cursor: not-allowed;
  transform: none;
  opacity: 0.45;
  box-shadow: none;
}

.secondary-button,
.ghost-button {
  color: var(--text);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 8px 16px rgba(110, 126, 170, 0.08);
}

.ghost-button {
  border: 1px solid var(--line);
}

.disabled-button,
button:disabled.disabled-button {
  opacity: 0.6;
  cursor: not-allowed;
  background: rgba(184, 191, 209, 0.22);
  color: rgba(54, 66, 92, 0.72);
  border-color: rgba(150, 160, 180, 0.35);
  transform: none;
  box-shadow: none;
}

.action-button {
  background: linear-gradient(135deg, #7788ff, #57b8ff);
}

.success-button {
  background: linear-gradient(135deg, #43c89a, #6ed9c8);
}

.warning-button {
  background: linear-gradient(135deg, #ffbf5a, #ff9e43);
  color: #4b2f00;
}

.danger-button {
  background: linear-gradient(135deg, #ff7a87, #ff5f74);
}

.small {
  padding: 8px 12px;
  border-radius: 12px;
}

.notice {
  margin-top: 16px;
  border-radius: 16px;
  padding: 12px 14px;
}

.notice.success {
  color: #0a6b55;
  background: rgba(143, 246, 217, 0.34);
}

.notice.error {
  color: #a23c4b;
  background: rgba(255, 183, 194, 0.34);
}

.dialog-backdrop {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(18, 26, 45, 0.26);
  backdrop-filter: blur(6px);
  z-index: 50;
}

.dialog-card {
  width: min(420px, calc(100vw - 32px));
  display: grid;
  gap: 14px;
  padding: 20px 22px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--line);
  box-shadow: 0 24px 60px rgba(33, 46, 81, 0.2);
}

.dialog-card h3,
.dialog-card p {
  margin: 0;
}

.dialog-card p {
  color: var(--muted);
  line-height: 1.6;
}

.dialog-actions {
  justify-content: flex-end;
}

.session-head,
.card-head,
.team-card-head,
.selection-bar,
.auction-topbar,
.topbar-meta,
.team-stat-row,
.form-actions,
.row-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.card-head h2,
.card-head h3,
.card-head p,
.card-head span {
  margin-top: 0;
  margin-bottom: 0;
}

.workspace-grid {
  grid-template-columns: 1fr;
  margin-top: 24px;
  align-items: start;
}

.admin-workspace-shell {
  display: grid;
  gap: 18px;
}

.admin-inline-toolbar {
  display: grid;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.56);
}

.admin-inline-toolbar-main,
.admin-inline-pills {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.admin-segmented-item strong {
  margin: 0;
}

.admin-inline-pill {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.66);
  color: var(--muted);
  font-size: 12px;
  white-space: nowrap;
}

.admin-entity-list {
  display: grid;
  gap: 12px;
  align-content: start;
}

.admin-entity-card {
  display: grid;
  gap: 0;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.62);
  overflow: hidden;
}

.admin-entity-card.is-expanded {
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 16px 28px rgba(110, 126, 170, 0.1);
}

.admin-entity-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 18px;
  flex-wrap: wrap;
}

.admin-entity-copy {
  display: grid;
  gap: 10px;
  min-width: 0;
  flex: 1;
}

.admin-entity-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: space-between;
  flex-wrap: wrap;
}

.admin-entity-title-row h3 {
  margin: 0;
  font-size: 20px;
}

.admin-entity-meta-grid {
  display: flex;
  gap: 10px 14px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 14px;
}

.admin-entity-panel {
  display: grid;
  gap: 12px;
  padding: 0 18px 18px;
  border-top: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  background: color-mix(in srgb, rgba(255, 255, 255, 0.34) 92%, transparent);
}

.admin-entity-panel .admin-action-row {
  padding-top: 14px;
}

.admin-action-row,
.admin-compact-stats {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.admin-layout-grid {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.admin-sidebar,
.admin-main-panel {
  min-width: 0;
}

.admin-sidebar {
  position: sticky;
  top: 72px;
  padding: 12px;
  border-radius: 20px;
}

.admin-segmented-nav {
  display: grid;
  gap: 8px;
}

.admin-segmented-item {
  display: grid;
  gap: 2px;
  text-align: left;
  color: var(--text);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 8px 16px rgba(110, 126, 170, 0.08);
  padding: 10px 12px;
  border-radius: 14px;
}

.admin-segmented-item span {
  color: var(--muted);
}

.admin-segmented-item.is-active {
  color: white;
  background: linear-gradient(135deg, rgba(119, 136, 255, 0.96), rgba(87, 184, 255, 0.96));
  box-shadow: 0 16px 28px rgba(94, 132, 255, 0.24);
}

.admin-segmented-item.is-active span {
  color: rgba(255, 255, 255, 0.82);
}

.admin-main-panel {
  display: grid;
  gap: 20px;
}

.admin-card-expanded {
  height: auto;
  min-height: 0;
}

.admin-drawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 4000;
  display: flex;
  justify-content: flex-end;
  background: rgba(12, 18, 31, 0.26);
  backdrop-filter: blur(4px);
}

.admin-drawer-panel {
  width: min(680px, calc(100vw - 24px));
  height: 100dvh;
  border-radius: 0;
  border-left: 1px solid var(--line);
  padding: max(34px, env(safe-area-inset-top, 0px) + 18px) 18px 18px;
  overflow: hidden;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}

.admin-drawer-body {
  overflow: auto;
  padding-right: 4px;
}

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

.metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.metric-card {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 20px;
}

.metric-card span,
.metric-card small {
  color: var(--muted);
}

.metric-card strong {
  font-size: 28px;
}

.table-list,
.queue-list,
.team-stack,
.roster-list,
.history-list,
.checkbox-grid,
.player-event-list,
.directory-list,
.event-overview-list {
  display: grid;
  gap: 12px;
}

.table-list,
.queue-list,
.team-stack,
.history-list {
  max-height: 360px;
  overflow: auto;
  padding-right: 4px;
}

.player-event-list {
  max-height: 280px;
  overflow: auto;
  padding-right: 4px;
}

.event-summary {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin: 18px 0;
}

.event-summary div,
.price-box {
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 14px;
}

.event-summary strong,
.price-box strong {
  display: block;
  font-size: 28px;
}

.selection-bar {
  margin: 4px 0 6px;
}

.event-overview-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 18px 0 16px;
}

.auction-overview-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.event-overview-card {
  text-align: left;
  color: var(--text);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 8px 16px rgba(110, 126, 170, 0.08);
}

.auction-overview-card {
  display: grid;
  gap: 4px;
  align-items: start;
}

.event-overview-card span {
  display: block;
  margin-top: 6px;
  color: var(--muted);
  font-weight: 500;
}

.event-overview-card.selected-overview {
  background: linear-gradient(135deg, rgba(119, 136, 255, 0.18), rgba(87, 184, 255, 0.16));
  border: 1px solid rgba(111, 127, 255, 0.3);
}

.auction-editor-shell {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid var(--line);
}

.tournament-admin-shell,
.import-panel,
.budget-assignment,
.auction-editor-shell {
  border-radius: 20px;
}

.auction-admin-actions {
  justify-content: flex-start;
}

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

.check-card,
.pick-option,
.table-row,
.mini-player-card,
.history-row,
.player-event-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.62);
}

.check-card,
.pick-option {
  display: flex;
  align-items: center;
  gap: 12px;
}

.check-card input,
.pick-option input {
  width: auto;
  margin: 0;
}

.pick-option-main,
.check-card-main {
  flex: 1;
}

.table-row-main,
.check-card-main,
.pick-option-main {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.table-row-main {
  flex: 1;
}

.table-row-copy,
.check-card-copy,
.pick-option-copy {
  min-width: 0;
}

.table-row-copy strong,
.check-card-copy span,
.pick-option-copy span {
  display: block;
}

.player-home {
  display: grid;
  gap: 14px;
}

.global-toolbar {
  position: fixed !important;
  top: 12px !important;
  right: 16px !important;
  left: auto !important;
  bottom: auto !important;
  z-index: 260 !important;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  justify-content: flex-end;
  width: max-content;
  margin: 0;
  transform: translateZ(0);
  will-change: transform;
}

.global-theme-toggle,
.global-music-toggle {
  position: relative;
}

.global-music-toggle {
  padding-bottom: 10px;
  margin-bottom: -10px;
}

.global-theme-toggle .theme-toggle-button,
.global-music-toggle .theme-toggle-button {
  white-space: nowrap;
  min-height: 34px;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1;
  box-shadow: var(--stage-shadow-soft);
  background: rgba(12, 20, 37, 0.92);
  border: 1px solid rgba(137, 163, 255, 0.16);
}

.music-toggle-button {
  min-width: 40px;
  padding-inline: 0;
  font-size: 18px;
}

.music-toggle-glyph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.2em;
  height: 1.2em;
  position: relative;
  transform-origin: center;
}

.music-toggle-button.is-spinning .music-toggle-glyph {
  animation: musicSpin 6s linear infinite;
}

.music-toggle-button.is-muted .music-toggle-glyph {
  opacity: 0.86;
}

.music-toggle-button.is-muted .music-toggle-glyph::after {
  content: "";
  position: absolute;
  width: 1.5px;
  height: 1.6em;
  background: currentColor;
  border-radius: 999px;
  transform: rotate(-45deg);
}

.music-panel {
  position: absolute;
  top: 100%;
  right: 0;
  width: 220px;
  padding: 12px;
  border-radius: 16px;
  display: grid;
  gap: 10px;
  box-shadow: var(--stage-shadow-soft);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity 160ms ease, transform 160ms ease;
  background: rgba(12, 20, 37, 0.96);
  border: 1px solid rgba(137, 163, 255, 0.16);
  backdrop-filter: none;
}

.global-music-toggle:hover .music-panel,
.global-music-toggle.open .music-panel,
.global-music-toggle:focus-within .music-panel {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

@keyframes musicSpin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

.music-volume-control {
  display: grid;
  gap: 6px;
  font-size: 12px;
}

.music-volume-control input[type="range"] {
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  height: 18px;
  background: transparent;
  --music-volume: 35%;
}

.music-volume-control input[type="range"]::-webkit-slider-runnable-track {
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    var(--accent) 0,
    var(--accent) var(--music-volume),
    rgba(255, 255, 255, 0.2) var(--music-volume),
    rgba(255, 255, 255, 0.2) 100%
  );
}

.music-volume-control input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  margin-top: -4px;
  background: var(--accent);
  box-shadow: 0 0 0 2px rgba(12, 14, 20, 0.28);
  cursor: pointer;
}

.music-volume-control input[type="range"]::-moz-range-track {
  height: 4px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.2);
}

.music-volume-control input[type="range"]::-moz-range-progress {
  height: 4px;
  border-radius: 999px;
  background: var(--accent);
}

.music-volume-control input[type="range"]::-moz-range-thumb {
  width: 12px;
  height: 12px;
  border: 0;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 2px rgba(12, 14, 20, 0.28);
  cursor: pointer;
}

.home-main-stage {
  position: relative;
}

.session-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.admin-form-section {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.42);
}

.admin-form-section-tight {
  padding: 10px 12px;
}

.admin-form-subsection {
  display: grid;
  gap: 10px;
}

.nested-grid-form {
  margin: 0;
}

.subtle-admin-entry {
  opacity: 0.82;
}

.hero-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.9fr) minmax(300px, 0.9fr);
  gap: 12px;
  align-items: start;
}

.stage-surface,
.side-stage-panel,
.activity-stage-panel {
  color: var(--stage-text);
  background: linear-gradient(135deg, var(--stage-panel), var(--stage-panel-2));
  border-color: var(--stage-line);
  box-shadow: var(--stage-shadow-strong);
}

.stage-surface .subcopy,
.side-stage-panel .subcopy,
.stage-surface .muted-line,
.side-stage-panel .muted-line,
.activity-stage-panel .muted-line,
.stage-surface p,
.side-stage-panel p,
.side-stage-panel span,
.activity-stage-panel p,
.activity-stage-panel span,
.activity-stage-panel small {
  color: var(--stage-muted);
}

.stage-surface h2,
.stage-surface h3,
.side-stage-panel h2,
.side-stage-panel h3,
.activity-stage-panel h2,
.activity-stage-panel h3,
.stage-surface strong,
.side-stage-panel strong,
.activity-stage-panel strong {
  color: var(--stage-text);
}

.hero-rail {
  display: grid;
  gap: 10px;
}

.content-split {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(280px, 0.85fr);
  gap: 12px;
  align-items: start;
}

.community-hero,
.community-section,
.community-info-card,
.featured-player-card,
.hero-side-card,
.community-side-panel,
.hero-feature-card {
  border-radius: 28px;
}

.community-hero,
.community-section {
  padding: 14px 16px;
}

.community-hero {
  position: relative;
  z-index: 10;
  min-height: 352px;
  padding: 18px 18px 18px;
  background: var(--hero-bg);
  overflow: hidden;
}

.community-hero-main {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  align-items: start;
}

.hero-title-band {
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  pointer-events: none;
}

.hero-title-band h1 {
  margin: 0;
  font-size: clamp(34px, 4.8vw, 58px);
  line-height: 0.95;
  letter-spacing: 0.16em;
  text-indent: 0.16em;
  font-weight: 900;
  font-style: italic;
  color: transparent;
  background: linear-gradient(180deg, #f8fbff 0%, #cad8ff 34%, #8ea7ff 62%, #5d7cff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-stroke: 1px rgba(222, 232, 255, 0.18);
  text-shadow:
    0 2px 0 rgba(61, 90, 194, 0.35),
    0 10px 20px rgba(8, 13, 25, 0.18);
}

.hero-honor-stage {
  display: grid;
  grid-template-columns: minmax(0, 1.86fr) minmax(220px, 0.54fr);
  gap: 10px;
  align-items: center;
  position: relative;
  z-index: 1;
  margin-top: 18px;
}

.hero-champion-stack {
  display: grid;
  gap: 10px;
  align-items: start;
}

.hero-champion-stage {
  position: relative;
  display: grid;
  align-content: center;
  gap: 8px;
  min-height: 428px;
  padding: 8px 6px 8px 4px;
}

.hero-champion-congrats {
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
  text-align: center;
  font-size: 15px;
  font-weight: 600;
  color: rgba(245, 248, 255, 0.92);
  text-shadow: 0 4px 16px rgba(8, 13, 25, 0.42);
}

.hero-champion-stage-disabled {
  align-content: center;
}

.hero-champion-stage-placeholder {
  display: grid;
  gap: 8px;
  justify-items: start;
  padding: 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px dashed rgba(137, 163, 255, 0.2);
  color: var(--stage-muted);
}

.hero-champion-stage-placeholder strong {
  color: var(--stage-text);
  font-size: 24px;
}

.hero-champion-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hero-champion-stage > * {
  position: relative;
  z-index: 1;
}

.hero-feature-card,
.community-side-panel,
.community-info-card,
.featured-player-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(137, 163, 255, 0.12);
}

.featured-player-card span,
.featured-player-card small,
.community-info-card p,
.community-side-panel span,
.community-side-panel p,
.community-side-panel small,
.hero-feature-card p {
  color: var(--muted);
}

.hero-feature-card strong {
  font-size: clamp(22px, 2.6vw, 28px);
}

.spotlight-poster {
  margin-top: 6px;
  padding: 14px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.09), rgba(123, 140, 255, 0.12));
  border: 1px solid rgba(137, 163, 255, 0.16);
}

.spotlight-poster .community-info-head {
  margin-bottom: 4px;
}

.hero-feature-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 13px;
}

.hero-honor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.52fr) minmax(0, 0.8fr);
  gap: 8px;
  align-items: stretch;
}

.hero-honor-card {
  display: grid;
  gap: 8px;
  padding: 10px;
  border-radius: 22px;
  border: 1px solid rgba(137, 163, 255, 0.18);
  background:
    radial-gradient(circle at top right, rgba(123, 140, 255, 0.16), transparent 28%),
    rgba(255, 255, 255, 0.08);
}

.hero-honor-card-main {
  background:
    radial-gradient(circle at top right, rgba(255, 184, 79, 0.14), transparent 30%),
    radial-gradient(circle at top left, rgba(123, 140, 255, 0.2), transparent 34%),
    rgba(255, 255, 255, 0.09);
}

.hero-honor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.hero-honor-kicker {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.13em;
  color: #ffb56e;
}

.hero-honor-card h3 {
  margin: 0;
  font-size: clamp(17px, 1.7vw, 24px);
  line-height: 1.1;
}

.hero-honor-card-secondary {
  align-content: start;
  justify-self: end;
  width: 100%;
  max-width: 320px;
  padding: 8px;
  background:
    radial-gradient(circle at top right, rgba(123, 140, 255, 0.05), transparent 22%),
    rgba(255, 255, 255, 0.035);
  border-color: rgba(137, 163, 255, 0.08);
  opacity: 0.82;
  transform: translateY(18px) scale(0.94);
  box-shadow: 0 10px 22px rgba(8, 15, 30, 0.12);
}

.hero-honor-card-secondary h3 {
  font-size: clamp(17px, 1.35vw, 22px);
}

.hero-honor-intro {
  margin: 0;
  color: var(--stage-muted);
}

.hero-honor-captain {
  display: grid;
  grid-template-columns: 66px minmax(0, 1fr);
  gap: 6px;
  align-items: center;
  padding: 7px;
  border-radius: 14px;
  background: rgba(12, 20, 37, 0.26);
  border: 1px solid rgba(137, 163, 255, 0.18);
}

.hero-event-spotlight {
  margin-top: 12px;
}

.hero-honor-avatar {
  width: 66px;
  height: 66px;
  font-size: 24px;
}

.hero-honor-captain-copy {
  min-width: 0;
}

.hero-honor-captain-copy > strong,
.hero-honor-captain-copy > span,
.hero-honor-captain-copy > small {
  display: block;
}

.hero-honor-captain-copy > span,
.hero-honor-captain-copy > small {
  color: var(--stage-muted);
  font-size: 12px;
}

.hero-honor-roster {
  display: grid;
  gap: 6px;
}

.hero-honor-member {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 4px 9px;
  border-radius: 999px;
  font-size: 12px;
  color: var(--stage-muted);
  border: 1px solid rgba(137, 163, 255, 0.16);
  background: rgba(255, 255, 255, 0.05);
}

.hero-honor-note {
  color: var(--stage-muted);
  opacity: 0.82;
  font-size: 12px;
}

.hero-honor-card-secondary .hero-honor-member {
  min-height: 22px;
  font-size: 10px;
  padding: 2px 7px;
  background: rgba(255, 255, 255, 0.025);
}

.hero-event-spotlight {
  margin-top: 10px;
}

.spotlight-event-card {
  position: relative;
  display: grid;
  gap: 8px;
  margin-top: 6px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background:
    linear-gradient(135deg, rgba(8, 14, 29, 0.42), rgba(12, 20, 37, 0.48)),
    radial-gradient(circle at top right, rgba(118, 135, 255, 0.08), transparent 28%),
    url("/assets/featured-event-bg.jpg");
  background-size: cover;
  background-position: center 42%;
  color: var(--stage-text);
  overflow: hidden;
  box-shadow: var(--stage-shadow-soft);
  isolation: isolate;
}

.spotlight-event-card::before,
.spotlight-event-card::after {
  content: "";
  position: absolute;
  inset: auto;
  pointer-events: none;
  z-index: 0;
}

.spotlight-event-card::before {
  top: -22%;
  right: -16%;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(126, 154, 255, 0.4), transparent 70%);
  opacity: 0.92;
  transform: scale(0.9);
  transition: transform 360ms ease, opacity 360ms ease, filter 360ms ease;
  filter: blur(4px);
  animation: spotlightOrbPulse 2.2s ease-in-out infinite;
}

.spotlight-event-card::after {
  top: -38%;
  left: -42%;
  width: 52%;
  height: 180%;
  background: linear-gradient(115deg, transparent 14%, rgba(255, 255, 255, 0.28) 45%, transparent 74%);
  opacity: 0;
  transform: rotate(10deg) translateX(0);
  transition: transform 820ms cubic-bezier(0.22, 1, 0.36, 1), opacity 280ms ease;
}

.spotlight-event-card-clickable .community-info-head strong {
  transition:
    text-shadow 280ms ease,
    letter-spacing 280ms ease;
  animation: spotlightTitlePulse 2.2s ease-in-out infinite;
}

.spotlight-event-card > * {
  position: relative;
  z-index: 1;
}

.spotlight-event-card-clickable {
  cursor: pointer;
  animation: spotlightPulse 2.2s ease-in-out infinite;
  transition:
    transform 220ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 260ms ease,
    border-color 260ms ease,
    filter 260ms ease,
    background-position 520ms ease;
}

.spotlight-event-card-clickable:hover {
  transform: translateY(-4px) scale(1.01);
  border-color: rgba(118, 150, 255, 0.34);
  box-shadow: 0 24px 42px rgba(3, 8, 19, 0.24);
  filter: saturate(1.05);
  background-position: center 38%;
}

.spotlight-event-card-clickable:hover::before,
.spotlight-event-card-clickable:focus-visible::before {
  opacity: 0.96;
  transform: scale(1.08);
  filter: blur(0);
}

.spotlight-event-card-clickable:hover::after,
.spotlight-event-card-clickable:focus-visible::after {
  opacity: 1;
  transform: rotate(10deg) translateX(165%);
}

.spotlight-event-card-clickable:focus-visible {
  outline: 2px solid rgba(118, 150, 255, 0.48);
  outline-offset: 3px;
}

.spotlight-event-card-clickable:active {
  transform: translateY(-1px) scale(0.995);
}

@keyframes spotlightPulse {
  0%,
  100% {
    box-shadow: var(--stage-shadow-soft);
    filter: saturate(1);
    border-color: rgba(118, 150, 255, 0.18);
  }
  50% {
    box-shadow:
      0 24px 44px rgba(3, 8, 19, 0.22),
      0 0 0 1px rgba(118, 150, 255, 0.18),
      0 0 64px rgba(118, 150, 255, 0.34);
    filter: saturate(1.12) brightness(1.04);
    border-color: rgba(118, 150, 255, 0.44);
  }
}

@keyframes spotlightOrbPulse {
  0%,
  100% {
    opacity: 0.72;
    transform: scale(0.86);
    filter: blur(7px);
  }
  50% {
    opacity: 1;
    transform: scale(1.3);
    filter: blur(0);
  }
}

@keyframes spotlightTitlePulse {
  0%,
  100% {
    text-shadow: 0 0 0 rgba(151, 179, 255, 0);
    letter-spacing: 0;
  }
  50% {
    text-shadow:
      0 0 18px rgba(151, 179, 255, 0.28),
      0 0 30px rgba(151, 179, 255, 0.14);
    letter-spacing: 0.015em;
  }
}

.champion-panel-head {
  display: grid;
  gap: 2px;
}

.champion-panel-head span {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: #ffb56e;
}

.champion-panel-head small {
  color: var(--stage-muted);
}

.champion-lineup {
  position: relative;
  min-height: 240px;
  overflow: visible;
  perspective: 1200px;
  transform-style: preserve-3d;
}

.champion-lineup::before {
  content: none;
}

.champion-member-card {
  position: absolute;
  top: 16px;
  left: 50%;
  width: min(56%, 208px);
  min-height: 240px;
  padding: 0;
  overflow: hidden;
  border-radius: 20px;
  isolation: isolate;
  transform-origin: center center;
  backface-visibility: hidden;
  will-change: transform, opacity;
  opacity: 0;
  transform: translate3d(-50%, 18px, 0) scale(0.68);
  background: rgba(11, 18, 32, 0.72);
  border: 3px solid var(--poster-accent, rgba(125, 140, 255, 0.82));
  box-shadow:
    0 14px 30px rgba(3, 8, 19, 0.18),
    inset 0 0 0 2px color-mix(in srgb, var(--poster-accent, #8aa6ff) 88%, white 12%),
    inset 0 0 20px color-mix(in srgb, var(--poster-accent, #8aa6ff) 22%, transparent),
    0 0 12px color-mix(in srgb, var(--poster-accent, #8aa6ff) 18%, transparent);
  translate: 0 0;
  transition:
    transform 760ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 620ms ease,
    translate 180ms ease,
    box-shadow 180ms ease,
    border-color 180ms ease;
}

.champion-member-card .player-poster-art {
  border-radius: inherit;
  overflow: hidden;
  z-index: 0;
}

.champion-member-card .player-poster-avatar,
.champion-member-card .player-poster-avatar.image-avatar img {
  border-radius: inherit;
}

.champion-member-positions {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  width: fit-content;
  gap: 9px;
  height: 23px;
  padding: 4px 9.5px;
  border-radius: 20px 20px 20px 0;
  clip-path: inset(0 round 20px 20px 20px 0);
  background: rgba(28, 60, 66, 0.9);
}

.champion-position-icon {
  width: 15px;
  height: 15px;
  object-fit: contain;
  background: transparent;
  border-radius: 0;
}

.champion-position-fallback {
  color: rgba(235, 242, 255, 0.86);
  font-size: 11px;
  line-height: 1;
}

.champion-member-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 20px;
  border: 2px solid transparent;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.champion-member-card:hover {
  translate: 0 -4px;
  z-index: 9;
  box-shadow:
    0 24px 42px rgba(17, 24, 39, 0.32),
    inset 0 0 0 3px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 100%, white 14%),
    inset 0 0 28px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 34%, transparent),
    0 0 26px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 42%, transparent),
    0 0 54px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 24%, transparent);
  border-color: var(--poster-accent-bright, var(--poster-accent, rgba(160, 180, 255, 0.72)));
}

.champion-member-card:hover::after {
  opacity: 1;
  border-color: color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 96%, white 4%);
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 100%, white 0%),
    0 0 26px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 82%, transparent),
    0 0 46px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 56%, transparent);
}

.champion-poster-caption {
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;
  display: grid;
  gap: 5px;
  align-items: start;
  z-index: 1;
  padding: 10px 10px 9px;
  border-radius: 13px;
  background: linear-gradient(180deg, rgba(18, 25, 44, 0.42), rgba(18, 25, 44, 0.7));
  border: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
}

.champion-member-copy {
  min-width: 0;
}

.champion-member-name-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.champion-captain-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(255, 184, 79, 0.34), rgba(123, 140, 255, 0.22));
  color: #fff4d6;
  line-height: 1;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.champion-captain-icon svg {
  width: 11px;
  height: 11px;
  fill: currentColor;
}

.champion-member-copy > strong,
.champion-member-copy > span,
.champion-member-copy > small {
  display: block;
}

.champion-member-copy strong {
  color: #fff;
  font-size: 14px;
  line-height: 1.08;
  text-shadow: 0 2px 10px rgba(8, 13, 25, 0.78);
  text-align: center;
}

.champion-member-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  color: rgba(235, 242, 255, 0.88);
  font-size: 10px;
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.champion-member-meta span {
  white-space: nowrap;
  flex: 0 0 auto;
}

.champion-member-power {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.champion-stat-icon {
  width: 14px;
  height: 14px;
  object-fit: contain;
  display: block;
  flex: 0 0 auto;
}

.champion-member-mmr {
  margin-left: auto;
}

.champion-member-card.is-front {
  opacity: 1;
  z-index: 5;
  transform: translate3d(-50%, 24px, 0) scale(1);
  box-shadow: 0 18px 38px rgba(3, 8, 19, 0.22);
}

.champion-member-card.is-right {
  opacity: 0.8;
  z-index: 4;
  transform: translate3d(calc(-50% + 186px), -12px, 0) rotateY(-30deg) scale(0.8) scaleX(1.1);
}

.champion-member-card.is-right-back {
  opacity: 0.22;
  z-index: 2;
  transform: translate3d(calc(-50% + 302px), -52px, -80px) rotateY(-36deg) scale(0.62) scaleX(1.12);
}

.champion-member-card.is-left-back {
  opacity: 0.22;
  z-index: 2;
  transform: translate3d(calc(-50% - 302px), -52px, -80px) rotateY(36deg) scale(0.62) scaleX(1.12);
}

.champion-member-card.is-left {
  opacity: 0.8;
  z-index: 4;
  transform: translate3d(calc(-50% - 186px), -12px, 0) rotateY(30deg) scale(0.8) scaleX(1.1);
}

.hero-side-stack {
  gap: 10px;
  background: linear-gradient(180deg, rgba(10, 17, 31, 0.94), rgba(15, 24, 42, 0.88));
}

.panel-header-compact {
  padding-bottom: 0;
  background: transparent;
  border: 0;
}

.panel-header-compact span {
  color: var(--stage-muted);
}

.community-card-grid,
.featured-player-grid,
.activity-list,
.leaderboard-list,
.live-scene-list,
.player-preview-grid {
  display: grid;
  gap: 8px;
}

.community-info-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.side-entry-actions,
.compact-side-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.live-scene-card,
.activity-row-card,
.leaderboard-row,
.player-preview-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(137, 163, 255, 0.12);
}

.compact-scene-card,
.compact-activity-card,
.compact-rank-row,
.compact-player-preview {
  min-height: 0;
  padding: 10px 12px;
}

.compact-activity-card,
.compact-scene-card,
.compact-rank-row,
.compact-player-preview {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(139, 163, 255, 0.14);
}

.live-scene-card,
.activity-row-card {
  align-items: start;
  justify-content: space-between;
}

.activity-row-main {
  flex: 1;
  min-width: 0;
}

.activity-row-main p,
.activity-row-main small {
  display: block;
}

.activity-row-actions {
  flex: 0 0 auto;
}

.activity-list,
.leaderboard-list,
.live-scene-list,
.player-preview-grid {
  gap: 8px;
}

.compact-activity-card .activity-row-main p,
.compact-activity-card .activity-row-main small {
  margin: 0;
  line-height: 1.35;
}

.leaderboard-copy,
.player-preview-copy {
  min-width: 0;
}

.leaderboard-copy strong,
.player-preview-copy strong,
.featured-player-card strong {
  display: block;
  margin-bottom: 4px;
}

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

.merged-player-library {
  gap: 20px;
}

.merged-player-library .card-head {
  margin-bottom: 16px;
}

.merged-library-toggle {
  min-width: 180px;
  border-radius: 999px;
  padding: 8px 14px;
  white-space: nowrap;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(137, 163, 255, 0.14);
  box-shadow: none;
}

:root[data-theme="light"] .merged-library-toggle {
  color: var(--text);
  background: rgba(255, 255, 255, 0.82);
  border-color: rgba(114, 142, 255, 0.14);
}

.player-hover-detail {
  position: fixed;
  width: 320px;
  z-index: 40;
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 24px;
  color: var(--stage-text);
  background:
    radial-gradient(circle at top right, rgba(118, 150, 255, 0.16), transparent 34%),
    radial-gradient(circle at bottom left, rgba(67, 200, 154, 0.12), transparent 26%),
    linear-gradient(180deg, rgba(12, 20, 37, 0.98), rgba(15, 25, 45, 0.96));
  border: 1px solid rgba(137, 163, 255, 0.16);
  box-shadow: 0 20px 44px rgba(3, 8, 19, 0.28);
  opacity: 0;
  transform: translateY(6px) scale(0.985);
  transition: opacity 140ms ease, transform 160ms ease;
  will-change: opacity, transform;
}

.player-hover-detail.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.player-hover-header {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding-bottom: 2px;
}

.player-hover-head-main {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
  flex: 1;
}

.player-hover-title {
  min-width: 0;
  display: grid;
  gap: 4px;
  flex: 1;
}

.player-hover-title strong,
.player-hover-title span,
.player-hover-title small {
  display: block;
}

.player-hover-title strong {
  font-size: 18px;
  line-height: 1.1;
}

.player-hover-title span,
.player-hover-title small,
.player-hover-intro,
.player-hover-tags-head span {
  color: var(--stage-muted);
}

.player-hover-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.player-hover-summary-inline {
  margin-top: 2px;
  gap: 6px;
}

.player-hover-summary-vertical {
  flex-direction: column;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 6px;
  margin-top: 0;
  min-width: 74px;
}

.player-hover-summary-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(137, 163, 255, 0.14);
  color: #eef4ff;
  font-size: 11px;
  font-weight: 600;
}

.player-hover-power-icon {
  width: 14px;
  height: 14px;
  object-fit: contain;
  margin-right: 6px;
  flex: 0 0 auto;
}

.player-hover-meta-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.player-hover-meta-item {
  display: grid;
  gap: 6px;
  padding: 10px 12px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03));
  border: 1px solid rgba(137, 163, 255, 0.12);
}

.player-hover-meta-item span {
  color: var(--stage-muted);
  font-size: 12px;
}

.player-hover-meta-item strong {
  color: #eef4ff;
  font-size: 13px;
}

.player-hover-meta-item-plain {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.player-hover-position-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
  white-space: nowrap;
  overflow: hidden;
}

.player-hover-position-row .profile-pos-icon {
  width: 18px;
  height: 18px;
}

.player-hover-intro {
  margin: 0;
  line-height: 1.55;
  padding: 2px 0 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.player-hover-intro-label {
  display: inline-block;
  color: #eef4ff;
  font-size: inherit;
  font-weight: 700;
  margin-right: 6px;
}

.player-hover-tags {
  display: grid;
  gap: 10px;
  min-height: 132px;
  padding: 12px 12px 14px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.03));
  border: 1px solid rgba(137, 163, 255, 0.12);
}

.player-hover-tags-head {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 2px 0 4px;
}

.player-hover-tags-head span {
  font-size: 12px;
  letter-spacing: 0.04em;
  padding: 0 10px;
  position: relative;
  z-index: 1;
  background: inherit;
}

.player-hover-tags-head::before,
.player-hover-tags-head::after {
  content: "";
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(137, 163, 255, 0.22), transparent);
}

.player-hover-heroes-empty {
  color: var(--stage-muted);
  font-size: 12px;
}

.player-tag-composer {
  display: grid;
  gap: 8px;
}

.player-tag-composer-inline {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  margin-top: 2px;
}

.player-tag-composer-inline input {
  width: 100%;
  min-width: 0;
  height: 30px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(137, 163, 255, 0.16);
  background: rgba(255, 255, 255, 0.08);
  color: var(--stage-text);
  font-size: 12px;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.player-tag-composer-inline input::placeholder {
  color: color-mix(in srgb, var(--stage-muted) 88%, white 12%);
}

.player-tag-composer-inline input:focus {
  border-color: rgba(137, 163, 255, 0.34);
  box-shadow: 0 0 0 3px rgba(111, 127, 255, 0.12);
}

.player-tag-composer-inline button {
  height: 30px;
  padding: 0 14px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #6f7fff, #49b2ff);
  color: #f7fbff;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 10px 20px rgba(73, 109, 255, 0.22);
}

.player-tag-composer-inline button:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(73, 109, 255, 0.26);
}

.player-tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  align-items: flex-start;
}

.player-tag-wall {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 10px 14px;
  padding: 2px 0;
}

.player-tag-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 0;
  background: transparent;
  color: #f4f8ff;
  box-shadow: none;
}

.player-tag-wall-item {
  break-inside: avoid;
  margin: 0;
  padding: 0;
  border-radius: 0;
  justify-content: flex-start;
  transform-origin: center;
  opacity: 0.96;
  transition:
    transform 160ms ease,
    filter 160ms ease;
}

.player-tag-wall-item:nth-child(3n + 1) {
  transform: rotate(-3deg) translateY(1px);
}

.player-tag-wall-item:nth-child(3n + 2) {
  transform: rotate(2.2deg) translateY(-1px);
}

.player-tag-wall-item:nth-child(3n) {
  transform: rotate(-1deg) translateY(2px);
}

.player-tag-wall-item:nth-child(4n) {
  transform: rotate(1deg) translateY(-2px);
}

.player-tag-wall-item:hover {
  transform: translateY(-4px) scale(1.05) !important;
  filter: saturate(1.08) brightness(1.06);
}

.player-tag-wall-item span {
  line-height: 1.2;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.player-tag-chip strong {
  color: currentColor;
  font-size: 0.9em;
}

.player-tag-chip.tag-tone-0 {
  color: #8be7ff;
  text-shadow: 0 0 12px rgba(139, 231, 255, 0.2);
}

.player-tag-chip.tag-tone-1 {
  color: #9ad6ff;
  text-shadow: 0 0 12px rgba(154, 214, 255, 0.2);
}

.player-tag-chip.tag-tone-2 {
  color: #b8c7ff;
  text-shadow: 0 0 12px rgba(184, 199, 255, 0.2);
}

.player-tag-chip.tag-tone-3 {
  color: #ffcfa8;
  text-shadow: 0 0 12px rgba(255, 207, 168, 0.2);
}

.player-tag-chip.tag-tone-4 {
  color: #ffd8f6;
  text-shadow: 0 0 12px rgba(255, 216, 246, 0.2);
}

.player-tag-chip.tag-tone-5 {
  color: #a6ffd6;
  text-shadow: 0 0 12px rgba(166, 255, 214, 0.2);
}

.player-tag-chip.tag-xl {
  font-size: 18px;
  padding: 11px 16px;
}

.player-tag-chip.tag-lg {
  font-size: 16px;
  padding: 10px 14px;
}

.player-tag-chip.tag-md {
  font-size: 14px;
  padding: 8px 12px;
}

.player-tag-chip.tag-sm {
  font-size: 12px;
  padding: 7px 10px;
}

.player-tag-chip.is-vote-bump {
  filter: saturate(1.12) brightness(1.08);
}

.player-tag-chip.is-vote-bump strong {
  position: relative;
  animation: tagVotePulse 360ms cubic-bezier(0.22, 1, 0.36, 1);
}

.player-tag-chip.is-vote-bump strong::after {
  content: "+1";
  position: absolute;
  left: calc(100% + 4px);
  top: -6px;
  font-size: 11px;
  font-weight: 700;
  color: #7dff95;
  text-shadow: 0 0 10px rgba(125, 255, 149, 0.22);
  animation: tagVotePlus 420ms ease-out;
}

@keyframes tagVotePulse {
  0% {
    transform: scale(1);
  }
  35% {
    transform: scale(1.18);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes tagVotePlus {
  0% {
    opacity: 0;
    transform: translateY(4px) scale(0.9);
  }
  30% {
    opacity: 1;
    transform: translateY(-2px) scale(1);
  }
  100% {
    opacity: 0;
    transform: translateY(-12px) scale(1);
  }
}

@keyframes playerDetailEnter {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

:root[data-theme="light"] .player-hover-detail {
  color: var(--text);
  background:
    radial-gradient(circle at top right, rgba(114, 142, 255, 0.14), transparent 34%),
    radial-gradient(circle at bottom left, rgba(67, 200, 154, 0.1), transparent 24%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(239, 244, 251, 0.98));
  border-color: rgba(114, 142, 255, 0.16);
}

:root[data-theme="light"] .player-hover-title span,
:root[data-theme="light"] .player-hover-title small,
:root[data-theme="light"] .player-hover-intro,
:root[data-theme="light"] .player-hover-tags-head span {
  color: var(--muted);
}

:root[data-theme="light"] .player-hover-summary-pill {
  color: #223252;
  background: rgba(114, 142, 255, 0.08);
  border-color: rgba(114, 142, 255, 0.14);
}

:root[data-theme="light"] .player-hover-meta-item {
  background: rgba(255, 255, 255, 0.86);
  border-color: rgba(114, 142, 255, 0.14);
}

:root[data-theme="light"] .player-hover-meta-item-plain {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

:root[data-theme="light"] .player-hover-meta-item strong {
  color: #223252;
}

:root[data-theme="light"] .player-hover-intro-label {
  color: #223252;
}

:root[data-theme="light"] .player-hover-tags {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(242, 247, 255, 0.9));
  border-color: rgba(114, 142, 255, 0.14);
}

:root[data-theme="light"] .player-tag-composer-inline input {
  color: var(--text);
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(114, 142, 255, 0.16);
}

:root[data-theme="light"] .player-tag-composer-inline input::placeholder {
  color: color-mix(in srgb, var(--muted) 90%, white 10%);
}

:root[data-theme="light"] .player-tag-chip {
  color: #2c446d;
}

:root[data-theme="light"] .player-tag-chip {
  color: var(--text);
  background: rgba(255, 255, 255, 0.88);
  border-color: rgba(114, 142, 255, 0.14);
}

.poster-preview-grid {
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 10px;
  --poster-grid-gap: 10px;
  --poster-card-size: calc((100% - 7 * var(--poster-grid-gap)) / 8);
  max-height: none;
  overflow: visible;
}

.merged-library-filters {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transform: translateY(-8px);
  transition:
    max-height 360ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 260ms ease,
    transform 360ms cubic-bezier(0.22, 1, 0.36, 1),
    margin 360ms cubic-bezier(0.22, 1, 0.36, 1);
  margin-top: -6px;
}

.merged-library-filters.expanded {
  max-height: 120px;
  opacity: 1;
  transform: translateY(0);
  margin-top: 0;
}

.poster-preview-grid {
  transition:
    grid-template-columns 320ms ease,
    opacity 260ms ease,
    transform 360ms cubic-bezier(0.22, 1, 0.36, 1);
  transform: translateY(0);
}

.poster-preview-grid.expanded {
  transform: translateY(8px);
  max-height: none;
  overflow: visible;
}

.home-main-stage button {
  box-shadow: 0 10px 22px rgba(20, 31, 61, 0.34);
}

.home-main-stage .secondary-button,
.page-nav-hub .secondary-button {
  color: var(--stage-text);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: none;
}

.featured-player-rank {
  display: inline-flex;
  width: fit-content;
  padding: 4px 10px;
  border-radius: 999px;
  color: white;
  background: linear-gradient(135deg, #7788ff, #57b8ff);
  font-size: 12px;
  font-weight: 700;
}

.spotlight-shell,
.directory-shell {
  border-radius: 28px;
  padding: 16px;
}

.page-shell-home .collapsible-panel,
.page-shell-home .directory-shell,
.page-shell-home .embedded-directory-shell,
.page-shell-home .collapsible-panel .collapsible-body {
  background: linear-gradient(135deg, var(--stage-panel), var(--stage-panel-2));
  border-color: var(--stage-line);
  color: var(--stage-text);
  box-shadow: var(--stage-shadow-soft);
}

.page-shell-home .collapsible-trigger,
.page-shell-home .collapsible-trigger span,
.page-shell-home .card-head span,
.page-shell-home .directory-shell span,
.page-shell-home .directory-shell p,
.page-shell-home .directory-shell label,
.page-shell-home .directory-shell small,
.page-shell-home .muted-line {
  color: var(--stage-muted);
}

.page-shell-home input,
.page-shell-home textarea,
.page-shell-home select {
  color: var(--stage-text);
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(130, 156, 255, 0.14);
}

.page-shell-home .community-section,
.page-shell-home .leaderboard-shell,
.page-shell-home #player-preview {
  background: linear-gradient(135deg, var(--stage-panel), var(--stage-panel-2));
  border-color: var(--stage-line);
  box-shadow: var(--stage-shadow-soft);
}

:root[data-theme="light"] .page-shell-home {
  color: var(--text);
}

:root[data-theme="light"] .page-shell-home .community-info-card,
:root[data-theme="light"] .page-shell-home .player-preview-card,
:root[data-theme="light"] .page-shell-home .leaderboard-row,
:root[data-theme="light"] .page-shell-home .activity-row-card,
:root[data-theme="light"] .page-shell-home .hero-feature-card {
  background:
    radial-gradient(circle at top right, rgba(86, 117, 227, 0.12), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(236, 243, 255, 0.98));
  border-color: rgba(86, 117, 227, 0.2);
  box-shadow: 0 10px 22px rgba(103, 129, 210, 0.14);
}

:root[data-theme="light"] .global-theme-toggle .theme-toggle-button,
:root[data-theme="light"] .global-music-toggle .theme-toggle-button {
  color: var(--text);
  background: rgba(255, 255, 255, 0.88);
  border-color: rgba(114, 142, 255, 0.14);
}

:root[data-theme="light"] .admin-sidebar,
:root[data-theme="light"] .admin-card,
:root[data-theme="light"] .admin-drawer-panel {
  background:
    radial-gradient(circle at top right, rgba(102, 133, 255, 0.12), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(245, 249, 255, 0.92));
  border-color: rgba(114, 142, 255, 0.18);
  box-shadow: 0 18px 38px rgba(103, 129, 210, 0.12);
}

:root[data-theme="light"] .admin-segmented-item,
:root[data-theme="light"] .admin-entity-card,
:root[data-theme="light"] .admin-entity-panel,
:root[data-theme="light"] .admin-inline-pill {
  border-color: rgba(114, 142, 255, 0.18);
}

:root[data-theme="light"] .admin-segmented-item span,
:root[data-theme="light"] .admin-card span,
:root[data-theme="light"] .admin-card label,
:root[data-theme="light"] .admin-card .muted-line,
:root[data-theme="light"] .admin-card small,
:root[data-theme="light"] .admin-card p,
:root[data-theme="light"] .admin-entity-meta-grid,
:root[data-theme="light"] .admin-inline-pill {
  color: #5b6a88;
}

:root[data-theme="light"] .admin-entity-card {
  background: rgba(255, 255, 255, 0.78);
}

:root[data-theme="light"] .admin-entity-card.is-expanded {
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 16px 30px rgba(103, 129, 210, 0.12);
}

:root[data-theme="light"] .admin-entity-panel {
  background: rgba(241, 246, 255, 0.72);
}

:root[data-theme="light"] .admin-inline-pill {
  background: rgba(246, 249, 255, 0.96);
}

:root[data-theme="light"] .admin-card .secondary-button,
:root[data-theme="light"] .admin-card .ghost-button {
  color: #2c3b5c;
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(114, 142, 255, 0.2);
  box-shadow: 0 8px 18px rgba(103, 129, 210, 0.08);
}

:root[data-theme="light"] .admin-card input,
:root[data-theme="light"] .admin-card textarea,
:root[data-theme="light"] .admin-card select {
  background: rgba(255, 255, 255, 0.98);
  border-color: rgba(114, 142, 255, 0.22);
}

:root[data-theme="light"] .music-panel {
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(114, 142, 255, 0.14);
}

:root[data-theme="light"] .nav-auth-drawer {
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(114, 142, 255, 0.14);
}

:root[data-theme="light"] .page-shell-home input,
:root[data-theme="light"] .page-shell-home textarea,
:root[data-theme="light"] .page-shell-home select {
  color: var(--text);
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(86, 117, 227, 0.2);
}

:root[data-theme="light"] .nav-drawer-form label {
  color: var(--muted);
}

:root[data-theme="light"] .champion-member-card.player-profile-card {
  background:
    radial-gradient(circle at top right, rgba(86, 117, 227, 0.14), transparent 20%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(237, 244, 255, 0.98));
  border-color: rgba(86, 117, 227, 0.16);
  box-shadow: 0 14px 30px rgba(103, 129, 210, 0.16);
}

:root[data-theme="light"] .champion-member-rank {
  color: #6a4300;
  background: linear-gradient(135deg, rgba(255, 184, 79, 0.38), rgba(86, 117, 227, 0.22));
}

:root[data-theme="light"] .champion-member-copy {
  background: transparent;
  border-color: transparent;
}

:root[data-theme="light"] .champion-member-copy strong {
  color: var(--text);
  text-shadow: none;
}

:root[data-theme="light"] .page-shell-home .community-info-head strong,
:root[data-theme="light"] .page-shell-home .card-head h2,
:root[data-theme="light"] .page-shell-home .card-head h3,
:root[data-theme="light"] .page-shell-home .leaderboard-copy strong,
:root[data-theme="light"] .page-shell-home .activity-row-main strong,
:root[data-theme="light"] .page-shell-home .live-scene-card strong,
:root[data-theme="light"] .page-shell-home .community-side-panel strong {
  color: #203150;
}

:root[data-theme="light"] .page-shell-home .card-head span,
:root[data-theme="light"] .page-shell-home .community-info-card p,
:root[data-theme="light"] .page-shell-home .community-side-panel span,
:root[data-theme="light"] .page-shell-home .community-side-panel p,
:root[data-theme="light"] .page-shell-home .community-side-panel small,
:root[data-theme="light"] .page-shell-home .activity-row-main p,
:root[data-theme="light"] .page-shell-home .activity-row-main small,
:root[data-theme="light"] .page-shell-home .leaderboard-copy small,
:root[data-theme="light"] .page-shell-home .hero-feature-meta {
  color: #5b6b88;
}

:root[data-theme="light"] .page-shell-home button.secondary-button,
:root[data-theme="light"] .page-shell-home button.ghost-button {
  color: #203150;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(229, 239, 255, 0.96));
  border-color: rgba(86, 117, 227, 0.22);
  box-shadow: 0 8px 18px rgba(103, 129, 210, 0.14);
}

:root[data-theme="light"] .page-shell-home button.secondary-button:hover,
:root[data-theme="light"] .page-shell-home button.ghost-button:hover {
  background: linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(220, 233, 255, 1));
  border-color: rgba(86, 117, 227, 0.32);
}

/* Top-right controls on home: keep outlined style without gradient fill */
.page-shell-home .page-nav .nav-auth-entry-row .secondary-button,
.page-shell-home .page-nav .nav-auth-entry-row .ghost-button,
.page-shell-home .page-nav .nav-auth-logged .secondary-button,
.page-shell-home .global-theme-toggle .theme-toggle-button,
.page-shell-home .global-music-toggle .theme-toggle-button {
  background: transparent !important;
  box-shadow: none !important;
  border: 1px solid rgba(118, 150, 255, 0.28);
}

.page-shell-home .page-nav .nav-auth-entry-row .secondary-button:hover,
.page-shell-home .page-nav .nav-auth-entry-row .ghost-button:hover,
.page-shell-home .page-nav .nav-auth-logged .secondary-button:hover,
.page-shell-home .global-theme-toggle .theme-toggle-button:hover,
.page-shell-home .global-music-toggle .theme-toggle-button:hover {
  background: transparent !important;
  border-color: rgba(118, 150, 255, 0.44);
  box-shadow: none !important;
}

:root[data-theme="light"] .page-shell-home button.action-button {
  color: #fff;
  background: linear-gradient(135deg, #5b73ff, #2ea7ff);
  border-color: rgba(65, 111, 255, 0.36);
  box-shadow: 0 10px 22px rgba(65, 111, 255, 0.22);
}

:root[data-theme="light"] .page-shell-home button.success-button {
  color: #fff;
  background: linear-gradient(135deg, #24b874, #4ad8b1);
  border-color: rgba(36, 184, 116, 0.3);
  box-shadow: 0 10px 22px rgba(36, 184, 116, 0.18);
}

:root[data-theme="light"] .page-shell-home .status-badge.phase-info {
  color: #2646a3;
  background: rgba(86, 117, 227, 0.14);
  border-color: rgba(86, 117, 227, 0.22);
}

:root[data-theme="light"] .page-shell-home .status-badge.phase-live {
  color: #0f7b56;
  background: rgba(36, 184, 116, 0.14);
  border-color: rgba(36, 184, 116, 0.22);
}

:root[data-theme="light"] .page-shell-home .status-badge.phase-warning {
  color: #8c5700;
  background: rgba(255, 165, 50, 0.16);
  border-color: rgba(255, 165, 50, 0.24);
}

:root[data-theme="light"] .featured-player-rank {
  background: linear-gradient(135deg, #5b73ff, #2ea7ff);
}

:root[data-theme="light"] .spotlight-event-card {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.16), rgba(232, 240, 255, 0.2)),
    radial-gradient(circle at top right, rgba(86, 117, 227, 0.06), transparent 24%),
    radial-gradient(circle at bottom left, rgba(255, 184, 79, 0.04), transparent 20%),
    url("/assets/featured-event-bg.jpg");
  background-size: cover;
  background-position: center 42%;
  border-color: rgba(86, 117, 227, 0.2);
  color: #203150;
  box-shadow: 0 14px 28px rgba(103, 129, 210, 0.16);
}

:root[data-theme="light"] .champion-member-copy span,
:root[data-theme="light"] .champion-member-copy small {
  color: var(--muted);
  text-shadow: none;
}

:root[data-theme="light"] .champion-poster-caption .champion-member-rank {
  color: #735118;
  background: linear-gradient(135deg, rgba(255, 184, 79, 0.26), rgba(114, 142, 255, 0.16));
}

:root[data-theme="light"] .player-poster-caption {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.56), rgba(244, 248, 255, 0.6));
  border-color: rgba(114, 142, 255, 0.18);
  backdrop-filter: blur(10px);
}

:root[data-theme="light"] .champion-poster-caption {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.56), rgba(244, 248, 255, 0.6));
  border-color: rgba(114, 142, 255, 0.18);
  backdrop-filter: blur(10px);
}

:root[data-theme="light"] .player-poster-heading strong {
  color: var(--text);
  text-shadow: none;
}

:root[data-theme="light"] .player-poster-meta {
  color: #566784;
}

:root[data-theme="light"] .player-hover-meta-item {
  background: rgba(255, 255, 255, 0.9);
  border-color: rgba(114, 142, 255, 0.16);
}

:root[data-theme="light"] .player-hover-meta-item.player-hover-meta-item-plain {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

:root[data-theme="light"] .hero-event-spotlight .card-head span,
:root[data-theme="light"] .hero-event-spotlight p,
:root[data-theme="light"] .hero-feature-meta {
  color: var(--muted);
}

:root[data-theme="light"] .hero-event-spotlight .community-info-head strong {
  color: var(--text);
}

:root[data-theme="light"] .spotlight-event-card {
  color: var(--text);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.14), rgba(229, 255, 248, 0.18)),
    radial-gradient(circle at top right, rgba(118, 135, 255, 0.06), transparent 26%),
    url("/assets/featured-event-bg.jpg");
  background-size: cover;
  background-position: center 42%;
  border-color: rgba(114, 142, 255, 0.14);
}

:root[data-theme="light"] .hero-title-band h1 {
  background: linear-gradient(180deg, #6a7dff 0%, #5f76ff 36%, #6ab7ff 72%, #7a88d8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.18);
  text-shadow:
    0 2px 0 rgba(123, 140, 255, 0.18),
    0 8px 18px rgba(103, 129, 210, 0.12);
}

:root[data-theme="light"] .hero-champion-congrats {
  color: var(--text);
  text-shadow: 0 4px 14px rgba(103, 129, 210, 0.14);
}

:root[data-theme="dark"] .left-panel {
  background: linear-gradient(180deg, rgba(14, 22, 40, 0.96), rgba(10, 17, 31, 0.94));
  border-color: rgba(118, 150, 255, 0.22);
}

:root[data-theme="dark"] .right-panel {
  background: linear-gradient(180deg, rgba(12, 20, 37, 0.96), rgba(10, 17, 31, 0.94));
  border-color: rgba(118, 150, 255, 0.16);
}

:root[data-theme="dark"] .center-stage,
:root[data-theme="dark"] .inhouse-shell,
:root[data-theme="dark"] .auction-topbar {
  background:
    radial-gradient(circle at top center, rgba(118, 150, 255, 0.14), transparent 24%),
    linear-gradient(180deg, rgba(12, 20, 37, 0.94), rgba(16, 26, 46, 0.92));
  border-color: rgba(118, 150, 255, 0.18);
  box-shadow: var(--stage-shadow-strong);
}

:root[data-theme="dark"] .hero-player-card,
:root[data-theme="dark"] .metric-card,
:root[data-theme="dark"] .price-box,
:root[data-theme="dark"] .team-card,
:root[data-theme="dark"] .auction-editor-shell,
:root[data-theme="dark"] .import-panel,
:root[data-theme="dark"] .budget-assignment,
:root[data-theme="dark"] .tournament-admin-shell,
:root[data-theme="dark"] .check-card,
:root[data-theme="dark"] .pick-option,
:root[data-theme="dark"] .table-row,
:root[data-theme="dark"] .mini-player-card,
:root[data-theme="dark"] .history-row,
:root[data-theme="dark"] .player-event-card,
:root[data-theme="dark"] .event-summary div {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(118, 150, 255, 0.16);
  color: var(--stage-text);
  box-shadow: none;
}

:root[data-theme="dark"] .admin-workspace-shell .metric-card,
:root[data-theme="dark"] .admin-sidebar,
:root[data-theme="dark"] .admin-card,
:root[data-theme="dark"] .admin-workspace-shell .import-panel,
:root[data-theme="dark"] .admin-workspace-shell .budget-assignment,
:root[data-theme="dark"] .admin-workspace-shell .auction-editor-shell,
:root[data-theme="dark"] .admin-workspace-shell .tournament-admin-shell {
  background:
    radial-gradient(circle at top right, rgba(118, 150, 255, 0.12), transparent 26%),
    linear-gradient(180deg, rgba(13, 21, 39, 0.96), rgba(10, 17, 31, 0.94));
  border-color: rgba(118, 150, 255, 0.14);
  box-shadow: 0 12px 28px rgba(3, 8, 19, 0.18);
}

:root[data-theme="dark"] .admin-workspace-shell .metric-card strong,
:root[data-theme="dark"] .admin-card h2,
:root[data-theme="dark"] .admin-card h3,
:root[data-theme="dark"] .admin-card h4,
:root[data-theme="dark"] .admin-drawer-panel h2,
:root[data-theme="dark"] .admin-drawer-panel h3,
:root[data-theme="dark"] .admin-drawer-panel h4,
:root[data-theme="dark"] .admin-card strong,
:root[data-theme="dark"] .admin-drawer-panel strong,
:root[data-theme="dark"] .admin-card .section-title h4,
:root[data-theme="dark"] .admin-card .section-title h3,
:root[data-theme="dark"] .admin-drawer-panel .section-title h4,
:root[data-theme="dark"] .admin-drawer-panel .section-title h3 {
  color: #eef4ff;
}

:root[data-theme="dark"] .admin-workspace-shell .metric-card span,
:root[data-theme="dark"] .admin-workspace-shell .metric-card small,
:root[data-theme="dark"] .admin-inline-pill,
:root[data-theme="dark"] .admin-segmented-item span,
:root[data-theme="dark"] .admin-card span,
:root[data-theme="dark"] .admin-card label,
:root[data-theme="dark"] .admin-card .muted-line,
:root[data-theme="dark"] .admin-card small,
:root[data-theme="dark"] .admin-card p,
:root[data-theme="dark"] .admin-drawer-panel span,
:root[data-theme="dark"] .admin-drawer-panel label,
:root[data-theme="dark"] .admin-drawer-panel .muted-line,
:root[data-theme="dark"] .admin-drawer-panel small,
:root[data-theme="dark"] .admin-drawer-panel p,
:root[data-theme="dark"] .admin-card .section-title span,
:root[data-theme="dark"] .admin-card .table-row-copy span,
:root[data-theme="dark"] .admin-card .check-card-copy small,
:root[data-theme="dark"] .admin-drawer-panel .section-title span,
:root[data-theme="dark"] .admin-drawer-panel .table-row-copy span,
:root[data-theme="dark"] .admin-drawer-panel .check-card-copy small,
:root[data-theme="dark"] .admin-drawer-panel .file-pick-name,
:root[data-theme="dark"] .admin-drawer-panel .checkbox-label,
:root[data-theme="dark"] .admin-drawer-panel .position-picker-label,
:root[data-theme="dark"] .admin-drawer-panel .hero-picker-label {
  color: rgba(220, 230, 250, 0.82);
}

:root[data-theme="dark"] .admin-card input,
:root[data-theme="dark"] .admin-card textarea,
:root[data-theme="dark"] .admin-card select,
:root[data-theme="dark"] .admin-drawer-panel input,
:root[data-theme="dark"] .admin-drawer-panel textarea,
:root[data-theme="dark"] .admin-drawer-panel select {
  color: #eef4ff;
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(118, 150, 255, 0.2);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

:root[data-theme="dark"] .admin-card input::placeholder,
:root[data-theme="dark"] .admin-card textarea::placeholder,
:root[data-theme="dark"] .admin-drawer-panel input::placeholder,
:root[data-theme="dark"] .admin-drawer-panel textarea::placeholder {
  color: rgba(220, 230, 250, 0.54);
}

:root[data-theme="dark"] .admin-card .secondary-button,
:root[data-theme="dark"] .admin-card .ghost-button,
:root[data-theme="dark"] .admin-drawer-panel .secondary-button,
:root[data-theme="dark"] .admin-drawer-panel .ghost-button {
  color: #e9f0ff;
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(118, 150, 255, 0.2);
  box-shadow: 0 10px 20px rgba(3, 8, 19, 0.16);
}

:root[data-theme="dark"] .admin-inline-toolbar,
:root[data-theme="dark"] .admin-drawer-panel,
:root[data-theme="dark"] .admin-segmented-item,
:root[data-theme="dark"] .admin-form-section {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(118, 150, 255, 0.16);
  color: #eef4ff;
}

:root[data-theme="dark"] .admin-inline-pill {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(118, 150, 255, 0.2);
}

:root[data-theme="dark"] .admin-entity-card {
  background: rgba(15, 24, 42, 0.8);
  border-color: rgba(118, 150, 255, 0.18);
}

:root[data-theme="dark"] .admin-entity-card.is-expanded {
  background: rgba(20, 32, 56, 0.9);
  box-shadow: 0 20px 36px rgba(3, 8, 19, 0.28);
}

:root[data-theme="dark"] .admin-entity-panel {
  background: rgba(8, 14, 28, 0.42);
  border-top-color: rgba(118, 150, 255, 0.16);
}

:root[data-theme="dark"] .admin-segmented-item.is-active {
  background: linear-gradient(135deg, rgba(119, 136, 255, 0.96), rgba(87, 184, 255, 0.92));
}

:root[data-theme="dark"] .auth-panel .secondary-button,
:root[data-theme="dark"] .auth-panel .ghost-button,
:root[data-theme="dark"] .session-actions .secondary-button,
:root[data-theme="dark"] .session-actions .ghost-button,
:root[data-theme="dark"] .subtle-admin-entry {
  color: #e9f0ff;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(118, 150, 255, 0.14);
  box-shadow: none;
}

:root[data-theme="dark"] .auth-panel .secondary-button:hover,
:root[data-theme="dark"] .auth-panel .ghost-button:hover,
:root[data-theme="dark"] .session-actions .secondary-button:hover,
:root[data-theme="dark"] .session-actions .ghost-button:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(118, 150, 255, 0.22);
}

:root[data-theme="dark"] .admin-card .selection-bar,
:root[data-theme="dark"] .admin-card .event-summary,
:root[data-theme="dark"] .admin-card .toolbar-grid,
:root[data-theme="dark"] .admin-card .file-pick-row,
:root[data-theme="dark"] .admin-card .import-actions,
:root[data-theme="dark"] .admin-card .form-actions.top-space,
:root[data-theme="dark"] .admin-card .inhouse-mode-row,
:root[data-theme="dark"] .admin-drawer-panel .selection-bar,
:root[data-theme="dark"] .admin-drawer-panel .event-summary,
:root[data-theme="dark"] .admin-drawer-panel .toolbar-grid,
:root[data-theme="dark"] .admin-drawer-panel .file-pick-row,
:root[data-theme="dark"] .admin-drawer-panel .import-actions,
:root[data-theme="dark"] .admin-drawer-panel .form-actions.top-space,
:root[data-theme="dark"] .admin-drawer-panel .inhouse-mode-row {
  align-items: start;
}

:root[data-theme="dark"] .admin-card .event-summary div,
:root[data-theme="dark"] .admin-card .event-overview-card,
:root[data-theme="dark"] .admin-card .check-card,
:root[data-theme="dark"] .admin-card .table-row,
:root[data-theme="dark"] .admin-card .player-event-card {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(118, 150, 255, 0.12);
}

:root[data-theme="dark"] .admin-card .event-overview-card.selected-overview {
  background: linear-gradient(135deg, rgba(119, 136, 255, 0.2), rgba(87, 184, 255, 0.14));
  border-color: rgba(111, 127, 255, 0.28);
}

:root[data-theme="dark"] .admin-card .table-list,
:root[data-theme="dark"] .admin-card .checkbox-grid,
:root[data-theme="dark"] .admin-card .event-overview-list {
  gap: 10px;
}

:root[data-theme="dark"] .admin-card .card-head {
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(118, 150, 255, 0.1);
}

:root[data-theme="dark"] .admin-card .admin-card-body {
  padding-top: 6px;
}

:root[data-theme="dark"] .admin-form-section {
  background: rgba(255, 255, 255, 0.035);
  border-color: rgba(118, 150, 255, 0.1);
}

:root[data-theme="dark"] .admin-form-subsection,
:root[data-theme="dark"] .budget-assignment,
:root[data-theme="dark"] .import-panel {
  background: rgba(255, 255, 255, 0.028);
}

:root[data-theme="dark"] .admin-drawer-panel .admin-form-subsection,
:root[data-theme="dark"] .admin-drawer-panel .budget-assignment,
:root[data-theme="dark"] .admin-drawer-panel .import-panel,
:root[data-theme="dark"] .admin-drawer-panel .selection-bar,
:root[data-theme="dark"] .admin-drawer-panel .file-pick-row,
:root[data-theme="dark"] .admin-drawer-panel .toolbar-grid {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(118, 150, 255, 0.16);
  color: #eef4ff;
}

:root[data-theme="dark"] .admin-drawer-panel .check-card {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(118, 150, 255, 0.16);
  color: #eef4ff;
}

:root[data-theme="dark"] .admin-drawer-panel .check-card input[type="checkbox"] {
  accent-color: #7b8cff;
}

:root[data-theme="dark"] .history-strip span,
:root[data-theme="dark"] .auction-roster-player,
:root[data-theme="dark"] .auction-roster-player-empty {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(118, 150, 255, 0.14);
}

:root[data-theme="dark"] .admin-card,
:root[data-theme="dark"] .admin-card-body,
:root[data-theme="dark"] .table-list,
:root[data-theme="dark"] .checkbox-grid,
:root[data-theme="dark"] .event-overview-list,
:root[data-theme="dark"] .player-event-list,
:root[data-theme="dark"] .queue-list,
:root[data-theme="dark"] .history-list {
  scrollbar-color: rgba(118, 150, 255, 0.38) rgba(255, 255, 255, 0.04);
}

:root[data-theme="dark"] .admin-card::-webkit-scrollbar,
:root[data-theme="dark"] .admin-card-body::-webkit-scrollbar,
:root[data-theme="dark"] .table-list::-webkit-scrollbar,
:root[data-theme="dark"] .checkbox-grid::-webkit-scrollbar,
:root[data-theme="dark"] .event-overview-list::-webkit-scrollbar,
:root[data-theme="dark"] .player-event-list::-webkit-scrollbar,
:root[data-theme="dark"] .queue-list::-webkit-scrollbar,
:root[data-theme="dark"] .history-list::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

:root[data-theme="dark"] .admin-card::-webkit-scrollbar-track,
:root[data-theme="dark"] .admin-card-body::-webkit-scrollbar-track,
:root[data-theme="dark"] .table-list::-webkit-scrollbar-track,
:root[data-theme="dark"] .checkbox-grid::-webkit-scrollbar-track,
:root[data-theme="dark"] .event-overview-list::-webkit-scrollbar-track,
:root[data-theme="dark"] .player-event-list::-webkit-scrollbar-track,
:root[data-theme="dark"] .queue-list::-webkit-scrollbar-track,
:root[data-theme="dark"] .history-list::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.03);
  border-radius: 999px;
}

:root[data-theme="dark"] .admin-card::-webkit-scrollbar-thumb,
:root[data-theme="dark"] .admin-card-body::-webkit-scrollbar-thumb,
:root[data-theme="dark"] .table-list::-webkit-scrollbar-thumb,
:root[data-theme="dark"] .checkbox-grid::-webkit-scrollbar-thumb,
:root[data-theme="dark"] .event-overview-list::-webkit-scrollbar-thumb,
:root[data-theme="dark"] .player-event-list::-webkit-scrollbar-thumb,
:root[data-theme="dark"] .queue-list::-webkit-scrollbar-thumb,
:root[data-theme="dark"] .history-list::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(118, 150, 255, 0.5), rgba(87, 184, 255, 0.34));
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}

:root[data-theme="dark"] .auction-roster-player-captain {
  background: rgba(255, 184, 79, 0.14);
  border-color: rgba(255, 184, 79, 0.22);
}

:root[data-theme="dark"] .tag,
:root[data-theme="dark"] .pill,
:root[data-theme="dark"] .budget-chip,
:root[data-theme="dark"] .status-pill,
:root[data-theme="dark"] .auction-team-power,
:root[data-theme="dark"] .auction-player-power,
:root[data-theme="dark"] .auction-player-positions {
  color: var(--stage-text);
}

:root[data-theme="dark"] .warning-button {
  color: #2f2000;
}

@keyframes authDrawerSlideIn {
  0% {
    opacity: 0;
    transform: translateY(-10px) scale(0.985);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes authDrawerSlideOut {
  0% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  100% {
    opacity: 0;
    transform: translateY(-10px) scale(0.985);
  }
}

.collapsible-panel {
  display: grid;
  gap: 0;
  overflow: hidden;
}

.collapsible-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  padding: 14px 16px;
  background: transparent;
  color: inherit;
  border-radius: 22px;
}

.collapsible-trigger strong {
  display: block;
  text-align: left;
}

.collapsible-trigger span {
  color: var(--muted);
}

.collapsible-indicator {
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 700;
}

.collapsible-panel .collapsible-body {
  padding: 0 16px 16px;
}

.collapsible-panel.collapsed .collapsible-body {
  display: none;
}

.collapsible-home-body .directory-shell,
.collapsible-home-body .spotlight-shell {
  border-radius: 22px;
}

.embedded-directory-shell {
  padding: 0;
  border: 0;
  box-shadow: none;
  background: transparent;
}

.collapsible-home-body .directory-shell {
  height: auto;
}

.spotlight-shell-inline {
  background:
    radial-gradient(circle at top right, rgba(118, 135, 255, 0.16), transparent 26%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(229, 255, 248, 0.9));
}

.directory-shell {
  display: flex;
  flex-direction: column;
  min-height: 0;
  height: auto;
  overflow: hidden;
}

.spotlight-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) 280px;
  gap: 18px;
  align-items: stretch;
  background:
    radial-gradient(circle at top right, rgba(118, 135, 255, 0.16), transparent 26%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(229, 255, 248, 0.9));
}

.spotlight-side {
  display: grid;
  align-content: center;
  gap: 10px;
  padding: 20px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--line);
}

.spotlight-side span {
  color: var(--muted);
}

.spotlight-side strong {
  font-size: 22px;
  line-height: 1.4;
}

.status-live,
.status-closed {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 3px 10px;
  font-weight: 700;
}

.status-live {
  color: #0e7d5f;
  background: rgba(110, 217, 200, 0.22);
  animation: livePulse 1.6s ease-in-out infinite;
}

.status-closed {
  color: #8d5e14;
  background: rgba(255, 191, 90, 0.22);
}

.status-badge,
.tag.phase-live,
.tag.phase-warning,
.tag.phase-info,
.tag.phase-muted {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 10px;
  font-weight: 700;
  border: 1px solid transparent;
}

.phase-live {
  color: #afffe4;
  background: rgba(39, 211, 162, 0.16);
  border-color: rgba(39, 211, 162, 0.26);
}

.phase-warning {
  color: #ffd58c;
  background: rgba(255, 184, 79, 0.16);
  border-color: rgba(255, 184, 79, 0.26);
}

.phase-info {
  color: #d3dcff;
  background: rgba(123, 140, 255, 0.18);
  border-color: rgba(123, 140, 255, 0.26);
}

.phase-muted {
  color: #c4d0e7;
  background: rgba(152, 170, 200, 0.12);
  border-color: rgba(152, 170, 200, 0.18);
}

.budget-assignment {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid var(--line);
}

.import-panel {
  display: grid;
  gap: 12px;
  padding: 16px;
  margin-bottom: 18px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid var(--line);
}

.import-toolbar {
  margin: 0;
}

.file-pick-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.file-pick-name {
  font-size: 0.88em;
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 180px;
}

.import-actions {
  display: flex;
  align-items: end;
}

.position-picker {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.position-picker-label {
  font-size: 0.88em;
  color: var(--muted);
}

.position-picker-options {
  display: flex;
  gap: 6px;
}

.nav-auth-drawer .position-pick-btn {
  width: 0;
  height: auto;
  flex: 1 1 0;
  aspect-ratio: 1;
  padding: 5px;
}

.nav-auth-drawer .form-actions {
  flex-wrap: wrap;
}

.position-pick-btn {
  width: 48px;
  height: auto;
  flex: 0 0 48px;
  aspect-ratio: 1 / 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  border-radius: 8px;
  border: 2px solid var(--line);
  background: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  opacity: 0.5;
  transition: opacity 160ms ease, border-color 160ms ease, transform 120ms ease, box-shadow 160ms ease;
}

.position-pick-btn img {
  width: 88%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  pointer-events: none;
}

.position-pick-btn.selected {
  opacity: 1;
  border-color: #7788ff;
  box-shadow: 0 0 0 2px rgba(119, 136, 255, 0.3);
}

.position-pick-btn:hover {
  opacity: 0.85;
  transform: scale(1.08);
}

.position-pick-btn.selected:hover {
  opacity: 1;
}

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

.player-event-shell {
  border-radius: 28px;
  padding: 24px;
}

.toolbar-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 12px;
  margin: 16px 0 18px;
}

.player-event-card p {
  margin: 6px 0 0;
  color: var(--muted);
}

.directory-list {
  grid-template-columns: repeat(8, minmax(0, 1fr));
  --directory-list-gap: 10px;
  --directory-card-row-height: calc((100% - 7 * var(--directory-list-gap)) / 8);
  flex: 0 0 auto;
  min-height: 0;
  overflow: auto;
  padding-right: 4px;
  gap: var(--directory-list-gap);
  grid-auto-rows: var(--directory-card-row-height);
  max-height: calc(
    var(--directory-visible-rows, 4) * var(--directory-card-row-height) +
      (var(--directory-visible-rows, 4) - 1) * var(--directory-list-gap)
  );
  overscroll-behavior: contain;
}

.directory-card {
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.68);
  display: grid;
  gap: 12px;
  height: 100%;
}

.directory-card-head {
  display: flex;
  gap: 12px;
  align-items: center;
}

.directory-card-head p,
.directory-intro {
  margin: 6px 0 0;
  color: var(--muted);
}

.pick-option.selected,
.team-card.highlight {
  border-color: rgba(111, 127, 255, 0.52);
  box-shadow: 0 18px 40px rgba(111, 127, 255, 0.16);
}

.mini-player-card {
  display: flex;
  gap: 12px;
  align-items: center;
}

.player-profile-card {
  border: 1px solid rgba(111, 127, 255, 0.16);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(241, 246, 255, 0.9));
  box-shadow: 0 16px 32px rgba(79, 103, 177, 0.12);
}

.champion-member-card.player-profile-card {
  background: #0b1220;
  border: 1px solid rgba(137, 163, 255, 0.1);
  box-shadow: 0 14px 30px rgba(3, 8, 19, 0.18);
}

.player-card-girl {
  border-color: rgba(255, 105, 180, 0.55) !important;
  box-shadow: 0 16px 32px rgba(255, 105, 180, 0.16);
}

.girl-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 6px;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(255, 105, 180, 0.14);
  color: #ff4fa3;
  border: 1px solid rgba(255, 105, 180, 0.28);
  font-size: 12px;
  line-height: 1;
  vertical-align: middle;
}

.checkbox-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.player-profile-card-large {
  gap: 14px;
}

.player-poster-card {
  position: relative;
  padding: 0;
  min-height: 0;
  height: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border: 2.5px solid var(--poster-accent, rgba(125, 140, 255, 0.55));
  background:
    radial-gradient(circle at top center, rgba(125, 140, 255, 0.2), transparent 36%),
    linear-gradient(180deg, rgba(233, 239, 255, 0.96), rgba(214, 227, 255, 0.94));
  box-shadow:
    0 14px 28px rgba(79, 103, 177, 0.12),
    0 0 0 1px color-mix(in srgb, var(--poster-accent, #8aa6ff) 28%, transparent);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.player-poster-card::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: 24px;
  border: 2px solid transparent;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.player-poster-card:hover {
  transform: translateY(-4px);
  box-shadow:
    0 24px 42px rgba(17, 24, 39, 0.3),
    0 0 0 2px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #b2c2ff)) 78%, transparent),
    0 0 26px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #b2c2ff)) 44%, transparent),
    0 0 44px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #b2c2ff)) 24%, transparent);
  border-color: var(--poster-accent-bright, var(--poster-accent, rgba(160, 180, 255, 0.72)));
}

.player-poster-card:hover::after {
  opacity: 1;
  border-color: color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 92%, white 8%);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 95%, white 5%),
    0 0 18px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 58%, transparent),
    0 0 34px color-mix(in srgb, var(--poster-accent-bright, var(--poster-accent, #d7e2ff)) 34%, transparent);
}

.player-poster-art {
  position: absolute;
  inset: 0;
}

.player-poster-shade {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(10, 16, 30, 0.08) 0%, rgba(10, 16, 30, 0.14) 34%, rgba(10, 16, 30, 0.72) 100%),
    radial-gradient(circle at 50% 18%, rgba(255, 255, 255, 0.12), transparent 26%);
  z-index: 0;
}

.player-poster-avatar {
  width: 100%;
  height: 100%;
  border-radius: 0;
  box-shadow: none;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #7d8cff, #67dfc4);
  color: white;
  font-size: 3rem;
  font-weight: 700;
}

.player-poster-avatar.image-avatar img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.player-poster-caption {
  position: absolute;
  left: 8px;
  right: 8px;
  bottom: 8px;
  z-index: 1;
  display: grid;
  gap: 5px;
  padding: 10px 10px 9px;
  border-radius: 13px;
  background: linear-gradient(180deg, rgba(18, 25, 44, 0.42), rgba(18, 25, 44, 0.7));
  border: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
}

.player-poster-heading strong {
  display: block;
  color: #fff;
  font-size: 14px;
  line-height: 1.08;
  text-shadow: 0 2px 12px rgba(17, 24, 39, 0.4);
  text-align: center;
}

.player-poster-heading span {
  display: none;
}

.player-poster-meta {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  color: rgba(235, 242, 255, 0.88);
  font-size: 9px;
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.player-poster-meta span {
  white-space: nowrap;
  flex: 0 0 auto;
}

.player-card-girl.player-poster-card {
  --poster-accent: #ff69b4;
  --poster-accent-bright: #ffb1dc;
}

.power-token {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  line-height: 1;
  white-space: nowrap;
}

.power-token-icon {
  width: 14px;
  height: 14px;
  flex: 0 0 auto;
  display: block;
  object-fit: contain;
}

.power-token-value {
  font-variant-numeric: tabular-nums;
}

.power-token-inline .power-token-icon {
  width: 13px;
  height: 13px;
}

.power-token-mini {
  gap: 2px;
}

.power-token-mini .power-token-icon {
  width: 10px;
  height: 10px;
}

.power-token-mini .power-token-value {
  font-size: 9px;
}

.champion-token {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  line-height: 1;
  white-space: nowrap;
}

.champion-token-icon {
  width: 12px;
  height: 12px;
  flex: 0 0 auto;
  display: block;
  object-fit: contain;
}

.champion-token-value {
  font-variant-numeric: tabular-nums;
}

.player-profile-head {
  display: flex;
  gap: 14px;
  align-items: center;
}

.player-profile-heading {
  min-width: 0;
}

.player-profile-heading strong {
  display: block;
  font-size: 22px;
  line-height: 1.15;
}

.player-profile-heading p,
.player-profile-intro {
  margin: 6px 0 0;
  color: var(--muted);
}

.player-profile-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.player-profile-stats div {
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(111, 127, 255, 0.12);
}

.player-profile-stats span {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.player-profile-stats strong {
  display: block;
  margin-top: 4px;
  font-size: 20px;
  line-height: 1.1;
}

.player-profile-intro {
  line-height: 1.5;
}

.player-profile-card-compact {
  padding: 12px 14px;
  border-radius: 18px;
}

.player-profile-main {
  min-width: 0;
}

.player-profile-main strong {
  display: block;
  font-size: 16px;
  line-height: 1.15;
}

.player-profile-main span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
}

.player-profile-main small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.mini-avatar,
.hero-avatar {
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 999px;
  background: linear-gradient(135deg, #7d8cff, #67dfc4);
  color: white;
  font-weight: 700;
}

.mini-avatar {
  width: 42px;
  height: 42px;
  flex: 0 0 42px;
}

.profile-avatar {
  width: 84px;
  height: 84px;
  flex: 0 0 84px;
  border-radius: 22px;
  box-shadow: 0 10px 24px rgba(58, 78, 140, 0.16);
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #7d8cff, #67dfc4);
  color: white;
  font-weight: 700;
  font-size: 1.5rem;
}

.profile-avatar-compact {
  width: 58px;
  height: 58px;
  flex: 0 0 58px;
  border-radius: 18px;
}

.hero-avatar {
  overflow: hidden;
}

.image-avatar {
  position: relative;
  overflow: hidden;
}

.image-avatar img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.auction-shell {
  margin-top: 12px;
  display: grid;
  gap: 12px;
}

.auction-board {
  grid-template-columns: 380px minmax(0, 1fr) 280px;
  align-items: stretch;
}

.side-panel {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 0;
  max-height: min(78vh, 920px);
}

.left-panel {
  background: linear-gradient(180deg, rgba(220, 235, 255, 0.88), rgba(214, 250, 245, 0.9));
  border: 3px solid rgba(111, 127, 255, 0.5);
}

.right-panel {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(228, 255, 247, 0.92));
}

.center-stage {
  background:
    radial-gradient(circle at top center, rgba(138, 161, 255, 0.18), transparent 24%),
    rgba(255, 255, 255, 0.82);
}

.left-panel .team-stack {
  flex: 1;
  max-height: none;
  min-height: 0;
  align-content: start;
  overflow: auto;
}

.team-stack.compact-team-stack {
  gap: 6px;
  overflow: visible;
}

.team-stack.compact-team-stack.compact-team-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: 1fr;
  height: 100%;
  align-content: stretch;
}

.team-stack.compact-team-stack.scrollable {
  max-height: min(78vh, 920px);
  overflow: auto;
  padding-right: 4px;
}

.player-library-card .table-list {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-height: none;
  overflow: visible;
}

.player-library-card .table-row {
  display: grid;
  gap: 10px;
  align-items: start;
  padding: 14px;
}

.player-library-card .row-actions {
  justify-content: flex-start;
}

.player-library-card .row-actions button {
  flex: 0 0 auto;
}

.event-management-card .checkbox-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.event-management-card .check-card {
  align-items: flex-start;
  min-height: 88px;
}

.section-title {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
}

.section-title h3,
.section-title h4,
.stage-header h3 {
  margin-top: 0;
  margin-bottom: 0;
}

.hero-player-card {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 20px;
  align-items: center;
  padding: 22px;
  border-radius: 28px;
  background: rgba(237, 240, 255, 0.82);
}

.hero-avatar {
  width: 112px;
  height: 112px;
  font-size: 42px;
}

.hero-meta strong {
  font-size: 34px;
}

.hero-tags,
.topbar-meta,
.signup-actions,
.history-strip {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.tag,
.pill,
.budget-chip,
.status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(111, 127, 255, 0.1);
  color: #536cb8;
  font-weight: 700;
}

.budget-chip {
  background: rgba(255, 198, 91, 0.18);
  color: #ab7218;
}

.auction-readiness {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.auction-core {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.price-box.warning {
  background: rgba(255, 234, 202, 0.62);
}

.countdown-box {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  transition: background 180ms ease, box-shadow 180ms ease;
}

.countdown-box::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.36) 50%, transparent 100%);
  transform: translateX(-140%);
  opacity: 0;
  pointer-events: none;
}

.countdown-value {
  display: inline-block;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.03em;
  transform-origin: center;
}

.countdown-box.countdown-normal {
  box-shadow: 0 10px 24px rgba(255, 181, 77, 0.12);
}

.countdown-box.countdown-urgent {
  background: rgba(255, 213, 148, 0.82);
  box-shadow: 0 14px 32px rgba(255, 159, 67, 0.22);
}

.countdown-box.countdown-urgent::after,
.countdown-box.countdown-critical::after {
  opacity: 1;
  animation: countdownSweep 1.25s linear infinite;
}

.countdown-box.countdown-normal .countdown-value {
  animation: countdownTextGlow 1.8s ease-in-out infinite;
}

.countdown-box.countdown-urgent .countdown-value {
  color: #9a5800;
  animation: countdownTextUrgent 0.72s ease-in-out infinite;
}

.countdown-box.countdown-critical {
  background: rgba(255, 168, 168, 0.9);
  box-shadow: 0 18px 40px rgba(255, 95, 116, 0.32);
}

.countdown-box.countdown-critical .countdown-value {
  color: #a23c4b;
  animation: countdownTextCritical 0.48s ease-in-out infinite;
}

.countdown-box.countdown-paused {
  background: rgba(220, 225, 241, 0.82);
  box-shadow: none;
}

.bid-panel {
  margin-top: 14px;
}

.auction-rule-hint {
  margin: 10px 0 0;
  font-size: 13px;
  line-height: 1.5;
  color: var(--muted);
}

.bid-form {
  grid-template-columns: auto 140px auto 1fr;
  align-items: center;
}

.auction-rule-hint {
  opacity: 0.88;
}

.history-strip {
  margin-top: 18px;
}

.history-strip span {
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(255, 255, 255, 0.66);
  border: 1px solid var(--line);
}

.team-card {
  border: 1px solid rgba(111, 127, 255, 0.18);
  border-radius: 24px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.58);
}

.auction-team-card {
  display: flex;
  flex-direction: column;
  padding: 7px 8px;
  border-radius: 14px;
  height: 100%;
  min-height: 0;
}

.auction-team-card .team-card-head {
  gap: 4px;
  align-items: center;
  flex-wrap: nowrap;
  margin-bottom: 4px;
}

.auction-team-power {
  display: inline-flex;
  align-items: center;
  min-height: 18px;
  padding: 1px 6px;
  border-radius: 999px;
  background: rgba(111, 127, 255, 0.08);
  color: #536cb8;
  font-size: 9px;
  line-height: 1;
  font-weight: 700;
  white-space: nowrap;
}

.compact-budget-chip {
  min-height: 18px;
  padding: 1px 6px;
  font-size: 9px;
  line-height: 1;
  flex: 0 0 auto;
}

.compact-roster-list {
  flex: 1;
  grid-auto-rows: minmax(0, 1fr);
  gap: 3px;
  margin-top: 0;
}

.auction-roster-player {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) auto auto;
  gap: 4px;
  align-items: center;
  min-height: 0;
  padding: 3px 5px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(111, 127, 255, 0.12);
}

.auction-roster-player-captain {
  background: rgba(255, 236, 201, 0.78);
  border-color: rgba(234, 164, 64, 0.28);
}

.auction-roster-player strong {
  min-width: 0;
  font-size: 10px;
  line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.auction-roster-player span {
  display: inline-flex;
  align-items: center;
  font-size: 9px;
  line-height: 1;
  color: var(--muted);
  white-space: nowrap;
}

.auction-player-power,
.auction-player-positions {
  justify-content: center;
  min-width: 22px;
  padding: 1px 4px;
  border-radius: 999px;
  background: rgba(111, 127, 255, 0.08);
}

.auction-player-power {
  font-variant-numeric: tabular-nums;
  color: #536cb8;
  font-weight: 700;
}

.auction-player-power .power-token-value {
  color: inherit;
  font-weight: inherit;
  font-size: inherit;
}

.auction-player-positions {
  letter-spacing: 0.02em;
}

.auction-roster-player-captain strong {
  color: #8a4d08;
}

.auction-roster-player-captain .auction-player-power,
.auction-roster-player-captain .auction-player-positions {
  background: rgba(234, 164, 64, 0.14);
  color: #8a4d08;
}

.auction-roster-player-empty {
  background: rgba(255, 255, 255, 0.36);
  border-style: dashed;
  opacity: 0.72;
}

.auction-roster-player-empty strong,
.auction-roster-player-empty span {
  color: rgba(96, 108, 139, 0.76);
}

.compact-stack {
  max-height: 420px;
}

.inhouse-shell {
  margin-top: 8px;
}

.inhouse-grid {
  grid-template-columns: 250px minmax(0, 1fr) 440px;
  margin-top: 8px;
  align-items: start;
}

.pick-panel,
.teams-panel,
.signup-panel {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
  min-height: 0;
  max-height: min(78vh, 920px);
}

.signup-panel h3,
.pick-panel h3,
.teams-panel h3 {
  margin: 0;
  line-height: 1.15;
}

.signup-panel p,
.pick-panel p,
.teams-panel p {
  margin: 0;
}

.compact-history {
  margin-top: 6px;
}

.inhouse-scroll,
.inhouse-history-scroll {
  min-height: 0;
  overflow: auto;
}

.inhouse-team-scroll {
  min-height: 0;
  overflow: visible;
}

.signup-panel .inhouse-scroll {
  flex: 1;
}

.pick-panel .inhouse-scroll {
  flex: 1;
}

.inhouse-pick-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-content: start;
}

.pick-panel .inhouse-history-scroll {
  max-height: 150px;
}

.teams-panel .inhouse-team-scroll {
  flex: 1;
  max-height: none;
}

.teams-panel .inhouse-team-scroll.scrollable {
  overflow: auto;
}

.empty-state {
  text-align: center;
}

.signup-actions {
  margin-top: 2px;
}

#pick-player-button {
  margin-top: -2px;
}

@media (max-width: 1200px) {
  .admin-layout-grid,
  .workspace-grid,
  .auction-board,
  .inhouse-grid,
  .top-shell,
  .auth-grid,
  .hero-layout,
  .content-split {
    grid-template-columns: 1fr;
  }

  .grid-form.compact,
  .grid-form {
    grid-template-columns: 1fr;
  }

  .toolbar-grid,
  .directory-list,
  .event-overview-list,
  .checkbox-grid,
  .budget-grid,
  .auction-core,
  .auction-readiness,
  .bid-form {
    grid-template-columns: 1fr;
  }

  .community-hero,
  .player-preview-grid {
    grid-template-columns: 1fr;
  }

  .community-hero-main {
    grid-template-columns: 1fr;
  }

  .hero-honor-stage,
  .hero-honor-grid {
    grid-template-columns: 1fr;
  }

  .admin-subnav {
    grid-template-columns: 1fr;
  }

  .admin-inline-toolbar-main,
  .admin-inline-pills {
    align-items: stretch;
  }

  .admin-action-row,
  .admin-compact-stats {
    align-items: stretch;
  }

  .community-hero {
    min-height: 0;
  }

  .hero-honor-stage {
    margin-top: 12px;
  }

  .hero-champion-stage {
    min-height: 360px;
  }

  .hero-honor-card {
    padding: 12px;
  }

  .hero-champion-stage {
    min-height: 380px;
    padding-inline: 0;
  }

  .champion-lineup {
    min-height: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .champion-lineup::before {
    display: none;
  }

  .champion-member-card {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    transform: none;
    animation: none;
    min-height: 136px;
  }

  .player-library-card .table-list,
  .event-management-card .checkbox-grid,
  .auction-overview-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .inhouse-pick-grid {
    grid-template-columns: 1fr;
  }

  .player-library-card,
  .event-management-card,
  .auction-management-card,
  .admin-sidebar,
  .side-panel,
  .pick-panel,
  .teams-panel,
  .signup-panel {
    height: auto;
    max-height: none;
  }

  .admin-sidebar {
    position: static;
  }

  .player-library-card .table-list,
  .directory-list,
  .admin-card-body,
  .left-panel .team-stack,
  .signup-panel .inhouse-scroll,
  .pick-panel .inhouse-scroll,
  .teams-panel .inhouse-team-scroll,
  .pick-panel .inhouse-history-scroll {
    max-height: 420px;
  }

  .page-nav,
  .page-nav-main,
  .nav-auth,
  .nav-login-form,
  .nav-admin-form,
  .activity-row-card,
  .live-scene-card,
  .side-entry-actions,
  .compact-side-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .page-nav-system {
    top: 2px;
  }

  .page-nav-links {
    width: 100%;
    margin-inline: 0;
  }

}

@media (max-width: 720px) {
  .page-shell {
    width: min(var(--shell-width), calc(100vw - 16px));
    padding-top: 16px;
  }

  .page-nav-system {
    top: 0;
    padding: 7px 10px;
    border-radius: 14px;
  }

  .page-nav-link {
    flex: 1 1 calc(50% - 6px);
    justify-content: center;
  }

  .page-shell-home {
    padding-top: 6px;
  }

  .community-hero {
    padding: 16px 14px 14px;
  }

  .hero-title-band {
    top: 12px;
  }

  .hero-champion-stage {
    min-height: 320px;
    padding: 6px 2px 4px;
  }

  .global-theme-toggle {
    top: 10px;
    right: 10px;
  }

  .brand-panel,
  .auth-panel,
  .admin-card,
  .auction-topbar,
  .center-stage,
  .side-panel,
  .inhouse-shell {
    padding: 18px;
    border-radius: 22px;
  }

  .community-hero,
  .community-section,
  .community-side-panel,
  .admin-sidebar,
  .hero-feature-card {
    padding: 14px 16px;
  }

  .hero-floating-meta {
    margin-bottom: 0;
  }

  .hero-login-floating {
    margin-left: 0;
    width: 100%;
  }

  .spotlight-event-card {
    padding: 14px;
    border-radius: 18px;
  }

  .hero-login-embed .nav-auth,
  .hero-login-embed .nav-auth-logged {
    width: 100%;
  }

  .hero-login-embed .nav-auth,
  .hero-login-embed .nav-auth-logged {
    width: 100%;
  }

  .admin-card {
    height: auto;
  }

  .directory-shell {
    height: auto;
  }

  .hero-player-card {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .hero-honor-captain {
    grid-template-columns: 54px minmax(0, 1fr);
  }

  .hero-honor-avatar {
    width: 54px;
    height: 54px;
    font-size: 20px;
  }

  .player-library-card .table-list,
  .event-management-card .checkbox-grid,
  .directory-list,
  .auction-overview-list,
  .player-preview-grid {
    grid-template-columns: 1fr;
  }

  .session-head,
  .community-info-head {
    align-items: start;
    flex-direction: column;
  }
}

@keyframes livePulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(67, 200, 154, 0.16);
    transform: translateY(0);
  }
  50% {
    box-shadow: 0 0 0 8px rgba(67, 200, 154, 0);
    transform: translateY(-1px);
  }
}

@keyframes countdownGlow {
  0%,
  100% {
    box-shadow: 0 10px 24px rgba(255, 181, 77, 0.12);
  }
  50% {
    box-shadow: 0 14px 30px rgba(255, 181, 77, 0.22);
  }
}

@keyframes countdownTextGlow {
  0%,
  100% {
    transform: scale(1);
    text-shadow: 0 0 0 rgba(255, 181, 77, 0);
  }
  50% {
    transform: scale(1.04);
    text-shadow: 0 0 14px rgba(255, 181, 77, 0.55);
  }
}

@keyframes countdownTextUrgent {
  0%,
  100% {
    transform: scale(1) translateY(0);
    text-shadow: 0 0 0 rgba(255, 159, 67, 0);
  }
  30% {
    transform: scale(1.08) translateY(-1px);
    text-shadow: 0 0 16px rgba(255, 159, 67, 0.75);
  }
  60% {
    transform: scale(0.98) translateY(0);
    text-shadow: 0 0 8px rgba(255, 159, 67, 0.4);
  }
}

@keyframes countdownTextCritical {
  0%,
  100% {
    transform: scale(1);
    text-shadow: 0 0 0 rgba(255, 95, 116, 0);
  }
  25% {
    transform: scale(1.12);
    text-shadow: 0 0 18px rgba(255, 95, 116, 0.95);
  }
  55% {
    transform: scale(0.96);
    text-shadow: 0 0 8px rgba(255, 95, 116, 0.55);
  }
}

@keyframes countdownSweep {
  0% {
    transform: translateX(-140%);
  }
  100% {
    transform: translateX(140%);
  }
}

/* ── Hero chips ── */
.player-poster-heroes {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}
.player-hover-heroes {
  margin: 8px 0 4px;
}
.player-hover-heroes-label {
  display: block;
  font-size: 0.72rem;
  color: var(--muted);
  margin-bottom: 4px;
}
.hero-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.hero-icon-list,
.hero-chip-row,
.player-poster-heroes {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.hero-icon {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  object-fit: cover;
  filter: drop-shadow(0 2px 6px rgba(15, 23, 42, 0.16));
}

.hero-icon-fallback {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.08);
  font-size: 12px;
}

.hero-picker {
  display: grid;
  gap: 8px;
}

.hero-picker-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.hero-picker-label,
.hero-picker-meta {
  font-size: 12px;
}

.hero-picker-search {
  width: 100%;
}

.hero-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(32px, 1fr));
  gap: 6px;
  max-height: 220px;
  overflow: auto;
  padding: 6px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.hero-picker-option {
  border: 0;
  padding: 0;
  background: transparent;
  border-radius: 8px;
  cursor: pointer;
  opacity: 0.72;
  transition: transform 120ms ease, opacity 120ms ease, box-shadow 120ms ease;
}

.hero-picker-option:hover {
  opacity: 1;
  transform: translateY(-1px);
}

.hero-picker-option.selected {
  opacity: 1;
  box-shadow: 0 0 0 2px var(--accent);
}

.hero-picker-option img {
  width: 100%;
  display: block;
  border-radius: 8px;
  filter: drop-shadow(0 2px 6px rgba(15, 23, 42, 0.16));
}

/* ── Extended toolbar grid ── */
.toolbar-grid-extended {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 8px;
  align-items: end;
}

/* ── Skeleton screen ── */
.skeleton-shell {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 100vh;
}
.skeleton-nav {
  height: 48px;
  border-radius: 10px;
}
.skeleton-hero {
  height: 260px;
  border-radius: 14px;
}
.skeleton-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.skeleton-card {
  height: 140px;
  border-radius: 10px;
}
.skeleton-shimmer {
  background: linear-gradient(
    90deg,
    var(--panel, rgba(255,255,255,0.08)) 25%,
    var(--line, rgba(114,142,255,0.12)) 50%,
    var(--panel, rgba(255,255,255,0.08)) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
}
[data-theme="dark"] .skeleton-shimmer {
  background: linear-gradient(
    90deg,
    rgba(19,30,52,0.6) 25%,
    rgba(118,150,255,0.1) 50%,
    rgba(19,30,52,0.6) 75%
  );
  background-size: 200% 100%;
}
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── Global loading bar ── */
.global-loading-bar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  z-index: 10000;
  overflow: hidden;
  background: transparent;
}
.global-loading-bar-indicator {
  height: 100%;
  width: 40%;
  background: linear-gradient(90deg, transparent, var(--accent, #6f7fff), transparent);
  animation: loadingSlide 1.2s ease-in-out infinite;
}
@keyframes loadingSlide {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(350%); }
}

/* ── Registration form ── */
.join-button {
  color: #7788ff;
  background: transparent;
  border: 1.5px solid #7788ff;
  box-shadow: none;
}

.join-button:hover {
  background: rgba(119, 136, 255, 0.1);
}

.nav-auth-drawer .ghost-button {
  color: rgba(220, 228, 255, 0.8);
  background: transparent;
  border-color: rgba(160, 180, 255, 0.25);
  box-shadow: none;
}

.nav-auth-drawer .ghost-button:hover {
  background: rgba(160, 180, 255, 0.1);
}

.nav-auth-drawer .join-button {
  color: #a0b4ff;
  border-color: rgba(160, 180, 255, 0.4);
}

.nav-auth-drawer .join-button:hover {
  background: rgba(160, 180, 255, 0.1);
}

:root[data-theme="light"] .nav-auth-drawer .join-button {
  color: #7788ff;
  border-color: #7788ff;
}

:root[data-theme="dark"] .page-nav .nav-auth-entry-row .secondary-button,
:root[data-theme="dark"] .page-nav .nav-auth-entry-row .ghost-button,
:root[data-theme="dark"] .page-nav .nav-auth-logged .secondary-button {
  color: var(--stage-text);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(118, 150, 255, 0.16);
  box-shadow: none;
}

:root[data-theme="dark"] .page-nav .nav-auth-entry-row .secondary-button:hover,
:root[data-theme="dark"] .page-nav .nav-auth-entry-row .ghost-button:hover,
:root[data-theme="dark"] .page-nav .nav-auth-logged .secondary-button:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(118, 150, 255, 0.24);
}

:root[data-theme="dark"] .hero-login-embed .nav-auth-entry-row .secondary-button,
:root[data-theme="dark"] .hero-login-embed .nav-auth-entry-row .ghost-button,
:root[data-theme="dark"] .hero-login-embed .nav-auth-logged .secondary-button {
  color: var(--stage-text);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(118, 150, 255, 0.16);
  box-shadow: none;
}

:root[data-theme="dark"] .hero-login-embed .nav-auth-entry-row .secondary-button:hover,
:root[data-theme="dark"] .hero-login-embed .nav-auth-entry-row .ghost-button:hover,
:root[data-theme="dark"] .hero-login-embed .nav-auth-logged .secondary-button:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(118, 150, 255, 0.24);
}

:root[data-theme="dark"] .auction-shell [data-back-to-event].secondary-button,
:root[data-theme="dark"] .inhouse-shell [data-back-to-event].secondary-button,
:root[data-theme="dark"] .event-detail-shell [data-page="hub"].secondary-button,
:root[data-theme="dark"] .event-detail-shell [data-event-cancel].secondary-button,
:root[data-theme="dark"] .auction-shell .ghost-button {
  color: var(--stage-text);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(118, 150, 255, 0.16);
  box-shadow: none;
}

:root[data-theme="dark"] .auction-shell [data-back-to-event].secondary-button:hover,
:root[data-theme="dark"] .inhouse-shell [data-back-to-event].secondary-button:hover,
:root[data-theme="dark"] .event-detail-shell [data-page="hub"].secondary-button:hover,
:root[data-theme="dark"] .event-detail-shell [data-event-cancel].secondary-button:hover,
:root[data-theme="dark"] .auction-shell .ghost-button:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(118, 150, 255, 0.24);
}

:root[data-theme="dark"] .auction-shell input,
:root[data-theme="dark"] .auction-shell select,
:root[data-theme="dark"] .auction-shell textarea,
:root[data-theme="dark"] .inhouse-shell input,
:root[data-theme="dark"] .inhouse-shell select,
:root[data-theme="dark"] .inhouse-shell textarea,
:root[data-theme="dark"] .event-detail-shell input,
:root[data-theme="dark"] .event-detail-shell select,
:root[data-theme="dark"] .event-detail-shell textarea {
  color: var(--stage-text);
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(118, 150, 255, 0.16);
}

:root[data-theme="dark"] .auction-shell input::placeholder,
:root[data-theme="dark"] .auction-shell textarea::placeholder,
:root[data-theme="dark"] .inhouse-shell input::placeholder,
:root[data-theme="dark"] .inhouse-shell textarea::placeholder,
:root[data-theme="dark"] .event-detail-shell input::placeholder,
:root[data-theme="dark"] .event-detail-shell textarea::placeholder {
  color: rgba(228, 236, 255, 0.52);
}

:root[data-theme="dark"] .auction-shell select,
:root[data-theme="dark"] .inhouse-shell select,
:root[data-theme="dark"] .event-detail-shell select {
  color-scheme: dark;
}

:root[data-theme="dark"] .auction-shell .queue-list,
:root[data-theme="dark"] .auction-shell .history-list,
:root[data-theme="dark"] .auction-shell .team-stack,
:root[data-theme="dark"] .inhouse-shell .queue-list,
:root[data-theme="dark"] .inhouse-shell .history-list,
:root[data-theme="dark"] .inhouse-shell .team-stack {
  scrollbar-color: rgba(118, 150, 255, 0.35) rgba(255, 255, 255, 0.04);
}

:root[data-theme="dark"] .power-token-icon {
  filter: brightness(1.28) contrast(1.16) drop-shadow(0 0 6px rgba(160, 210, 255, 0.18));
}

:root[data-theme="dark"] .join-button {
  color: #a9bbff;
  border-color: rgba(160, 180, 255, 0.42);
}

:root[data-theme="dark"] .join-button:hover {
  background: rgba(160, 180, 255, 0.12);
}

.label-hint {
  font-size: 0.75em;
  color: var(--muted);
  font-weight: 400;
}

.register-form {
  max-width: 360px;
  grid-column: 1 / -1;
  min-width: 0;
}
.register-form h3 {
  margin-bottom: 4px;
}
.register-avatar-preview {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 8px;
  border: 2px solid var(--accent);
}
.register-avatar-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ── Profile editor ── */
/* ── Profile drawer ── */
.nav-profile-drawer {
  width: min(380px, 90vw);
  right: 0;
  left: auto;
}

/* ── My profile card ── */
.my-profile-card {
  padding: 12px;
  border-radius: 12px;
  background: var(--glass-bg, rgba(255, 255, 255, 0.06));
  border: 1px solid var(--border, rgba(255, 255, 255, 0.08));
}

.my-profile-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.my-profile-avatar {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  font-size: 22px;
  font-weight: 700;
}

.my-profile-name-block {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.my-profile-name-block strong {
  font-size: 16px;
}

.my-profile-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 12px;
  text-align: center;
}

.my-profile-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 8px 4px;
  border-radius: 8px;
  background: var(--glass-bg, rgba(255, 255, 255, 0.04));
}

.my-profile-stat .stat-label {
  font-size: 11px;
  color: var(--muted, #888);
}

.my-profile-stat .stat-label-power {
  display: flex;
  justify-content: center;
  align-items: center;
}

.my-profile-stat .stat-label-power .power-token-icon {
  width: 13px;
  height: 13px;
}

.my-profile-stat .stat-value {
  font-size: 16px;
  font-weight: 700;
}

.my-profile-detail-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  font-size: 13px;
  border-top: 1px solid var(--border, rgba(255, 255, 255, 0.06));
}

.my-profile-detail-row .detail-label {
  flex-shrink: 0;
  width: 64px;
  color: var(--muted, #888);
  font-size: 12px;
}

.my-profile-detail-row .detail-value {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
}

.profile-pos-icon {
  width: 20px;
  height: 20px;
  object-fit: contain;
}

.my-profile-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border, rgba(255, 255, 255, 0.06));
}

.my-profile-editing {
  padding: 12px;
}

.my-profile-editing .card-head {
  margin-bottom: 8px;
}

.my-profile-editing .stack {
  gap: 6px;
}

.my-profile-editing .card-head h4 {
  margin: 0;
  font-size: 15px;
}

.my-profile-editing label {
  gap: 4px;
  font-size: 13px;
}

.my-profile-editing input,
.my-profile-editing textarea,
.my-profile-editing select {
  padding: 8px 10px;
  border-radius: 12px;
}

.my-profile-editing textarea {
  min-height: 68px;
}

.my-profile-editing .position-picker {
  gap: 4px;
}

.my-profile-editing .position-picker-label {
  font-size: 12px;
}

.my-profile-editing .position-picker-options {
  gap: 5px;
}

.my-profile-editing .position-pick-btn img {
  width: 40% !important;
  height: 40% !important;
}

.my-profile-editing .position-pick-btn {
  width: 34px;
  height: auto;
  flex-basis: 34px;
  aspect-ratio: 1 / 1;
  padding: 3px;
  border-radius: 6px;
}

.my-profile-editing .hero-picker {
  gap: 6px;
}

.my-profile-editing .hero-picker-search input {
  padding: 8px 10px;
}

.my-profile-editing button[type="submit"] {
  min-height: 40px;
}

/* ── Event detail page ── */
.event-detail-shell {
  display: grid;
  gap: 14px;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 8px 0 20px;
}

.event-detail-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.9fr) minmax(300px, 0.85fr);
  gap: 14px;
  align-items: stretch;
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.event-detail-topbar {
  display: grid;
  gap: 8px;
}

.event-detail-topbar-main {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.event-detail-breadcrumb {
  font-size: 12px;
  color: rgba(222, 232, 255, 0.58);
  letter-spacing: 0.04em;
}

.event-detail-hero-main {
  display: grid;
  grid-template-rows: auto auto 1fr;
  gap: 16px;
  min-height: 100%;
  padding: 18px 20px 16px;
  border-radius: 16px;
  background:
    radial-gradient(circle at top right, rgba(105, 142, 255, 0.24), transparent 30%),
    radial-gradient(circle at bottom left, rgba(67, 200, 154, 0.12), transparent 24%),
    linear-gradient(135deg, rgba(14, 22, 40, 0.9), rgba(24, 39, 68, 0.84));
  border: 1px solid rgba(118, 150, 255, 0.16);
  box-shadow: 0 18px 38px rgba(3, 8, 19, 0.22);
}

.event-detail-hero-main .event-summary-grid {
  align-self: end;
}

.event-detail-hero-copy {
  display: grid;
  gap: 8px;
  align-content: start;
}

.event-detail-highlight-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 2px;
}

.event-detail-highlight-item {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.025));
  border: 1px solid rgba(118, 150, 255, 0.1);
}

.event-detail-highlight-item span {
  font-size: 12px;
  color: rgba(206, 218, 245, 0.62);
}

.event-detail-highlight-item strong {
  font-size: 14px;
  color: #f1f6ff;
}

.event-detail-hero-copy h2 {
  margin: 0;
  font-size: 31px;
  line-height: 1.1;
  color: #f4f7ff;
  text-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}

.event-detail-lead {
  margin: 0;
  font-size: 14px;
  line-height: 1.65;
  color: rgba(222, 232, 255, 0.74);
  max-width: 62ch;
}

.event-detail-badges {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.event-progress-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
}

.event-progress-row.is-active .event-progress-dot {
  background: rgba(105, 142, 255, 0.95);
}

.event-progress-row.is-complete .event-progress-dot {
  background: rgba(85, 208, 138, 0.95);
}

.event-detail-rail-card {
  display: grid;
  gap: 8px;
  min-height: 100%;
  padding: 12px;
  border-radius: 16px;
  align-content: start;
  background:
    radial-gradient(circle at top right, rgba(255, 184, 79, 0.18), transparent 30%),
    linear-gradient(180deg, rgba(15, 24, 43, 0.92), rgba(24, 39, 68, 0.88));
  border: 1px solid rgba(255, 184, 79, 0.18);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05), 0 14px 30px rgba(3, 8, 19, 0.22);
}

.event-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.event-summary-card,
.event-summary-notes > div {
  display: grid;
  gap: 4px;
  padding: 10px 11px;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.02));
  border: 1px solid rgba(118, 150, 255, 0.1);
}

.compact-summary-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.event-summary-card span,
.event-summary-notes span {
  font-size: 11px;
  color: rgba(206, 218, 245, 0.6);
}

.event-summary-card strong,
.event-summary-notes strong {
  font-size: 15px;
  color: #f1f6ff;
}

.event-summary-notes {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.event-progress-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.event-progress-row {
  display: flex;
  align-items: center;
  gap: 7px;
  min-height: 0;
  padding: 6px 8px;
  border-radius: 9px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.012));
  border: 1px solid rgba(118, 150, 255, 0.07);
}

.event-progress-row strong {
  font-size: 11px;
  color: rgba(237, 243, 255, 0.88);
  font-weight: 600;
}

.rail-notes {
  gap: 6px;
}

.event-progress-dot {
  width: 8px;
  height: 8px;
  opacity: 0.8;
}

.event-detail-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(300px, 0.85fr);
  gap: 12px;
  align-items: stretch;
}

.event-detail-primary,
.event-detail-secondary {
  display: grid;
  gap: 12px;
  height: 100%;
}

.event-detail-secondary {
  position: sticky;
  top: 16px;
}

.event-detail-rail {
  gap: 10px;
}

.event-detail-rail-stack {
  display: grid;
  gap: 10px;
}

.event-detail-allocation-inline {
  margin-top: 0;
}

.event-allocation-card-inline {
  display: grid;
  gap: 6px;
  padding: 9px 10px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03));
  border: 1px solid rgba(118, 150, 255, 0.14);
}

.event-allocation-head-inline,
.event-allocation-status-inline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.event-allocation-head-inline strong {
  font-size: 14px;
  color: #eef4ff;
}

.event-allocation-head-inline span,
.event-allocation-status-inline span:first-child {
  font-size: 12px;
  color: rgba(206, 218, 245, 0.66);
}

.compact-status-card button {
  min-height: 34px;
  padding: 0 12px;
  font-size: 13px;
}

.event-detail-meta {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--muted, #888);
}

.event-detail-actions {
  display: flex;
  gap: 8px;
}

.event-detail-actions button {
  width: 100%;
}

.event-detail-section {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 14px;
  background:
    radial-gradient(circle at top right, rgba(118, 150, 255, 0.08), transparent 24%),
    linear-gradient(180deg, rgba(14, 22, 40, 0.9), rgba(21, 34, 58, 0.84));
  border: 1px solid rgba(118, 150, 255, 0.12);
  box-shadow: 0 12px 24px rgba(3, 8, 19, 0.14);
}

.event-detail-section h3 {
  margin: 0;
  font-size: 15px;
  line-height: 1.25;
  color: #eef4ff;
}

.event-detail-section .section-title {
  margin-bottom: 2px;
}

.event-signup-panel .event-signup-grid {
  max-height: 420px;
  overflow: auto;
  padding-right: 2px;
}

.event-signup-panel-wide {
  gap: 12px;
}

.event-signup-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  max-height: 280px;
  overflow: auto;
  padding-right: 2px;
}

.event-signup-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 7px;
}

.event-signup-card {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 9px;
  border-radius: 9px;
  background: var(--glass-bg, rgba(255, 255, 255, 0.06));
  border: 1px solid var(--border, rgba(255, 255, 255, 0.06));
  font-size: 12px;
}

.event-signup-card.is-captain {
  border-color: rgba(255, 184, 79, 0.4);
  background: rgba(255, 184, 79, 0.06);
}

.event-signup-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}

.event-signup-info strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.event-signup-info small {
  color: rgba(198, 210, 236, 0.7);
}

.event-teams-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
}

.event-team-panel-compact {
  align-content: start;
  grid-template-rows: auto 1fr;
  height: 100%;
  min-height: 100%;
  overflow: hidden;
}

.event-teams-grid-compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  --compact-team-gap: 8px;
  --compact-team-visible-rows: 4;
  gap: var(--compact-team-gap);
  grid-auto-rows: calc((100% - (var(--compact-team-visible-rows) - 1) * var(--compact-team-gap)) / var(--compact-team-visible-rows));
  max-height: 100%;
  overflow: auto;
  padding-right: 2px;
  align-content: start;
}

.event-team-card {
  padding: 12px;
  border-radius: 12px;
  background:
    radial-gradient(circle at top right, rgba(118, 150, 255, 0.12), transparent 24%),
    linear-gradient(180deg, rgba(19, 30, 52, 0.88), rgba(24, 39, 68, 0.8));
  border: 1px solid rgba(118, 150, 255, 0.16);
  box-shadow: 0 12px 22px rgba(3, 8, 19, 0.16);
}

.event-team-card-compact {
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-rows: minmax(0, auto) minmax(0, auto) minmax(0, 1fr);
  align-content: stretch;
  overflow: hidden;
}

.event-team-card-placeholder {
  opacity: 0.88;
  border-style: dashed;
}

.event-signup-card-placeholder {
  opacity: 0.7;
  border-style: dashed;
}

.event-team-card-placeholder strong,
.event-signup-card-placeholder strong {
  color: rgba(238, 244, 255, 0.8);
}

:root[data-theme="light"] .event-team-card-placeholder {
  border-color: rgba(86, 117, 227, 0.2);
  background:
    radial-gradient(circle at top right, rgba(86, 117, 227, 0.08), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(239, 245, 255, 0.96));
}

:root[data-theme="light"] .event-signup-card-placeholder {
  border-color: rgba(86, 117, 227, 0.18);
  background: rgba(86, 117, 227, 0.04);
}

.polished-team-card {
  display: grid;
  gap: 8px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
}

.event-team-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border, rgba(255, 255, 255, 0.06));
}

.event-team-head strong {
  line-height: 1.25;
}

.event-team-title,
.event-team-strength {
  display: grid;
  gap: 4px;
}

.event-team-title small,
.event-team-strength small,
.event-team-submeta span {
  color: var(--muted, #8d99af);
}

.event-team-submeta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 0;
}

.event-team-submeta span {
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(118, 150, 255, 0.1);
  border: 1px solid rgba(118, 150, 255, 0.16);
  font-size: 11px;
}

.event-team-members {
  display: grid;
  gap: 6px;
}

.event-team-members-compact {
  grid-template-columns: 1fr;
  grid-auto-rows: minmax(0, 1fr);
  gap: 3px;
  align-content: stretch;
  min-height: 0;
  overflow: hidden;
}

.event-signup-slot-compact {
  min-height: 0;
  padding: 3px 5px;
  align-items: center;
  overflow: hidden;
}

.event-signup-slot-compact .event-signup-info {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  width: 100%;
  min-width: 0;
}

.event-signup-slot-compact .event-signup-info strong {
  font-size: clamp(10px, 0.62vw, 12px);
  line-height: 1.1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
  min-width: 0;
}

.event-signup-slot-compact .event-signup-info small {
  font-size: clamp(8px, 0.5vw, 9px);
  line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 0 0 auto;
}

.event-team-card-compact .event-team-title strong {
  font-size: clamp(11px, 0.72vw, 13px);
}

.event-team-card-compact .event-team-title small,
.event-team-card-compact .event-team-strength small,
.event-team-card-compact .event-team-submeta span {
  font-size: clamp(8px, 0.5vw, 9px);
}

.event-team-card-compact .event-team-head {
  margin-bottom: 4px;
  padding-bottom: 5px;
}

.event-team-card-compact .event-team-submeta {
  gap: 4px;
}

.event-team-card-compact .event-team-submeta span {
  padding: 2px 6px;
}

.event-team-budget {
  margin-top: 8px;
  padding-top: 6px;
  border-top: 1px solid var(--border, rgba(255, 255, 255, 0.06));
  text-align: right;
  opacity: 0.7;
}

.tournament-section {
  gap: 12px;
  padding: 14px;
  background:
    radial-gradient(circle at top right, rgba(118, 150, 255, 0.1), transparent 24%),
    linear-gradient(180deg, rgba(11, 18, 35, 0.94), rgba(18, 30, 54, 0.9));
  border-color: rgba(118, 150, 255, 0.14);
}

.tournament-layout {
  display: block;
}

.tournament-board {
  display: grid;
  gap: 12px;
  min-width: 0;
  position: relative;
}

.tournament-section > .section-title {
  align-items: end;
}

.tournament-section > .section-title span,
.tournament-lane .section-title span {
  font-size: 12px;
}

.tournament-lane {
  display: grid;
  gap: 12px;
  padding: 10px;
  border-radius: 14px;
  background:
    radial-gradient(circle at top right, rgba(255, 184, 79, 0.08), transparent 26%),
    linear-gradient(180deg, rgba(18, 30, 52, 0.88), rgba(24, 39, 68, 0.84));
  border: 1px solid rgba(118, 150, 255, 0.14);
}

.tournament-lane .section-title {
  margin-bottom: -2px;
}

.tournament-rounds {
  display: flex;
  gap: 28px;
  overflow-x: auto;
  padding: 2px 6px 8px 2px;
}

.tournament-round-column {
  min-width: 205px;
  display: grid;
  gap: 8px;
  position: relative;
}

.tournament-round-column > strong {
  font-size: 12px;
  color: rgba(205, 218, 245, 0.72);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding-left: 4px;
}

.tournament-round-stack {
  display: grid;
  gap: 8px;
  position: relative;
  padding-top: var(--round-offset, 0);
  gap: var(--round-gap, 12px);
}

.tournament-fixture-shell {
  position: relative;
}

.tournament-lane.is-tree-bracket .tournament-fixture-shell::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -28px;
  width: 28px;
  border-top: 2px solid rgba(255, 255, 255, 0.15);
  transform: translateY(-50%);
}

.tournament-lane.is-tree-bracket .tournament-round-column.is-last-round .tournament-fixture-shell::after {
  display: none;
}

.tournament-lane.is-tree-bracket .tournament-round-column:not(.is-first-round) .tournament-fixture-shell::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -28px;
  width: 28px;
  border-top: 2px solid rgba(255, 255, 255, 0.15);
  transform: translateY(-50%);
}

.tournament-lane.is-tree-bracket .tournament-round-column:not(.is-last-round) .tournament-fixture-shell.is-odd-fixture > .tournament-fixture-card::after,
.tournament-lane.is-tree-bracket .tournament-round-column:not(.is-last-round) .tournament-fixture-shell.is-even-fixture > .tournament-fixture-card::after {
  content: "";
  position: absolute;
  right: -28px;
  width: 28px;
  border-top: 2px solid rgba(255, 255, 255, 0.15);
  top: 50%;
  transform: translateY(-50%);
}

.tournament-lane.is-tree-bracket .tournament-round-column:not(.is-last-round) .tournament-fixture-shell.is-odd-fixture > .tournament-fixture-card::before,
.tournament-lane.is-tree-bracket .tournament-round-column:not(.is-last-round) .tournament-fixture-shell.is-even-fixture > .tournament-fixture-card::before {
  content: "";
  position: absolute;
  right: -28px;
  width: 28px;
  top: 50%;
  pointer-events: none;
}

.tournament-lane.is-tree-bracket .tournament-round-column:not(.is-last-round) .tournament-fixture-shell.is-odd-fixture > .tournament-fixture-card::before {
  height: calc(50% + (var(--round-gap, 12px) / 2));
  border-right: 2px solid rgba(255, 255, 255, 0.15);
  border-top: 2px solid rgba(255, 255, 255, 0.15);
  transform: translateY(0);
}

.tournament-lane.is-tree-bracket .tournament-round-column:not(.is-last-round) .tournament-fixture-shell.is-even-fixture > .tournament-fixture-card::before {
  height: calc(50% + (var(--round-gap, 12px) / 2));
  border-right: 2px solid rgba(255, 255, 255, 0.15);
  border-bottom: 2px solid rgba(255, 255, 255, 0.15);
  transform: translateY(-100%);
}

.tournament-fixture-card {
  display: grid;
  gap: 8px;
  padding: 11px;
  border-radius: 12px;
  border: 1px solid var(--border, rgba(255, 255, 255, 0.08));
  background:
    radial-gradient(circle at top right, rgba(118, 150, 255, 0.14), transparent 24%),
    linear-gradient(180deg, rgba(20, 33, 58, 0.94), rgba(27, 43, 74, 0.9));
  text-align: left;
  position: relative;
  overflow: hidden;
  box-shadow: inset 3px 0 0 rgba(118, 150, 255, 0.18), 0 12px 24px rgba(3, 8, 19, 0.18);
  transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
  min-height: 160px;
}

.tournament-detail-empty {
  display: grid;
  place-items: center;
  min-height: 88px;
  border-radius: 10px;
  border: 1px dashed rgba(255, 255, 255, 0.1);
  color: var(--muted, #8fa0bb);
  background: rgba(255, 255, 255, 0.025);
}

.tournament-fixture-card > * {
  position: relative;
  z-index: 1;
}

.tournament-fixture-card:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: inset 3px 0 0 rgba(255, 255, 255, 0.08), 0 14px 28px rgba(0, 0, 0, 0.16);
}

.tournament-fixture-card.selected-fixture {
  border-color: rgba(115, 145, 255, 0.55);
  box-shadow: inset 3px 0 0 rgba(115, 145, 255, 1), 0 0 0 1px rgba(115, 145, 255, 0.3), 0 18px 38px rgba(74, 106, 230, 0.22);
}

.tournament-fixture-card.is-completed {
  background: rgba(68, 160, 110, 0.08);
}

.tournament-fixture-card.is-completed {
  box-shadow: inset 3px 0 0 rgba(85, 208, 138, 0.95);
}

.tournament-fixture-card.is-placeholder {
  opacity: 0.78;
  border-style: dashed;
  background: rgba(255, 255, 255, 0.025);
  box-shadow: inset 3px 0 0 rgba(255, 255, 255, 0.12);
}

.tournament-fixture-card.is-finals {
  border-color: rgba(255, 184, 79, 0.5);
  background:
    radial-gradient(circle at top right, rgba(255, 184, 79, 0.24), transparent 35%),
    radial-gradient(circle at bottom left, rgba(255, 120, 64, 0.1), transparent 22%),
    linear-gradient(180deg, rgba(42, 31, 14, 0.92), rgba(72, 46, 12, 0.86));
}

.tournament-fixture-head {
  padding-bottom: 4px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.tournament-fixture-head strong {
  font-size: 12px;
}

.tournament-fixture-card.is-finals .tournament-fixture-head strong {
  color: #ffd27e;
}

.tournament-fixture-head,
.tournament-fixture-team,
.tournament-detail-meta,
.tournament-game-card,
.tournament-scoreline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.tournament-fixture-head span,
.tournament-fixture-card small,
.tournament-detail-meta span,
.tournament-game-card span,
.tournament-game-card small {
  color: rgba(205, 218, 245, 0.68);
}

.tournament-fixture-team {
  font-size: 13px;
  border-radius: 10px;
  padding: 7px 8px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.tournament-fixture-team.is-winner span,
.tournament-fixture-team.is-winner strong {
  color: #6ee7a8;
}

.tournament-fixture-team.is-winner {
  background: rgba(85, 208, 138, 0.1);
}

.tournament-detail-panel {
  display: grid;
  gap: 10px;
  position: absolute;
  top: 42px;
  right: 12px;
  z-index: 6;
  width: min(300px, 32%);
  min-width: 248px;
  padding: 12px;
  border-radius: 12px;
  background:
    radial-gradient(circle at top right, rgba(255, 184, 79, 0.16), transparent 36%),
    radial-gradient(circle at bottom left, rgba(118, 150, 255, 0.14), transparent 24%),
    linear-gradient(180deg, rgba(9, 15, 30, 0.96), rgba(16, 28, 52, 0.92));
  border: 1px solid rgba(118, 150, 255, 0.18);
  box-shadow: 0 20px 42px rgba(3, 8, 19, 0.28);
  backdrop-filter: blur(16px);
}

.tournament-detail-panel .section-title {
  margin-bottom: 2px;
}

:root[data-theme="light"] .tournament-section,
:root[data-theme="light"] .tournament-lane,
:root[data-theme="light"] .event-detail-hero,
:root[data-theme="light"] .event-detail-rail-card,
:root[data-theme="light"] .event-detail-section {
  background:
    radial-gradient(circle at top right, rgba(114, 142, 255, 0.18), transparent 26%),
    radial-gradient(circle at top left, rgba(255, 184, 79, 0.12), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(236, 243, 255, 1));
  border-color: rgba(86, 117, 227, 0.24);
}

:root[data-theme="light"] .tournament-round-column > strong,
:root[data-theme="light"] .tournament-fixture-head span,
:root[data-theme="light"] .tournament-fixture-card small,
:root[data-theme="light"] .tournament-detail-meta span,
:root[data-theme="light"] .tournament-game-card span,
:root[data-theme="light"] .tournament-game-card small,
:root[data-theme="light"] .tournament-detail-empty {
  color: #55627f;
}

:root[data-theme="light"] .tournament-lane.is-tree-bracket .tournament-fixture-shell::after,
:root[data-theme="light"] .tournament-lane.is-tree-bracket .tournament-round-column:not(.is-first-round) .tournament-fixture-shell::before,
:root[data-theme="light"] .tournament-lane.is-tree-bracket .tournament-round-column:not(.is-last-round) .tournament-fixture-shell.is-odd-fixture > .tournament-fixture-card::after,
:root[data-theme="light"] .tournament-lane.is-tree-bracket .tournament-round-column:not(.is-last-round) .tournament-fixture-shell.is-even-fixture > .tournament-fixture-card::after,
:root[data-theme="light"] .tournament-lane.is-tree-bracket .tournament-round-column:not(.is-last-round) .tournament-fixture-shell.is-odd-fixture > .tournament-fixture-card::before,
:root[data-theme="light"] .tournament-lane.is-tree-bracket .tournament-round-column:not(.is-last-round) .tournament-fixture-shell.is-even-fixture > .tournament-fixture-card::before {
  border-color: rgba(86, 117, 227, 0.42);
}

:root[data-theme="light"] .tournament-fixture-card {
  background:
    radial-gradient(circle at top right, rgba(86, 117, 227, 0.12), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(235, 243, 255, 0.98));
  border-color: rgba(86, 117, 227, 0.22);
  box-shadow: inset 3px 0 0 rgba(86, 117, 227, 0.22), 0 10px 22px rgba(103, 129, 210, 0.16);
}

:root[data-theme="light"] .tournament-detail-panel {
  background:
    radial-gradient(circle at top right, rgba(86, 117, 227, 0.16), transparent 38%),
    radial-gradient(circle at bottom left, rgba(255, 184, 79, 0.16), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(238, 244, 255, 1));
  border-color: rgba(86, 117, 227, 0.24);
  box-shadow: 0 18px 38px rgba(103, 129, 210, 0.2);
}

:root[data-theme="light"] .event-detail-hero-main {
  background:
    radial-gradient(circle at top right, rgba(114, 142, 255, 0.14), transparent 30%),
    radial-gradient(circle at bottom left, rgba(67, 200, 154, 0.08), transparent 22%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(240, 246, 255, 0.94));
  border-color: rgba(114, 142, 255, 0.16);
  box-shadow: 0 18px 34px rgba(103, 129, 210, 0.14);
}

:root[data-theme="light"] .event-detail-hero-copy h2,
:root[data-theme="light"] .event-summary-card strong,
:root[data-theme="light"] .event-summary-notes strong,
:root[data-theme="light"] .event-progress-row strong,
:root[data-theme="light"] .event-detail-section h3 {
  color: #223252;
  text-shadow: none;
}

:root[data-theme="light"] .event-detail-lead,
:root[data-theme="light"] .event-detail-breadcrumb {
  color: #66738f;
}

:root[data-theme="light"] .event-detail-rail-card .section-title span,
:root[data-theme="light"] .event-detail-badges .status-badge,
:root[data-theme="light"] .event-summary-card span,
:root[data-theme="light"] .event-summary-notes span,
:root[data-theme="light"] .event-allocation-head-inline span,
:root[data-theme="light"] .event-allocation-status-inline span:first-child,
:root[data-theme="light"] .event-detail-highlight-item span {
  color: #52627f;
}

:root[data-theme="light"] .event-detail-lead,
:root[data-theme="light"] .event-detail-breadcrumb,
:root[data-theme="light"] .event-progress-row strong {
  color: #40506b;
}

:root[data-theme="light"] .event-detail-rail-card .section-title h3,
:root[data-theme="light"] .event-allocation-head-inline strong,
:root[data-theme="light"] .event-allocation-status-inline .status-badge,
:root[data-theme="light"] .event-detail-highlight-item strong {
  color: #1d2c46;
}

:root[data-theme="light"] .event-progress-row {
  background: linear-gradient(180deg, rgba(86, 117, 227, 0.08), rgba(86, 117, 227, 0.04));
  border-color: rgba(86, 117, 227, 0.14);
}

:root[data-theme="light"] .event-progress-dot {
  background: rgba(86, 117, 227, 0.42);
}

:root[data-theme="light"] .event-summary-card,
:root[data-theme="light"] .event-summary-notes > div,
:root[data-theme="light"] .event-allocation-card-inline {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(236, 242, 255, 0.98));
  border-color: rgba(86, 117, 227, 0.18);
}

:root[data-theme="light"] .tournament-fixture-card:hover:not(:disabled) {
  box-shadow: inset 3px 0 0 rgba(86, 117, 227, 0.22), 0 14px 26px rgba(103, 129, 210, 0.2);
}

:root[data-theme="light"] .tournament-fixture-team {
  background: rgba(86, 117, 227, 0.09);
  border-color: rgba(86, 117, 227, 0.12);
}

:root[data-theme="light"] .tournament-fixture-team.is-winner {
  background: rgba(67, 200, 154, 0.18);
}

:root[data-theme="light"] .tournament-detail-empty {
  background: rgba(86, 117, 227, 0.06);
  border-color: rgba(86, 117, 227, 0.2);
}

:root[data-theme="light"] .event-detail-hero-main,
:root[data-theme="light"] .event-detail-rail-card {
  border-color: rgba(86, 117, 227, 0.2);
  box-shadow: 0 16px 32px rgba(103, 129, 210, 0.16);
}

:root[data-theme="light"] .event-allocation-card-inline {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(233, 241, 255, 0.96));
  border-color: rgba(86, 117, 227, 0.2);
}

:root[data-theme="light"] .event-detail-hero-copy h2,
:root[data-theme="light"] .event-summary-card strong,
:root[data-theme="light"] .event-summary-notes strong,
:root[data-theme="light"] .event-progress-row strong,
:root[data-theme="light"] .event-detail-section h3 {
  color: #1f2f4f;
}

:root[data-theme="light"] .event-detail-lead,
:root[data-theme="light"] .event-detail-breadcrumb,
:root[data-theme="light"] .event-summary-card span,
:root[data-theme="light"] .event-summary-notes span,
:root[data-theme="light"] .event-signup-info small,
:root[data-theme="light"] .event-team-title small,
:root[data-theme="light"] .event-team-strength small,
:root[data-theme="light"] .event-team-submeta span {
  color: #5b6b88;
}

:root[data-theme="light"] .event-signup-info strong,
:root[data-theme="light"] .event-team-head strong,
:root[data-theme="light"] .event-team-title strong,
:root[data-theme="light"] .tournament-fixture-team span,
:root[data-theme="light"] .tournament-fixture-team strong {
  color: #203150;
}

:root[data-theme="light"] .event-detail-shell .secondary-button,
:root[data-theme="light"] .event-detail-shell .ghost-button {
  color: #203150;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(231, 240, 255, 0.96));
  border-color: rgba(86, 117, 227, 0.22);
  box-shadow: 0 8px 18px rgba(103, 129, 210, 0.14);
}

:root[data-theme="light"] .event-detail-shell .secondary-button:hover,
:root[data-theme="light"] .event-detail-shell .ghost-button:hover {
  background: linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(224, 235, 255, 1));
  border-color: rgba(86, 117, 227, 0.32);
}

:root[data-theme="light"] .event-detail-shell .action-button {
  color: #fff;
  background: linear-gradient(135deg, #5b73ff, #2ea7ff);
  border-color: rgba(65, 111, 255, 0.38);
  box-shadow: 0 10px 22px rgba(65, 111, 255, 0.24);
}

:root[data-theme="light"] .event-detail-shell .success-button {
  color: #fff;
  background: linear-gradient(135deg, #24b874, #4ad8b1);
  border-color: rgba(36, 184, 116, 0.34);
  box-shadow: 0 10px 22px rgba(36, 184, 116, 0.18);
}

:root[data-theme="light"] .event-detail-shell .warning-button {
  color: #533000;
  background: linear-gradient(135deg, #ffc553, #ff9f39);
  border-color: rgba(255, 165, 50, 0.34);
  box-shadow: 0 10px 22px rgba(255, 165, 50, 0.18);
}

:root[data-theme="light"] .event-detail-shell .danger-button {
  color: #fff;
  background: linear-gradient(135deg, #ff6a7f, #ff4f66);
  border-color: rgba(255, 91, 116, 0.34);
  box-shadow: 0 10px 22px rgba(255, 91, 116, 0.18);
}

:root[data-theme="light"] .event-detail-shell .status-badge.phase-info {
  color: #2646a3;
  background: rgba(86, 117, 227, 0.14);
  border-color: rgba(86, 117, 227, 0.22);
}

:root[data-theme="light"] .event-detail-shell .status-badge.phase-live {
  color: #0f7b56;
  background: rgba(36, 184, 116, 0.14);
  border-color: rgba(36, 184, 116, 0.22);
}

:root[data-theme="light"] .event-detail-shell .status-badge.phase-warning {
  color: #8c5700;
  background: rgba(255, 165, 50, 0.16);
  border-color: rgba(255, 165, 50, 0.24);
}

.tournament-scoreline {
  justify-content: center;
  font-size: 22px;
}

.tournament-game-list,
.tournament-standings,
.tournament-admin-shell {
  display: grid;
  gap: 10px;
}

.tournament-game-card,
.tournament-standing-card {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border, rgba(255, 255, 255, 0.08));
  background: var(--glass-bg, rgba(255, 255, 255, 0.04));
}

.tournament-standing-card.is-champion {
  border-color: rgba(255, 184, 79, 0.5);
  background: rgba(255, 184, 79, 0.08);
}

.tournament-game-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tournament-game-links a {
  color: inherit;
  text-decoration: underline;
}

@media (max-width: 980px) {
  .event-detail-hero,
  .tournament-layout {
    grid-template-columns: 1fr;
  }

  .event-detail-main-grid {
    grid-template-columns: 1fr;
  }

  .event-detail-secondary {
    position: static;
    height: auto;
  }

  .event-teams-grid-compact {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
    max-height: none;
    overflow: visible;
  }

  .event-team-card-compact {
    height: auto;
    min-height: 0;
  }

  .event-team-panel-compact {
    height: auto;
    min-height: 0;
    grid-template-rows: auto;
  }

  .event-signup-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .event-detail-hero {
    padding: 10px;
  }

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

  .tournament-detail-panel {
    position: static;
    width: 100%;
    min-width: 0;
  }
}

@media (max-width: 640px) {
  .event-detail-hero-main {
    padding: 16px;
  }

  .event-detail-hero-copy h2 {
    font-size: 24px;
  }

  .event-summary-grid {
    grid-template-columns: 1fr;
  }

  .compact-summary-grid {
    grid-template-columns: 1fr;
  }

  .event-signup-strip {
    grid-template-columns: 1fr;
    max-height: 320px;
  }
}

/* ── Inhouse mode selector row ── */
.inhouse-mode-row {
  display: flex;
  align-items: end;
  gap: 10px;
  flex-wrap: wrap;
}
.inhouse-mode-row label {
  flex: 0 0 auto;
}

/* ── Toast notifications ── */
.toast-container {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
  max-width: 380px;
}
.toast {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 0.85rem;
  line-height: 1.4;
  pointer-events: auto;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
  opacity: 0;
  transform: translateX(100%);
  backdrop-filter: blur(12px);
}
.toast-enter {
  animation: toastSlideIn 0.32s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.toast-exit {
  animation: toastFadeOut 0.28s ease forwards;
}
.toast-success {
  background: rgba(34, 170, 120, 0.92);
  color: #fff;
  border: 1px solid rgba(34, 170, 120, 0.4);
}
.toast-error {
  background: rgba(220, 60, 70, 0.92);
  color: #fff;
  border: 1px solid rgba(220, 60, 70, 0.4);
}
.toast-info {
  background: var(--panel-strong, rgba(255, 255, 255, 0.92));
  color: var(--text);
  border: 1px solid var(--line);
}
[data-theme="dark"] .toast-info {
  background: rgba(19, 30, 52, 0.94);
  color: #eef4ff;
  border-color: rgba(118, 150, 255, 0.22);
}
.toast-message {
  flex: 1;
  word-break: break-word;
}
.toast-close {
  flex-shrink: 0;
  background: none;
  border: none;
  color: inherit;
  opacity: 0.7;
  font-size: 1.1rem;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
}
.toast-close:hover {
  opacity: 1;
}
@keyframes toastSlideIn {
  from { opacity: 0; transform: translateX(100%); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes toastFadeOut {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(60%); }
}

/* ── Prototype page layers ── */
.page-shell-home {
  position: relative;
  overflow: visible;
  isolation: isolate;
}

.page-shell-home::before {
  content: "";
  position: absolute;
  inset: -120px -80px auto;
  height: 420px;
  background:
    radial-gradient(circle at 18% 18%, rgba(123, 140, 255, 0.16), transparent 24%),
    radial-gradient(circle at 82% 12%, rgba(67, 200, 154, 0.1), transparent 20%),
    radial-gradient(circle at 42% 48%, rgba(255, 184, 79, 0.08), transparent 28%);
  pointer-events: none;
  z-index: 0;
}

.page-shell-home::after {
  content: "";
  position: absolute;
  inset: auto -8% -160px;
  height: 320px;
  background: radial-gradient(circle, rgba(118, 150, 255, 0.1), transparent 62%);
  pointer-events: none;
  z-index: 0;
}

.page-shell-home > * {
  position: relative;
  z-index: 1;
}

.home-main-stage {
  display: grid;
  gap: 16px;
}

.community-home-shell,
.events-page-shell,
.events-list-shell,
.event-detail-shell {
  width: 100%;
}

.community-home-shell,
.events-page-shell,
.events-list-shell {
  display: grid;
  gap: 16px;
}

.community-home-shell .community-hero,
.events-page-hero,
.events-list-hero,
.event-detail-hero-main {
  overflow: hidden;
}

.community-home-shell .community-hero,
.events-page-hero,
.events-list-hero {
  position: relative;
  border-radius: 28px;
}

.community-home-shell .community-hero {
  min-height: 372px;
  padding: 20px 20px 18px;
  background:
    linear-gradient(135deg, rgba(6, 12, 26, 0.88), rgba(12, 20, 37, 0.82)),
    url("/assets/featured-event-bg.jpg");
  background-size: cover;
  background-position: center 40%;
  border: 1px solid rgba(118, 150, 255, 0.14);
  box-shadow: var(--stage-shadow-soft);
}

.community-home-shell .community-hero::before,
.events-page-hero::before,
.events-list-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top left, rgba(123, 140, 255, 0.22), transparent 28%),
    radial-gradient(circle at top right, rgba(67, 200, 154, 0.12), transparent 22%),
    linear-gradient(180deg, rgba(5, 10, 21, 0.08), rgba(5, 10, 21, 0.46));
  pointer-events: none;
}

.community-home-shell .community-hero > *,
.events-page-hero > *,
.events-list-hero > * {
  position: relative;
  z-index: 1;
}

.community-home-shell .hero-layout {
  gap: 14px;
}

.community-home-shell .hero-rail {
  gap: 12px;
}

.community-home-shell .spotlight-shell,
.community-home-shell .directory-shell,
.community-home-shell .leaderboard-shell,
.events-page-shell .events-list-card,
.events-list-shell .events-list-card,
.events-list-shell .events-list-tabs,
.events-page-shell .events-list-tabs {
  border-radius: 26px;
  border: 1px solid rgba(118, 150, 255, 0.14);
  background:
    radial-gradient(circle at top right, rgba(123, 140, 255, 0.08), transparent 28%),
    linear-gradient(180deg, rgba(12, 20, 37, 0.9), rgba(19, 30, 52, 0.86));
  box-shadow: var(--stage-shadow-soft);
}

.community-home-shell .community-section {
  overflow: hidden;
}

.community-home-shell .card-head {
  margin-bottom: 10px;
}

.activity-list,
.leaderboard-list,
.events-list-grid,
.events-card-grid {
  display: grid;
  gap: 12px;
}

.activity-list {
  align-content: start;
}

.activity-row-card {
  position: relative;
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(118, 150, 255, 0.16);
  background:
    linear-gradient(135deg, rgba(7, 12, 23, 0.62), rgba(16, 25, 43, 0.72)),
    url("/assets/featured-event-bg.jpg");
  background-size: cover;
  background-position: center;
  overflow: hidden;
  box-shadow: var(--stage-shadow-soft);
  isolation: isolate;
}

.activity-row-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(123, 140, 255, 0.2), transparent 24%),
    radial-gradient(circle at 82% 18%, rgba(67, 200, 154, 0.12), transparent 18%),
    linear-gradient(180deg, rgba(8, 14, 29, 0.12), rgba(8, 14, 29, 0.58));
  pointer-events: none;
}

.activity-row-card > * {
  position: relative;
  z-index: 1;
}

.compact-activity-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.activity-row-main {
  display: grid;
  gap: 8px;
}

.community-info-head {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.activity-row-main strong {
  color: #f1f6ff;
  font-size: clamp(18px, 2vw, 26px);
}

.activity-row-main p,
.activity-row-main small {
  color: rgba(226, 234, 251, 0.72);
}

.activity-row-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
}

.leaderboard-list {
  align-content: start;
}

.leaderboard-row {
  display: grid;
  grid-template-columns: auto 52px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(118, 150, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.03));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.leaderboard-row .mini-avatar {
  width: 46px;
  height: 46px;
  flex-basis: 46px;
}

.leaderboard-copy {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.leaderboard-copy strong {
  font-size: 15px;
  color: var(--stage-text);
}

.leaderboard-copy small {
  color: var(--stage-muted);
}

.featured-player-rank {
  min-width: 74px;
  justify-content: center;
  box-shadow: 0 8px 18px rgba(94, 132, 255, 0.18);
}

.events-page-shell .events-list-tabs,
.events-list-shell .events-list-tabs {
  display: flex;
  gap: 8px;
  align-items: center;
  padding: 10px;
  flex-wrap: wrap;
}

.events-list-tab {
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(118, 150, 255, 0.16);
  background: rgba(255, 255, 255, 0.06);
  color: var(--stage-muted);
  box-shadow: none;
}

.events-list-tab.is-active {
  color: #fff;
  background: linear-gradient(135deg, rgba(119, 136, 255, 0.98), rgba(87, 184, 255, 0.98));
  border-color: rgba(137, 163, 255, 0.42);
}

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

.events-list-card,
.event-list-card {
  display: grid;
  gap: 0;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(118, 150, 255, 0.14);
  background:
    radial-gradient(circle at top right, rgba(123, 140, 255, 0.12), transparent 24%),
    linear-gradient(180deg, rgba(12, 20, 37, 0.9), rgba(19, 30, 52, 0.88));
  box-shadow: var(--stage-shadow-soft);
}

.events-list-card-banner,
.event-list-card-banner {
  position: relative;
  min-height: 180px;
  background:
    linear-gradient(135deg, rgba(6, 10, 20, 0.28), rgba(6, 10, 20, 0.62)),
    url("/assets/featured-event-bg.jpg");
  background-size: cover;
  background-position: center;
}

.events-list-card-banner::after,
.event-list-card-banner::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 18%, rgba(123, 140, 255, 0.18), transparent 24%),
    radial-gradient(circle at 84% 18%, rgba(255, 184, 79, 0.1), transparent 22%),
    linear-gradient(180deg, rgba(8, 14, 29, 0.1), rgba(8, 14, 29, 0.34));
}

.events-list-card-body,
.event-list-card-body {
  display: grid;
  gap: 12px;
  padding: 16px;
}

.events-list-card-head,
.event-list-card-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.events-list-card-head strong,
.event-list-card-head strong {
  display: block;
  color: #f1f6ff;
  font-size: 20px;
  line-height: 1.15;
}

.events-list-card-head span,
.event-list-card-head span,
.events-list-card-body p,
.event-list-card-body p,
.events-list-card-body small,
.event-list-card-body small {
  color: rgba(226, 234, 251, 0.72);
}

.events-list-card-meta,
.event-list-card-meta,
.events-list-card-actions,
.event-list-card-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.events-list-card-actions,
.event-list-card-actions {
  justify-content: space-between;
}

.events-list-card.is-live,
.event-list-card.is-live {
  border-color: rgba(67, 200, 154, 0.22);
}

.events-list-card.is-featured,
.event-list-card.is-featured {
  box-shadow:
    0 18px 40px rgba(3, 8, 19, 0.26),
    0 0 0 1px rgba(123, 140, 255, 0.18);
}

.events-list-card.is-featured .events-list-card-banner::after,
.event-list-card.is-featured .event-list-card-banner::after {
  background:
    radial-gradient(circle at 20% 20%, rgba(123, 140, 255, 0.22), transparent 22%),
    radial-gradient(circle at 82% 18%, rgba(67, 200, 154, 0.14), transparent 20%),
    linear-gradient(180deg, rgba(8, 14, 29, 0.08), rgba(8, 14, 29, 0.42));
}

.events-list-shell .page-nav-link,
.events-page-shell .page-nav-link {
  color: var(--stage-muted);
}

.events-list-shell .page-nav-link:hover,
.events-page-shell .page-nav-link:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(118, 150, 255, 0.2);
}

.event-detail-shell .event-detail-hero {
  align-items: stretch;
}

.event-detail-shell .event-detail-hero-main {
  position: relative;
  background:
    linear-gradient(135deg, rgba(8, 14, 29, 0.72), rgba(12, 20, 37, 0.82)),
    url("/assets/featured-event-bg.jpg");
  background-size: cover;
  background-position: center 36%;
  border-radius: 26px;
}

.event-detail-shell .event-detail-hero-main::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top left, rgba(123, 140, 255, 0.2), transparent 26%),
    radial-gradient(circle at top right, rgba(67, 200, 154, 0.1), transparent 20%),
    linear-gradient(180deg, rgba(4, 8, 16, 0.04), rgba(4, 8, 16, 0.44));
  pointer-events: none;
}

.event-detail-shell .event-detail-hero-main > * {
  position: relative;
  z-index: 1;
}

.event-detail-shell .event-detail-hero-copy h2 {
  font-size: clamp(28px, 3vw, 40px);
}

.event-detail-shell .event-detail-highlight-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.event-detail-shell .event-detail-highlight-item {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.04));
  border-color: rgba(118, 150, 255, 0.14);
}

.event-detail-shell .event-detail-rail-card,
.event-detail-shell .event-detail-section {
  background:
    radial-gradient(circle at top right, rgba(123, 140, 255, 0.08), transparent 24%),
    linear-gradient(180deg, rgba(12, 20, 37, 0.9), rgba(19, 30, 52, 0.88));
}

.event-detail-shell .event-detail-rail-card .section-title h3,
.event-detail-shell .event-detail-section h3 {
  color: #f1f6ff;
}

.event-detail-shell .event-summary-card,
.event-detail-shell .event-summary-notes > div,
.event-detail-shell .event-allocation-card-inline {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.03));
}

.event-detail-shell .event-signup-card,
.event-detail-shell .event-team-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.03));
}

.event-detail-shell .event-signup-strip {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.event-detail-shell .event-team-card-compact,
.event-detail-shell .event-team-panel-compact {
  background: transparent;
}

.event-detail-shell .tournament-section {
  border-radius: 18px;
}

@media (max-width: 1200px) {
  .community-home-shell .hero-layout,
  .events-list-grid,
  .events-page-shell .events-list-grid,
  .events-list-shell .events-list-grid,
  .event-detail-shell .event-detail-highlight-strip {
    grid-template-columns: 1fr;
  }

  .compact-activity-card {
    grid-template-columns: 1fr;
  }

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

  .event-detail-shell .event-signup-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .page-shell-home::before,
  .page-shell-home::after {
    display: none;
  }

  .community-home-shell .community-hero,
  .events-page-hero,
  .events-list-hero {
    border-radius: 22px;
  }

  .community-home-shell .community-hero {
    min-height: 0;
    padding: 16px 14px 14px;
  }

  .community-home-shell .spotlight-shell,
  .community-home-shell .directory-shell,
  .community-home-shell .leaderboard-shell,
  .events-page-shell .events-list-tabs,
  .events-list-shell .events-list-tabs,
  .events-list-card,
  .event-list-card,
  .event-detail-shell .event-detail-hero-main,
  .event-detail-shell .event-detail-rail-card,
  .event-detail-shell .event-detail-section {
    border-radius: 20px;
  }

  .activity-row-card,
  .events-list-card-body,
  .event-list-card-body,
  .event-detail-shell .event-detail-hero-main {
    padding: 14px;
  }

  .leaderboard-row {
    grid-template-columns: auto 44px minmax(0, 1fr);
    padding: 12px 14px;
  }

  .events-list-grid,
  .event-detail-shell .event-detail-highlight-strip,
  .event-detail-shell .event-signup-strip {
    grid-template-columns: 1fr;
  }

  .events-list-card-banner,
  .event-list-card-banner {
    min-height: 150px;
  }

  .event-detail-shell .event-detail-hero-copy h2 {
    font-size: 24px;
  }
}

/* Prototype page refresh: home / events / event detail */

.prototype-home-page,
.prototype-events-page,
.prototype-event-detail-page,
.prototype-players-page {
  width: min(1180px, calc(100vw - 40px));
  margin: 0 auto 48px;
}

.prototype-hero-shell,
.prototype-block,
.prototype-event-detail-banner,
.prototype-event-stats-bar,
.prototype-event-list-card,
.prototype-leaderboard,
.prototype-team-card,
.prototype-tournament-summary {
  border: 1px solid rgba(108, 198, 255, 0.18);
  background:
    linear-gradient(180deg, rgba(10, 34, 43, 0.92), rgba(5, 18, 24, 0.96)),
    radial-gradient(circle at top left, rgba(85, 186, 255, 0.18), transparent 32%);
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.28);
}

.prototype-hero-shell,
.prototype-block,
.prototype-event-detail-banner,
.prototype-leaderboard,
.prototype-event-list-card {
  border-radius: 24px;
}

.prototype-home-page {
  width: min(1440px, calc(100vw - 40px));
  margin: 0 auto 48px;
  padding-top: 18px;
  display: grid;
  gap: 14px;
}

.prototype-events-page {
  width: min(1440px, calc(100vw - 40px));
  margin: 0 auto 48px;
  padding-top: 8px;
}

.prototype-event-detail-page {
  width: min(1440px, calc(100vw - 40px));
  margin: 0 auto 48px;
  padding-top: 8px;
}

.page-nav-home-refresh {
  display: grid;
  grid-template-columns: 426px 563px minmax(0, 1fr);
  align-items: center;
  min-height: 106px;
  padding: 0 32px 0 19px;
  width: min(1440px, calc(100vw - 40px));
  margin: 0 auto 16px;
  border-radius: 30px;
  background: rgba(28, 60, 66, 1);
  z-index: 140;
}

.page-shell-home > .page-nav-home-refresh {
  position: fixed;
  top: 10px;
  left: 50%;
  right: auto;
  margin: 0;
  transform: translateX(-50%);
  z-index: 180;
}

.page-nav-home-refresh .page-nav-main {
  display: contents;
}

.page-nav-home-refresh .page-nav-brand {
  display: flex;
  align-items: center;
  gap: 17px;
  width: 100%;
  min-width: 0;
}

.page-nav-brand-mark {
  width: 53px;
  height: 53px;
  border-radius: 16px;
  object-fit: cover;
  background: rgba(229, 229, 229, 1);
}

.page-nav-brand-copy {
  display: flex;
  align-items: center;
  gap: 28px;
}

.page-nav-home-refresh .page-nav-brand strong,
.page-nav-home-refresh .page-nav-brand span {
  color: rgba(210, 216, 217, 1);
  line-height: 50px;
}

.page-nav-home-refresh .page-nav-brand strong {
  font-size: 36px;
  font-weight: 700;
  letter-spacing: 0;
}

.page-nav-home-refresh .page-nav-brand span {
  font-size: 36px;
  font-weight: 400;
  opacity: 1;
}

.page-nav-home-refresh .page-nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 72px;
  width: 563px;
  min-height: 105px;
  margin: 0;
}

.page-nav-home-refresh .nav-auth,
.page-nav-home-refresh .nav-auth-logged {
  margin-left: auto;
  width: 100%;
  justify-content: flex-end;
  align-self: center;
}

.page-nav-home-refresh .page-nav-link {
  position: relative;
  min-width: 88px;
  min-height: 105px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: rgba(225, 243, 248, 0.92);
  font-size: 36px;
  font-weight: 700;
}

.page-nav-home-refresh .page-nav-link::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 2px;
  width: 0;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #79dcff, #63a3ff);
  transition: width 180ms ease;
}

.page-nav-home-refresh .page-nav-link.nav-active::after,
.page-nav-home-refresh .page-nav-link:hover::after {
  width: 34px;
}

.page-nav-home-refresh .nav-auth {
  gap: 10px;
}

.page-nav-home-refresh .nav-auth-entry-row {
  align-items: center;
  justify-content: flex-end;
  min-width: max-content;
  gap: 14px;
}

.page-nav-home-refresh .nav-auth-drawer-shell {
  width: auto;
  min-width: auto;
  justify-self: end;
}

.page-nav-home-refresh .nav-profile-avatar-btn,
.page-nav-home-refresh .nav-login-toggle,
.page-nav-home-refresh .nav-auth button.secondary-button {
  border-color: rgba(130, 208, 241, 0.16);
  background: rgba(255, 255, 255, 0.06);
}

.page-nav-home-refresh .nav-profile-avatar-btn,
.page-nav-home-refresh .nav-auth-entry-row .nav-profile-avatar-btn {
  width: 65px;
  min-width: 65px;
  height: 65px;
  min-height: 65px;
  border-radius: 50px;
  padding: 0;
}

.page-nav-home-refresh .nav-profile-avatar {
  width: 59px;
  height: 59px;
}

.page-nav-home-refresh .nav-auth-entry-row .secondary-button:not(.nav-profile-avatar-btn) {
  min-height: 52px;
  padding: 0 24px;
  border-radius: 999px;
  font-size: 24px;
  line-height: 1;
  font-weight: 700;
}

.page-nav-home-refresh .nav-profile-avatar.image-avatar img {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center;
}

.prototype-captain-card,
.prototype-player-card {
  border: 1px solid rgba(118, 209, 255, 0.18);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02));
}

.prototype-page-header {
  margin: 14px 0 22px;
}

.prototype-page-header h1 {
  margin: 0;
  font-size: clamp(26px, 4vw, 40px);
  color: #f2fbff;
}

.prototype-section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.prototype-section-title-centered {
  justify-content: center;
  text-align: center;
}

.prototype-section-title h2 {
  margin: 0;
  color: #f2fbff;
  font-size: 30px;
}

.prototype-kicker {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 14px;
  max-width: 100%;
  min-height: 50px;
  line-height: 50px;
  color: rgba(210, 216, 217, 1);
  font-size: 36px;
  font-weight: 400;
  text-align: left;
  white-space: nowrap;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
}

.prototype-kicker-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  font-size: 30px;
  line-height: 1;
  filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.22));
}

.prototype-hero-shell {
  min-height: 443px;
  padding: 18px 0 0;
  margin-bottom: 4px;
  line-height: 20px;
  color: rgba(16, 16, 16, 1);
  font-size: 14px;
  text-align: center;
  font-family: PingFangSC-regular, "PingFang SC", "Noto Sans SC", sans-serif;
  background: linear-gradient(90.23deg, rgba(13, 41, 46, 1) 0.56%, rgba(17, 59, 67, 1) 38.61%, rgba(56, 66, 66, 0) 99.66%);
}

.prototype-home-stage-wrap {
  overflow: visible;
  border-radius: 20px;
  min-height: 329px;
}

.prototype-home-stage-wrap .hero-champion-stage {
  min-height: 329px;
  height: auto;
  align-content: start;
  padding: 0;
  border: 0;
  box-shadow: none;
  background: transparent;
  overflow: visible;
}

.prototype-home-stage-wrap .champion-lineup {
  min-height: 329px;
  height: auto;
  overflow: visible;
  padding: 0 4px;
}

.prototype-home-stage-wrap .champion-member-card {
  top: 8px;
  width: 211px;
  min-height: 211px;
  height: 211px;
  overflow: hidden;
  border-radius: 20px;
  clip-path: inset(0 round 20px);
  background: rgba(229, 229, 229, 1);
  border: 0;
}

.prototype-home-stage-wrap .champion-member-card::after,
.prototype-home-stage-wrap .champion-member-card .player-poster-art,
.prototype-home-stage-wrap .champion-member-card .player-poster-shade,
.prototype-home-stage-wrap .champion-member-card .player-poster-avatar,
.prototype-home-stage-wrap .champion-member-card .player-poster-avatar.image-avatar img,
.prototype-home-stage-wrap .champion-member-positions {
  border-radius: 20px;
}

.prototype-home-stage-wrap .champion-member-card::after {
  display: none;
}

.prototype-champion-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.prototype-champion-card {
  min-height: 126px;
  padding: 8px;
  border-radius: 16px;
  border: 2px solid rgba(92, 218, 255, 0.72);
  background:
    linear-gradient(180deg, rgba(10, 38, 52, 0.9), rgba(10, 28, 36, 0.96)),
    url("/assets/yugioh-card-bg.png") center/cover no-repeat;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.prototype-champion-card-art {
  min-height: 54px;
  border-radius: 12px;
  margin-bottom: 8px;
  background: linear-gradient(180deg, rgba(94, 138, 255, 0.16), rgba(82, 122, 214, 0.02));
}

.prototype-champion-avatar-wrap {
  display: flex;
  justify-content: center;
  padding-top: 6px;
}

.prototype-champion-avatar,
.prototype-row-avatar,
.prototype-inline-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  overflow: hidden;
  background: linear-gradient(135deg, #8ee1ff, #6288ff);
  color: #04121b;
  font-weight: 800;
}

.prototype-champion-avatar {
  width: 38px;
  height: 38px;
  font-size: 14px;
}

.prototype-row-avatar {
  width: 44px;
  height: 44px;
}

.prototype-inline-avatar {
  width: 28px;
  height: 28px;
  font-size: 13px;
}

.prototype-player-meta {
  display: flex;
  gap: 10px;
  margin: 4px 0;
  font-size: 10px;
  color: rgba(219, 246, 255, 0.78);
  justify-content: center;
}

.prototype-hero-row {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
  justify-content: center;
}

.prototype-hero-row .hero-icon {
  width: 14px;
  height: 14px;
}

.prototype-block {
  padding: 18px 20px 20px;
  margin-bottom: 0;
}

.prototype-event-banner-card,
.prototype-event-banner {
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  min-height: 156px;
  background:
    linear-gradient(90deg, rgba(18, 52, 59, 0.82), rgba(18, 52, 59, 0.28)),
    url("/assets/featured-event-bg.jpg") center/cover no-repeat;
}

.prototype-event-banner-card {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  padding: 22px;
}

.prototype-event-banner-card.is-clickable {
  cursor: pointer;
}

.prototype-event-banner-copy h3,
.prototype-event-card-title h2,
.prototype-event-detail-copy h2 {
  margin: 0 0 8px;
  color: #f8fdff;
}

.prototype-event-banner-copy p,
.prototype-event-card-body p,
.prototype-event-detail-copy p {
  margin: 0 0 6px;
  color: rgba(236, 248, 255, 0.82);
  font-size: 22px;
  font-weight: 700;
}

.prototype-event-banner-copy small {
  color: rgba(236, 248, 255, 0.74);
}

.prototype-event-banner-actions,
.prototype-event-card-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.prototype-events-list {
  width: min(1337px, calc(100% - 90px));
  margin: 0 auto;
  display: grid;
  gap: 20px;
}

.prototype-tab-row {
  display: flex;
  gap: 220px;
  width: min(1337px, calc(100% - 90px));
  margin: 0 auto 18px;
}

.prototype-tab-button {
  position: relative;
  border: 0;
  background: transparent;
  color: rgba(222, 245, 255, 0.9);
  font-size: 28px;
  line-height: 40px;
  font-weight: 700;
  padding: 0 0 14px;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
  white-space: nowrap;
  box-shadow: none !important;
  transform: none !important;
  border-radius: 0;
}

.prototype-tab-button:hover,
.prototype-tab-button:focus-visible,
.prototype-tab-button:active {
  background: transparent !important;
  box-shadow: none !important;
  transform: none !important;
  border-color: transparent !important;
}

.prototype-tab-button.is-active {
  color: #78e7ff;
}

.prototype-tab-button.is-active::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 55px;
  height: 4px;
  border-radius: 999px;
  background: #65dfff;
}

.prototype-event-list-card {
  padding: 0;
  border: 0;
  border-radius: 20px;
  background: linear-gradient(90.23deg, rgba(13, 41, 46, 1) 0.56%, rgba(17, 59, 67, 1) 38.61%, rgba(56, 66, 66, 0) 99.66%);
  box-shadow: none;
}

.prototype-event-list-card.is-clickable {
  cursor: pointer;
}

.prototype-events-page .prototype-page-header {
  width: min(1337px, calc(100% - 90px));
  margin: 0 auto 20px;
}

.prototype-event-detail-header {
  width: min(1337px, calc(100% - 90px));
  margin: 0 auto 8px;
}

.prototype-event-detail-header h1 {
  margin: 0;
  color: #d8dfe3;
  font-size: 50px;
  line-height: 1.1;
  font-weight: 800;
  text-align: left;
  white-space: nowrap;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
}

.prototype-events-page .prototype-page-header h1 {
  width: 166px;
  height: 50px;
  margin: 0;
  margin-left: 8px;
  color: #d8dfe3;
  font-size: 36px;
  line-height: 50px;
  font-weight: 800;
  text-align: left;
  white-space: nowrap;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
}

.prototype-events-list-frame {
  width: 1337px;
  max-width: 100%;
  height: 291px;
  margin: 0 auto;
  padding: 30px 21.5px;
  border-radius: 20px;
}

.prototype-events-list-media {
  position: relative;
  width: 1294px;
  max-width: 100%;
  height: 230px;
  margin: 0 auto;
  border-radius: 20px;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(18, 52, 59, 0.82), rgba(18, 52, 59, 0.28)),
    url("/assets/featured-event-bg.jpg") center/cover no-repeat;
}

.prototype-events-list-copy {
  position: absolute;
  left: 33px;
  top: 28px;
  width: calc(100% - 320px);
  text-align: left;
}

.prototype-events-list-copy h2 {
  margin: 0;
  color: #e3e8e7;
  font-size: 36px;
  line-height: 1;
  font-weight: 700;
  white-space: nowrap;
}

.prototype-events-list-foot {
  position: absolute;
  left: 33px;
  right: 31px;
  bottom: 14px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
}

.prototype-events-list-meta {
  display: inline-flex;
  align-items: center;
  gap: 24px;
  white-space: nowrap;
  min-width: 0;
}

.prototype-events-list-status {
  font-size: 20px;
  line-height: 1;
  font-weight: 700;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
}

.prototype-events-list-status.is-live {
  color: #5ecfff;
}

.prototype-events-list-status.is-completed {
  color: #34ca70;
}

.prototype-events-list-note {
  color: rgba(227, 232, 231, 0.95);
  font-size: 20px;
  line-height: 1;
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
}

.prototype-events-list-actions {
  display: flex;
  align-items: center;
}

.prototype-events-list-actions button {
  width: 147px;
  min-width: 147px;
  height: 43px;
  border-radius: 20px;
  border: 0;
  background: linear-gradient(88.13deg, rgba(114, 147, 255, 1) 5.19%, rgba(89, 181, 255, 1) 97.49%);
  color: rgba(210, 216, 217, 1);
  font-size: 20px;
  line-height: 1;
  text-align: center;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
  padding: 0;
  box-shadow: none;
}

.prototype-event-detail-stage {
  width: min(1337px, calc(100% - 90px));
  min-height: 940px;
  margin: 0 auto;
  padding: 24px 28px 24px;
  border-radius: 20px;
  background: linear-gradient(90.23deg, rgba(13, 41, 46, 1) 0.56%, rgba(17, 59, 67, 1) 38.61%, rgba(56, 66, 66, 0) 99.66%);
}

.prototype-event-detail-banner-wrap {
  width: 100%;
}

.prototype-event-detail-banner-wrap .prototype-event-banner-card {
  width: 100%;
  min-height: 230px;
  height: 230px;
  padding: 0;
  border: 0;
  border-radius: 20px;
  overflow: hidden;
  background: rgba(229, 229, 229, 1);
}

.prototype-event-detail-banner-wrap .prototype-event-banner-media {
  width: 100%;
  height: 100%;
  border-radius: 20px;
  background:
    linear-gradient(90deg, rgba(18, 52, 59, 0.82), rgba(18, 52, 59, 0.28)),
    url("/assets/featured-event-bg.jpg") center/cover no-repeat;
}

.prototype-event-detail-meta-row {
  margin-top: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.prototype-event-detail-meta-main {
  display: inline-flex;
  align-items: center;
  gap: 24px;
  min-width: 0;
}

.prototype-event-detail-meta-actions {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  flex: 0 0 auto;
}

.prototype-event-detail-meta-actions .secondary-button {
  width: 147px;
  min-width: 147px;
  height: 43px;
  border-radius: 20px;
  border: 0;
  background: linear-gradient(88.13deg, rgba(114, 147, 255, 1) 5.19%, rgba(89, 181, 255, 1) 97.49%) !important;
  color: rgba(210, 216, 217, 1) !important;
  font-size: 20px;
  line-height: 1;
  font-weight: 700;
  padding: 0;
  box-shadow: none;
}

.prototype-event-detail-roster {
  margin-top: 18px;
  display: grid;
  gap: 16px;
}

.prototype-event-detail-row {
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  height: 77px;
  margin: 0 auto;
  padding: 0 19px;
  border-radius: 20px;
  border: 1px solid rgba(62, 183, 247, 0.92);
  background: linear-gradient(90deg, rgba(20, 68, 78, 0.72), rgba(6, 19, 26, 0.34));
}

.prototype-event-slot-placeholders {
  display: grid;
  gap: 14px;
  justify-content: start;
  padding-left: 12px;
}

.prototype-leaderboard {
  width: 1337px;
  max-width: 100%;
  height: 593px;
  padding: 45px 19px 149px;
  border-radius: 20px;
  background: linear-gradient(90.23deg, rgba(13, 41, 46, 1) 0.56%, rgba(17, 59, 67, 1) 38.61%, rgba(56, 66, 66, 0) 99.66%);
  line-height: 20px;
  color: rgba(16, 16, 16, 1);
  font-size: 14px;
  text-align: center;
  font-family: PingFangSC-regular, "PingFang SC", "Noto Sans SC", sans-serif;
  border: 0;
}

.prototype-leaderboard-head,
.prototype-leaderboard-row,
.prototype-roster-row {
  align-items: center;
}

.prototype-leaderboard-head {
  display: block;
  width: 1299px;
  max-width: 100%;
  margin: 0 auto 25px;
  padding: 0;
}

.prototype-leaderboard-sort-group {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-left: 449px;
  margin-right: 325px;
}

.prototype-sort-button {
  border: 0;
  background: transparent;
  color: rgba(226, 236, 241, 0.86);
  font-size: 50px;
  line-height: 1;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  min-height: 66px;
  padding: 0 8px 10px;
  position: relative;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: none;
  flex: 0 0 auto;
}

.prototype-sort-button span {
  display: none;
}

.prototype-sort-button.is-active {
  color: #55d08a;
}

.prototype-sort-button.is-active::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 112px;
  height: 4px;
  border-radius: 999px;
  transform: translateX(-50%);
  background: #55d08a;
}

.prototype-leaderboard-row,
.prototype-roster-row {
  display: flex;
  align-items: center;
  gap: 16px;
  width: 1299px;
  max-width: 100%;
  height: 77px;
  margin: 0 auto 16px;
  padding: 0 19px;
  border-radius: 20px;
  border: 1px solid rgba(62, 183, 247, 0.92);
  background: linear-gradient(90deg, rgba(20, 68, 78, 0.72), rgba(6, 19, 26, 0.34));
}

.prototype-leaderboard-row-girl {
  border-color: rgba(255, 105, 180, 0.88);
  box-shadow:
    0 0 0 1px rgba(255, 105, 180, 0.62),
    0 0 14px rgba(255, 105, 180, 0.44),
    0 0 30px rgba(255, 105, 180, 0.26);
}

.prototype-leaderboard-row-empty {
  width: 1299px;
  max-width: 100%;
  min-height: 60px;
  border: 0;
  background: transparent;
  margin-bottom: 10px;
  padding: 0;
  grid-template-columns: 180px 1fr;
  gap: 0;
}

.prototype-rank-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 142px;
  height: 50px;
  border-radius: 25px;
  background: linear-gradient(88.13deg, rgba(114, 147, 255, 1) 5.19%, rgba(89, 181, 255, 1) 97.49%);
  color: #eff9ff;
  font-size: 20px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.prototype-row-rank-slot {
  width: 216px;
  min-width: 216px;
  display: flex;
  align-items: center;
}

.prototype-row-avatar-slot {
  width: 65px;
  min-width: 65px;
  height: 65px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.prototype-row-avatar {
  width: 65px;
  height: 65px;
}

.prototype-row-name {
  min-width: 120px;
  color: #f8fdff;
  font-size: 20px;
  line-height: 1.1;
  text-align: left;
  white-space: nowrap;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
  font-weight: 800;
}

.prototype-row-power {
  min-width: 96px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(222, 235, 240, 0.92);
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
  text-align: left;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
  font-weight: 800;
}

.prototype-row-power img {
  width: 21px;
  height: 21px;
  object-fit: contain;
}

.prototype-row-mmr,
.prototype-row-trophy,
.prototype-row-crown {
  min-width: 96px;
  color: rgba(222, 235, 240, 0.92);
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
  text-align: left;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
  font-weight: 800;
}

.prototype-row-mmr {
  font-size: 13px;
  text-align: left;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
  font-weight: 800;
}

.prototype-row-pos-capsule {
  width: fit-content;
  min-width: 0;
  max-width: 100%;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  padding: 0 14px;
  border-radius: 16px;
  border: 1px solid rgba(62, 183, 247, 0.92);
  background: rgba(8, 26, 34, 0.55);
  white-space: nowrap;
}

.prototype-row-pos-icon {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.prototype-row-pos-empty {
  color: rgba(212, 241, 255, 0.7);
  font-size: 20px;
}

.prototype-row-tail {
  margin-left: auto;
  min-width: 130px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
}

.prototype-row-hero-pair .hero-icon {
  width: 32px;
  height: 32px;
}

.prototype-row-tail {
  display: flex;
  justify-content: flex-start;
  gap: 10px;
}

.prototype-row-empty-fill {
  display: block;
}

.prototype-champion-copy strong,
.prototype-team-head strong {
  color: #f8fdff;
  font-size: 42px;
}

.prototype-player-cell small,
.prototype-table-empty,
.prototype-strip-empty,
.prototype-summary-metrics span,
.prototype-team-member span,
.prototype-team-head span {
  color: rgba(212, 241, 255, 0.72);
}

.prototype-hero-row .hero-icon {
  width: 36px;
  height: 36px;
}

.prototype-event-detail-banner {
  padding: 28px;
  margin-bottom: 18px;
}

.prototype-home-feature-block,
.prototype-home-board-block {
  background:
    linear-gradient(180deg, rgba(6, 20, 28, 0.96), rgba(5, 16, 22, 0.98));
}

.prototype-home-feature-block {
  width: min(1337px, calc(100% - 90px));
  margin: 0 auto;
  padding: 0;
  background: transparent;
}

.prototype-home-feature-title {
  position: relative;
  width: min(1337px, calc(100% - 90px));
  margin: 0 auto 18px;
  padding-left: 0;
  z-index: 2;
}

.prototype-home-feature-title::before {
  content: none;
}

.prototype-home-feature-title h2 {
  margin: 0;
  line-height: 46px;
  color: #d8dfe3;
  font-size: 36px;
  font-weight: 700;
  text-align: left;
  font-family: PingFangSC-regular, "PingFang SC", "Noto Sans SC", sans-serif;
}

.prototype-home-feature-frame {
  width: 1337px;
  max-width: 100%;
  height: 291px;
  margin: 0 auto;
  padding: 30px 21.5px;
  border-radius: 20px;
  line-height: 20px;
  color: rgba(16, 16, 16, 1);
  font-size: 14px;
  text-align: center;
  font-family: PingFangSC-regular, "PingFang SC", "Noto Sans SC", sans-serif;
  background: linear-gradient(90.23deg, rgba(13, 41, 46, 1) 0.56%, rgba(17, 59, 67, 1) 38.61%, rgba(56, 66, 66, 0) 99.66%);
}

.prototype-home-board-title {
  width: min(1337px, calc(100% - 90px));
  margin: 7px auto 30px;
}

.prototype-home-board-title h2 {
  width: 142px;
  min-height: 50px;
  margin: 0;
  color: #d8dfe3;
  font-size: 36px;
  line-height: 50px;
  font-weight: 800;
  text-align: left;
  white-space: nowrap;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
}

.prototype-home-board-block {
  border: 0 !important;
  border-color: transparent;
  border-radius: 0 !important;
  background: transparent;
  box-shadow: none;
  padding: 0;
  width: min(1337px, calc(100% - 90px));
  margin: 0 auto;
  overflow: visible;
}

.prototype-home-feature-block .prototype-event-banner-card {
  width: 1294px;
  max-width: 100%;
  min-height: 230px;
  height: 230px;
  margin: 0 auto;
  padding: 0;
  border: 0;
  border-radius: 20px;
  background: rgba(229, 229, 229, 1);
  overflow: hidden;
}

.prototype-home-feature-block .prototype-event-banner-media {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  border-radius: 20px;
  background:
    linear-gradient(90deg, rgba(18, 52, 59, 0.82), rgba(18, 52, 59, 0.28)),
    url("/assets/featured-event-bg.jpg") center/cover no-repeat;
}

.prototype-home-feature-block .prototype-event-banner-copy {
  position: absolute;
  left: 22px;
  top: 28px;
  width: 966px;
  text-align: left;
}

.prototype-home-feature-block .prototype-event-banner-copy h3 {
  margin: 0;
  color: #e3e8e7;
  font-size: 36px;
  line-height: 1;
  font-weight: 700;
  white-space: nowrap;
}

.prototype-home-feature-block .prototype-event-signup-count {
  position: absolute;
  left: 33px;
  bottom: 22px;
  margin: 0;
  color: rgba(227, 232, 231, 0.95);
  font-size: 20px;
  line-height: 1;
  font-weight: 600;
}

.prototype-home-feature-block .prototype-event-banner-actions {
  position: absolute;
  right: 31px;
  bottom: 14px;
  margin: 0;
}

.prototype-home-feature-block .prototype-event-banner-actions button {
  width: 147px;
  min-width: 147px;
  height: 43px;
  border-radius: 20px;
  border: 0;
  background: linear-gradient(88.13deg, rgba(114, 147, 255, 1) 5.19%, rgba(89, 181, 255, 1) 97.49%) !important;
  color: rgba(210, 216, 217, 1) !important;
  font-size: 20px;
  line-height: 1;
  text-align: center;
  font-family: "AlibabaPuHui", "AlibabaPuHuiTi", "PingFang SC", "Noto Sans SC", sans-serif;
  padding: 0;
  box-shadow: none;
}

.prototype-home-feature-block .prototype-event-banner-actions button:hover,
.prototype-home-feature-block .prototype-event-banner-actions button:focus-visible,
.prototype-home-feature-block .prototype-event-banner-actions button:active {
  background: linear-gradient(88.13deg, rgba(114, 147, 255, 1) 5.19%, rgba(89, 181, 255, 1) 97.49%) !important;
  color: rgba(210, 216, 217, 1) !important;
}

.prototype-home-section-title h2 {
  width: 142px;
  min-height: 50px;
  margin: 0;
  color: #d8dfe3;
  font-size: 50px;
  line-height: 50px;
  font-weight: 700;
  text-align: left;
}

.prototype-champion-copy {
  text-align: center;
}

.prototype-champion-name-row strong {
  font-size: 12px;
}

.prototype-event-detail-copy h2 {
  font-size: clamp(28px, 4vw, 42px);
}

.prototype-event-stats-bar {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  padding: 18px 22px;
  border-radius: 20px;
  margin-bottom: 24px;
}

.prototype-roster-list {
  display: grid;
}

.prototype-team-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.prototype-captain-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}

.prototype-captain-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 18px;
}

.prototype-captain-card small {
  color: rgba(212, 241, 255, 0.72);
}

.prototype-team-card {
  padding: 18px;
  border-radius: 20px;
}

.prototype-team-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.prototype-team-members {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.prototype-team-member {
  display: flex;
  align-items: center;
  gap: 10px;
}

.prototype-tournament-summary {
  padding: 18px;
  border-radius: 20px;
}

.prototype-summary-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.prototype-summary-metrics article {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 16px;
  border-radius: 16px;
  background: rgba(120, 204, 255, 0.08);
}

.prototype-summary-metrics strong {
  font-size: 22px;
  color: #f8fdff;
}

.prototype-player-filters-block {
  margin-bottom: 18px;
}

.prototype-filter-row {
  display: grid;
  grid-template-columns: 1.3fr 0.8fr 1fr;
  gap: 14px;
}

.prototype-filter-row label {
  display: grid;
  gap: 8px;
  color: rgba(212, 241, 255, 0.82);
}

.prototype-filter-row input,
.prototype-filter-row select {
  min-height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(118, 203, 235, 0.18);
  background: rgba(6, 20, 28, 0.66);
  color: #effbff;
  padding: 0 14px;
}

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

.prototype-player-card {
  padding: 18px;
  border-radius: 22px;
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.22);
}

.prototype-player-card-top {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}

.prototype-player-card-avatar {
  width: 58px;
  height: 58px;
  font-size: 20px;
}

.prototype-player-card-top p,
.prototype-player-card-intro {
  margin: 0;
  color: rgba(212, 241, 255, 0.72);
}

.prototype-player-card-metrics,
.prototype-player-card-meta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.prototype-player-card-metrics span,
.prototype-player-card-meta > span {
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(125, 204, 255, 0.08);
  color: #dff8ff;
  font-size: 13px;
}

@media (max-width: 1200px) {
  .prototype-champion-strip,
  .prototype-team-grid,
  .prototype-player-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .prototype-leaderboard-head,
  .prototype-leaderboard-row,
  .prototype-roster-row {
    grid-template-columns: 92px minmax(0, 1.3fr) 100px 100px 90px;
  }

  .prototype-home-feature-title h2 {
    font-size: 36px;
    line-height: 1.1;
  }

  .prototype-home-feature-frame {
    height: auto;
    padding: 20px 14px;
  }

  .prototype-home-feature-block .prototype-event-banner-card {
    min-height: 200px;
    height: 200px;
  }

  .prototype-home-feature-block .prototype-event-banner-copy {
    left: 18px;
    top: 20px;
    width: calc(100% - 240px);
  }

  .prototype-home-feature-block .prototype-event-banner-copy h3 {
    font-size: 30px;
  }

  .prototype-home-feature-block .prototype-event-signup-count {
    left: 18px;
    bottom: 16px;
    font-size: 32px;
  }

  .prototype-home-feature-block .prototype-event-banner-actions {
    right: 18px;
    bottom: 14px;
  }

  .prototype-home-feature-block .prototype-event-banner-actions button {
    min-width: 140px;
    height: 48px;
    font-size: 24px;
    padding: 0 16px;
  }
}

@media (max-width: 720px) {
  .page-shell-home {
    padding-top: 104px;
  }

  .page-nav-home-refresh {
    display: flex;
    grid-template-columns: none;
    width: min(100vw - 24px, 100%);
    min-height: 90px;
    padding: 14px 72px 14px 12px;
  }

  .page-shell-home > .page-nav-home-refresh {
    top: 8px;
  }

  .page-nav-home-refresh .page-nav-main {
    display: flex;
  }

  .page-nav-home-refresh .page-nav-brand strong {
    font-size: 22px;
    line-height: 1.2;
  }

  .page-nav-home-refresh .page-nav-brand span {
    font-size: 12px;
    line-height: 1.2;
  }

  .page-nav-home-refresh .page-nav-links {
    gap: 14px;
    width: auto;
    min-height: auto;
  }

  .prototype-home-feature-block {
    width: min(100vw - 24px, 100%);
  }

  .prototype-home-feature-title {
    margin-bottom: 12px;
  }

  .prototype-home-feature-title::before {
    content: none;
  }

  .prototype-home-feature-title h2 {
    font-size: 36px;
  }

  .prototype-home-feature-frame {
    padding: 10px;
  }

  .prototype-home-feature-block .prototype-event-banner-card {
    min-height: 176px;
    height: 176px;
  }

  .prototype-home-feature-block .prototype-event-banner-copy {
    left: 12px;
    top: 14px;
    width: calc(100% - 164px);
  }

  .prototype-home-feature-block .prototype-event-banner-copy h3 {
    font-size: 22px;
  }

  .prototype-home-feature-block .prototype-event-signup-count {
    left: 12px;
    bottom: 12px;
    font-size: 22px;
  }

  .prototype-home-feature-block .prototype-event-banner-actions {
    right: 12px;
    bottom: 10px;
  }

  .prototype-home-feature-block .prototype-event-banner-actions button {
    min-width: 110px;
    height: 40px;
    font-size: 18px;
    border-radius: 22px;
    padding: 0 12px;
  }

  .global-toolbar {
    top: 10px !important;
    right: 10px !important;
    left: auto !important;
    gap: 8px;
  }

  .prototype-home-page,
  .prototype-events-page,
  .prototype-event-detail-page,
  .prototype-players-page {
    width: min(100vw - 24px, 100%);
  }

  .prototype-champion-strip,
  .prototype-team-grid,
  .prototype-summary-metrics,
  .prototype-player-grid,
  .prototype-filter-row {
    grid-template-columns: 1fr;
  }

  .prototype-event-banner-card,
  .prototype-event-stats-bar {
    flex-direction: column;
    align-items: flex-start;
  }

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

  .prototype-leaderboard-row,
  .prototype-roster-row {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 16px 0;
  }

  .prototype-tab-row {
    gap: 18px;
    overflow-x: auto;
    padding-bottom: 4px;
  }
}
