/* LEADERBOARD.CSS — page-specific styles */
/* Global styles (nav, footer, dark mode, toggle, hamburger) come from global.css */

  /* PAGE */
  .page-wrap { max-width: var(--max); margin: 0 auto; padding: 0 32px 80px; }

  /* HEADER */
  .page-header { padding: 60px 0 40px; border-bottom: 1px solid transparent; border-image: linear-gradient(90deg, var(--sage-light), transparent) 1; margin-bottom: 32px; }
  .page-eyebrow { font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--sage-dark); margin-bottom: 16px; font-weight: 500; }
  .page-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(42px, 7vw, 64px); font-weight: 300; color: var(--text); line-height: 1.1; margin-bottom: 16px; }
  .page-title em { font-style: italic; color: var(--sage-dark); }
  .page-sub { font-size: 15px; color: var(--text2); font-weight: 300; line-height: 1.85; }

  /* FILTERS */
  .filter-row { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 28px; }
  .filter-btn { padding: 6px 16px; border-radius: 100px; font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; border: 0.5px solid var(--border2); background: transparent; color: var(--text2); cursor: pointer; transition: all 0.2s; font-family: 'DM Sans', sans-serif; }
  .filter-btn.active, .filter-btn:hover { background: var(--sage-dark); border-color: var(--sage-dark); color: var(--cream); }

  /* COUNT */
  .results-count { font-size: 12px; color: var(--text3); margin-bottom: 16px; letter-spacing: 0.04em; }

  /* LEADERBOARD */
  .leaderboard { display: flex; flex-direction: column; gap: 8px; }

  .lb-row {
    display: grid;
    grid-template-columns: 48px 1fr auto;
    align-items: center;
    gap: 16px;
    background: var(--surface);
    border: 0.5px solid var(--border);
    border-radius: 12px;
    padding: 16px 20px;
    text-decoration: none;
    transition: border-color 0.2s, background 0.2s, transform 0.15s;
    position: relative;
    overflow: hidden;
  }
  .lb-row::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: var(--sage); border-radius: 2px 0 0 2px; opacity: 0; transition: opacity 0.2s; }
  .lb-row:hover { border-color: var(--sage-light); background: var(--bg2); transform: translateX(2px); }
  .lb-row:hover::before { opacity: 1; }

  .lb-row.rank-1 { border-color: rgba(201,168,76,0.4); }
  .lb-row.rank-1::before { background: var(--gold); opacity: 1; }
  .lb-row.rank-2 { border-color: rgba(138,154,170,0.4); }
  .lb-row.rank-2::before { background: var(--silver); opacity: 1; }
  .lb-row.rank-3 { border-color: rgba(168,120,86,0.4); }
  .lb-row.rank-3::before { background: var(--bronze); opacity: 1; }

  .lb-rank { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 300; color: var(--text3); text-align: center; line-height: 1; }
  .lb-row.rank-1 .lb-rank { color: var(--gold); }
  .lb-row.rank-2 .lb-rank { color: var(--silver); }
  .lb-row.rank-3 .lb-rank { color: var(--bronze); }

  .lb-info { min-width: 0; }
  .lb-name { font-size: 15px; font-weight: 500; color: var(--text); margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .lb-meta { display: flex; gap: 10px; align-items: center; }
  .lb-city { font-size: 11px; color: var(--sage-dark); letter-spacing: 0.06em; }
  .lb-price { font-size: 11px; color: var(--text3); }

  .lb-score-wrap { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0; }
  .lb-score { font-family: 'Cormorant Garamond', serif; font-size: 30px; font-weight: 300; color: var(--sage-dark); line-height: 1; }
  .lb-row.rank-1 .lb-score { color: var(--gold); }
  .lb-row.rank-2 .lb-score { color: var(--silver); }
  .lb-row.rank-3 .lb-score { color: var(--bronze); }
  .lb-bar-wrap { width: 80px; height: 3px; background: var(--border); border-radius: 2px; overflow: hidden; }
  .lb-bar { height: 100%; background: var(--sage); border-radius: 2px; transition: width 0.4s ease; }
  .lb-row.rank-1 .lb-bar { background: var(--gold); }
  .lb-row.rank-2 .lb-bar { background: var(--silver); }
  .lb-row.rank-3 .lb-bar { background: var(--bronze); }

  @media (max-width: 600px) {
    .page-wrap { padding: 0 20px 60px; }
    .lb-bar-wrap { width: 52px; }
  }
