/* =====================================================================
   Leaderboard — Podium, ranked list, locked rows, pinned row, upsell
   ===================================================================== */

/* === Rank delta colours === */

.leaderboard-row__delta--up   { color: var(--success); }
.leaderboard-row__delta--down { color: var(--error); }

/* === Locked row blur placeholders === */

.leaderboard-row--locked__blur {
  background: var(--neutral-accent);
  border-radius: var(--rounded-sm);
  display: inline-block;
  filter: blur(4px);
  height: 1em;
  user-select: none;
  width: 80%;
}

/* === "Resets Monday" caption === */

.leaderboard__reset-label {
  color: var(--neutral-primary);
  font-size: var(--text-xs);
  margin-top: var(--space-3);
  text-align: center;
}

/* === Sticky upsell banner === */

.leaderboard__upsell {
  align-items: center;
  background: var(--neutral-bg);
  border-top: 1px solid var(--neutral-accent);
  bottom: 0;
  display: flex;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  position: sticky;
}

/* === Podium layout === */

.leaderboard-podium {
  align-items: flex-end;
  display: flex;
  gap: var(--space-3);
  justify-content: center;
}

.leaderboard-podium__slot {
  align-items: center;
  display: flex;
  flex-direction: column;
  text-align: center;
}

.leaderboard-podium__slot--gold   { order: 2; padding-top: 32px; }
.leaderboard-podium__slot--silver { order: 1; padding-top: 16px; }
.leaderboard-podium__slot--bronze { order: 3; padding-top: 8px; }

.leaderboard-podium__avatar {
  border-radius: var(--rounded-full);
  margin: 0;
}

.leaderboard-podium__avatar--gold   { border: 3px solid var(--rank-gold); border-radius: var(--rounded-full); }
.leaderboard-podium__avatar--silver { border: 3px solid var(--rank-silver); border-radius: var(--rounded-full); }
.leaderboard-podium__avatar--bronze { border: 3px solid var(--rank-bronze); border-radius: var(--rounded-full); }

.leaderboard-podium__name  { font-size: var(--text-label); font-weight: var(--font-semibold); }
.leaderboard-podium__count { color: var(--neutral-primary); font-size: var(--text-caption); }
.leaderboard-podium__rank  { color: var(--neutral-primary); font-size: var(--text-caption); font-variant-numeric: tabular-nums; }

/* === [!] alert badge === */

.leaderboard-row__alert         { color: var(--error); display: none; }
.leaderboard-row__alert--visible { display: inline; }

/* === Tabular numbers for rank and check-in columns === */

.leaderboard-row__rank,
.leaderboard-row__checkins {
  font-variant-numeric: tabular-nums;
}

/* === Cat avatar in rows === */

.leaderboard-row__avatar {
  flex-shrink: 0;
}

/* === Monday reset reorder animation === */

.leaderboard-list--animating > li {
  transition: transform 300ms ease-in-out, opacity 300ms ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
  .leaderboard-list--animating > li {
    transition: none;
  }
}

/* === "(You)" label injected by Stimulus after broadcast === */

.leaderboard-row__you {
  font-size: var(--text-xs);
  color: var(--neutral-primary);
  margin-left: var(--space-1);
}

/* === Collapsible list toggle (details/summary) === */

.leaderboard-list-details > summary {
  align-items: center;
  color: var(--neutral-primary);
  cursor: pointer;
  display: flex;
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  gap: var(--space-3);
  justify-content: space-between;
  letter-spacing: 0.04em;
  list-style: none;
  padding: var(--space-2);
  text-transform: uppercase;
  user-select: none;
  flex-direction: column;
  width: 100%;
}

/* Top-3 podium cards inside summary */

.leaderboard-summary__podium {
  align-items: flex-center;
  display: flex;
  flex: 1;
  width: 100%;
  gap: var(--space-2);
  min-width: 0;
}

.leaderboard-summary__podium-card {
  align-items: center;
  border-radius: var(--rounded-md);
  border-width: 2px;
  border-style: solid;
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  padding: var(--space-2) var(--space-1);
  text-align: center;
}

.leaderboard-summary__podium-card--gold   { border-color: var(--rank-gold);  }
.leaderboard-summary__podium-card--silver { border-color: var(--rank-silver);}
.leaderboard-summary__podium-card--bronze { border-color: var(--rank-bronze);}

.leaderboard-summary__podium-avatar {
  font-size: 1.25rem;
  line-height: 1;
}

.leaderboard-summary__podium-name {
  color: var(--neutral-dark, #3D3530);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: none;
  white-space: nowrap;
  width: 100%;
}

.leaderboard-summary__podium-rank {
  color: var(--neutral-primary);
  font-size: var(--text-xs);
  font-variant-numeric: tabular-nums;
  font-weight: var(--font-bold);
}

.leaderboard-list-summary__toggle {
  align-items: center;
  display: flex;
  flex-shrink: 0;
  gap: var(--space-1);
}

.leaderboard-list-details > summary::-webkit-details-marker {
  display: none;
}

.leaderboard-list-summary__chevron {
  display: inline-block;
  transition: transform var(--time-200) ease;
}

.leaderboard-list-details[open] .leaderboard-list-summary__chevron {
  transform: rotate(180deg);
}

@media (prefers-reduced-motion: reduce) {
  .leaderboard-list-summary__chevron {
    transition: none;
  }
}
