/* Reset & base */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ===========================
   CSS Custom Properties
   Scoped to .leaderboard to avoid
   polluting host page (Wix iframe)
   =========================== */
.leaderboard {
  /* Brand colors — Moontrekker cyan blue */
  --lb-primary: #0097A7;
  --lb-primary-dark: #00838F;
  --lb-primary-light: #00ACC1;
  --lb-gold: #d4880f;
  --lb-silver: #5a6877;
  --lb-bronze: #9c4221;

  /* Neutrals */
  --lb-bg: #ffffff;
  --lb-bg-alt: #f5f7fa;
  --lb-text: #333333;
  --lb-text-light: #666666;
  --lb-text-muted: #999999;
  --lb-border: #d0d5dd;
  --lb-border-light: #e8ecf0;
  --lb-hover: #eef2f7;
  --lb-error: #c53030;

  /* Typography */
  --lb-font: 'Segoe UI', system-ui, -apple-system, sans-serif;
  --lb-font-size-base: 15px;
  --lb-font-size-sm: 13px;
  --lb-font-size-lg: 18px;
  --lb-font-size-xl: 22px;

  /* Layout */
  --lb-radius: 4px;
  --lb-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

/* ===========================
   Container
   =========================== */
.leaderboard {
  font-family: var(--lb-font);
  font-size: var(--lb-font-size-base);
  color: var(--lb-text);
  background: var(--lb-bg);
  max-width: 700px;
  margin: 0 auto;
  border-radius: var(--lb-radius);
  box-shadow: var(--lb-shadow);
  overflow: hidden;
  border: 1px solid var(--lb-border);
}

/* ===========================
   Hero Header
   =========================== */
.leaderboard__hero {
  background:
    linear-gradient(rgba(0, 40, 50, 0.35), rgba(0, 40, 50, 0.35)),
    url('https://static.wixstatic.com/media/05717c_69be5a0edbb947e8892905bf498e9e95~mv2.jpg/v1/fill/w_675,h_450,al_c,q_80,usm_0.66_1.00_0.01,enc_auto/Ascent%202.jpg');
  background-size: cover;
  background-position: center;
  color: #ffffff;
  padding: 1.25rem 1rem;
}

.leaderboard__hero-inner {
  text-align: center;
}

.leaderboard__hero-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  margin-bottom: 0.75rem;
}

.leaderboard__hero-logo {
  max-width: 260px;
  width: 80%;
  height: auto;
  object-fit: contain;
}

.leaderboard__hero-title {
  font-size: var(--lb-font-size-lg);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  line-height: 1.2;
}

.leaderboard__hero-total {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.375rem;
}

.leaderboard__hero-total-label {
  font-size: var(--lb-font-size-sm);
  color: var(--lb-gold);
  font-weight: 600;
  font-style: italic;
}

.leaderboard__hero-total-amount {
  font-size: var(--lb-font-size-xl);
  font-weight: 700;
  color: var(--lb-gold);
  font-variant-numeric: tabular-nums;
}

/* ===========================
   Top 3 Podium
   =========================== */
.leaderboard__podium {
  background: var(--lb-bg);
  border-bottom: 1px solid var(--lb-border);
  padding: 0.75rem 1rem;
}

.leaderboard__podium-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  margin-bottom: 0.625rem;
}

.leaderboard__podium-title {
  font-size: var(--lb-font-size-base);
  font-weight: 700;
  color: var(--lb-text);
  letter-spacing: 0.02em;
}

.leaderboard__podium-cards {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
}

.leaderboard__podium-card {
  flex: 1;
  max-width: 180px;
  text-align: center;
  padding: 0.5rem 0.375rem;
  border-radius: var(--lb-radius);
  background: var(--lb-bg-alt);
  border: 1px solid var(--lb-border-light);
}

.leaderboard__podium-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 0.25rem;
}

.leaderboard__podium-card:nth-child(1) .leaderboard__podium-label {
  color: var(--lb-gold);
}

.leaderboard__podium-card:nth-child(2) .leaderboard__podium-label {
  color: var(--lb-silver);
}

.leaderboard__podium-card:nth-child(3) .leaderboard__podium-label {
  color: var(--lb-bronze);
}

.leaderboard__podium-name {
  font-size: var(--lb-font-size-sm);
  font-weight: 600;
  color: var(--lb-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.leaderboard__podium-amount {
  font-size: var(--lb-font-size-sm);
  font-weight: 700;
  color: var(--lb-primary);
  font-variant-numeric: tabular-nums;
}

/* ===========================
   Tabs
   =========================== */
.leaderboard__tabs {
  display: flex;
  background: var(--lb-bg);
  border-bottom: 1px solid var(--lb-border);
}

.leaderboard__tab {
  flex: 1;
  padding: 0.75rem 0.5rem;
  border: none;
  background: none;
  cursor: pointer;
  font-family: var(--lb-font);
  font-size: var(--lb-font-size-sm);
  color: var(--lb-text-light);
  font-weight: 600;
  transition: color 0.2s, background-color 0.2s;
  border-bottom: 3px solid transparent;
  margin-bottom: -1px;
}

.leaderboard__tab:hover {
  color: var(--lb-primary);
  background-color: var(--lb-bg-alt);
}

.leaderboard__tab--active {
  color: #ffffff;
  background: var(--lb-primary);
  border-bottom-color: var(--lb-primary);
}

.leaderboard__tab--active:hover {
  color: #ffffff;
  background: var(--lb-primary-dark);
}

/* ===========================
   Content Panel
   =========================== */
.leaderboard__content {
}

/* ===========================
   States: Loading, Error, Empty
   =========================== */
.leaderboard__loading,
.leaderboard__error,
.leaderboard__empty {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--lb-text-light);
  font-size: var(--lb-font-size-base);
}

.leaderboard__error {
  color: var(--lb-error);
}

.leaderboard__empty {
  color: var(--lb-text-muted);
}

/* Spinner */
.spinner {
  width: 36px;
  height: 36px;
  margin: 0 auto 1rem;
  border: 3px solid var(--lb-border);
  border-top-color: var(--lb-primary);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ===========================
   Table
   =========================== */
.leaderboard__table {
  width: 100%;
  border-collapse: collapse;
}

/* Header row — blue bar */
.leaderboard__th {
  padding: 0.625rem 0.75rem;
  text-align: left;
  font-size: var(--lb-font-size-sm);
  font-weight: 600;
  color: #ffffff;
  background: var(--lb-primary);
  border-bottom: 1px solid var(--lb-primary-dark);
}

.leaderboard__th--rank {
  width: 52px;
  text-align: center;
}

.leaderboard__th--amount {
  text-align: right;
}

/* Data rows */
.leaderboard__row {
  transition: background-color 0.15s;
  border-bottom: 1px solid var(--lb-border-light);
}

.leaderboard__row:hover {
  background-color: var(--lb-hover);
}

/* Data cells */
.leaderboard__td {
  padding: 0.625rem 0.75rem;
  text-align: left;
  color: var(--lb-text);
}

.leaderboard__td--rank {
  width: 52px;
  text-align: center;
  font-weight: 600;
  color: var(--lb-text-light);
}

.leaderboard__td--name {
  font-weight: 500;
}

.leaderboard__link {
  color: var(--lb-primary);
  text-decoration: none;
  font-weight: 500;
}

.leaderboard__link:hover {
  text-decoration: underline;
}

.leaderboard__td--amount {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}

/* ===========================
   Top 3 Rank Highlighting
   =========================== */
.leaderboard__row--top1 .leaderboard__td--rank {
  color: var(--lb-gold);
  font-weight: 700;
}

.leaderboard__row--top2 .leaderboard__td--rank {
  color: var(--lb-silver);
  font-weight: 700;
}

.leaderboard__row--top3 .leaderboard__td--rank {
  color: var(--lb-bronze);
  font-weight: 700;
}

.leaderboard__row--top1 .leaderboard__td--name {
  font-weight: 600;
}

/* ===========================
   Footer
   =========================== */
.leaderboard__footer {
  display: flex;
  justify-content: space-between;
  padding: 0.625rem 0.75rem;
  font-size: var(--lb-font-size-sm);
  color: var(--lb-text-muted);
  border-top: 1px solid var(--lb-border-light);
}

.leaderboard__footer-right {
  display: flex;
  gap: 0.75rem;
}

/* ===========================
   Responsive: Mobile (< 640px)
   =========================== */
@media (max-width: 639px) {
  .leaderboard {
    --lb-font-size-base: 14px;
    --lb-font-size-sm: 12px;
    --lb-font-size-lg: 16px;
    --lb-font-size-xl: 18px;
    border-radius: 0;
    box-shadow: none;
    border-left: none;
    border-right: none;
  }

  .leaderboard__hero {
    padding: 1rem 0.75rem;
  }

  .leaderboard__hero-logo {
    width: 30px;
    height: 30px;
  }

  .leaderboard__podium-cards {
    gap: 0.25rem;
  }

  .leaderboard__podium-card {
    padding: 0.375rem 0.25rem;
  }

  .leaderboard__podium-label {
    font-size: 10px;
  }

  .leaderboard__tab {
    padding: 0.625rem 0.25rem;
    font-size: 12px;
  }

  .leaderboard__th,
  .leaderboard__td {
    padding: 0.5rem;
  }

  .leaderboard__th--rank,
  .leaderboard__td--rank {
    width: 40px;
  }

  .leaderboard__footer {
    flex-direction: column;
    align-items: center;
    gap: 0.25rem;
    text-align: center;
  }

  .leaderboard__footer-right {
    flex-direction: column;
    gap: 0.125rem;
  }
}

/* ===========================
   Responsive: Tablet (640px - 1024px)
   =========================== */
@media (min-width: 640px) and (max-width: 1024px) {
  .leaderboard {
    margin: 0.5rem;
  }
}

/* ===========================
   Responsive: Desktop (> 1024px)
   =========================== */
@media (min-width: 1025px) {
  .leaderboard {
    margin: 1rem auto;
  }

  .leaderboard__tab {
    font-size: var(--lb-font-size-base);
    padding: 0.875rem 0.75rem;
  }
}
