/* ================================================================
   Leaderboards — HypeCity Tycoon · Phase D-Social
   ================================================================ */

.lb-tabs {
  display: flex;
  gap: var(--space-1);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.lb-tab {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: all 0.15s ease;
}
.lb-tab:hover { border-color: var(--color-primary); color: var(--color-primary); }
.lb-tab--active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

/* GAME-007: persona-filter pill row. Visually lighter than metric tabs
   (the metric is the primary axis; persona is a secondary cut). */
.lb-persona-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px dashed var(--color-border-subtle);
}
.lb-persona-pill {
  padding: 4px 12px;
  border: 1px solid var(--color-border-subtle);
  border-radius: 999px;
  background: transparent;
  color: var(--color-text-tertiary);
  font-size: var(--text-xs);
  font-family: var(--font-mono);
  cursor: pointer;
  transition: all 0.12s ease;
}
.lb-persona-pill:hover {
  border-color: rgba(0, 245, 212, 0.5);
  color: #00F5D4;
}
.lb-persona-pill--active {
  background: rgba(0, 245, 212, 0.12);
  border-color: #00F5D4;
  color: #00F5D4;
  font-weight: 600;
}
.lb-link-btn {
  background: none;
  border: none;
  padding: 0;
  color: var(--color-primary);
  cursor: pointer;
  text-decoration: underline;
  font: inherit;
}

.lb-content { min-height: 200px; }
.lb-loading, .lb-empty {
  text-align: center;
  padding: var(--space-6);
  color: var(--color-text-tertiary);
}

.lb-table { margin-bottom: var(--space-3); }

.lb-table__header {
  display: grid;
  grid-template-columns: 60px 1fr 140px;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-tertiary);
  border-bottom: 1px solid var(--color-border-subtle);
}

.lb-row {
  display: grid;
  grid-template-columns: 60px 1fr 140px;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border-subtle);
  font-size: var(--text-sm);
  transition: background 0.15s;
}
.lb-row:hover { background: rgba(0,0,0,0.02); }
.lb-row--you { background: rgba(34,197,94,0.06); font-weight: 600; }
.lb-row--top3 .lb-col-rank { font-size: var(--text-base); }

.lb-col-rank { font-weight: 600; color: var(--color-text-secondary); }
.lb-col-name { color: var(--color-text-primary); display: flex; align-items: center; gap: var(--space-1); }
.lb-col-value { text-align: right; font-family: var(--font-mono); color: var(--color-text-primary); }

.lb-you-badge {
  font-size: var(--text-xs);
  background: var(--color-primary);
  color: #fff;
  padding: 1px 6px;
  border-radius: var(--radius-sm);
  font-weight: 700;
}

.lb-your-rank {
  margin-top: var(--space-4);
  padding: var(--space-3);
  background: var(--color-surface);
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-lg);
}
.lb-your-rank h3 { margin: 0 0 var(--space-2) 0; font-size: var(--text-base); }

.lb-opt-in {
  text-align: center;
  padding: var(--space-4);
  color: var(--color-text-tertiary);
  font-size: var(--text-sm);
}
.lb-opt-in a { color: var(--color-primary); }

@media (max-width: 599px) {
  .lb-table__header, .lb-row { grid-template-columns: 50px 1fr 100px; }
  .lb-tabs { gap: var(--space-1); }
  .lb-tab { font-size: var(--text-xs); padding: var(--space-1) var(--space-2); }
}

/* ── DEMO_GATE: bot rows on the leaderboard ─────────────────── */
.lb-row--bot {
  background: linear-gradient(90deg, rgba(99,102,241,0.05) 0%, transparent 75%);
}
.lb-bot-badge {
  display: inline-block;
  margin-left: 4px;
  padding: 1px 6px;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.4;
  color: #fff;
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  border-radius: 4px;
  letter-spacing: 0.5px;
  vertical-align: 2px;
}
