/* LEADERBOARD */
:root { --medal-gold: #c9a84c; --medal-silver: #8a9eb8; --medal-bronze: #a87856; }

/* PAGE */
  .page-wrap { max-width: var(--max); margin: 0 auto; padding: 0 32px 80px; }
  .page-header { padding: 60px 0 40px; border-bottom: 1px solid transparent; border-image: linear-gradient(90deg, var(--ocean), transparent) 1; margin-bottom: 32px; }
  .page-eyebrow { font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--gold); margin-bottom: 16px; font-weight: 500; }
  .page-title { font-family: 'Playfair Display', serif; font-size: clamp(42px, 7vw, 64px); font-weight: 300; color: var(--cream); line-height: 1.1; margin-bottom: 16px; }
  .page-title em { font-style: italic; color: var(--gold-light); }
  .page-sub { font-size: 15px; color: var(--text2); font-weight: 300; line-height: 1.85; }

  /* FILTERS (ship class pills — mirrors the city pills) */
  .filter-row { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 28px; }
  .filter-btn { padding: 7px 18px; border-radius: 100px; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; border: 0.5px solid var(--border2); background: transparent; color: var(--text2); cursor: pointer; transition: all 0.2s; font-family: 'Jost', sans-serif; }
  .filter-btn.active, .filter-btn:hover { background: var(--gold); border-color: var(--gold); 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(--ocean); border-radius: 2px 0 0 2px; opacity: 0; transition: opacity 0.2s; }
  .lb-row:hover { border-color: var(--ocean); background: var(--navy2); transform: translateX(3px); }
  .lb-row:hover::before { opacity: 1; }

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

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

  .lb-info { min-width: 0; }
  .lb-name { font-size: 15px; font-weight: 500; color: var(--cream); margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .lb-meta { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
  .lb-class { font-size: 11px; color: var(--wave); letter-spacing: 0.08em; background: rgba(46,143,217,0.12); border: 0.5px solid rgba(46,143,217,0.25); border-radius: 100px; padding: 2px 10px; }
  .lb-year { font-size: 11px; color: var(--text3); }
  .lb-refurb { font-size: 10px; color: var(--gold); letter-spacing: 0.06em; background: rgba(201,168,76,0.1); border: 0.5px solid rgba(201,168,76,0.25); border-radius: 100px; padding: 2px 9px; }

  .lb-score-wrap { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; flex-shrink: 0; }
  .lb-score { font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 300; color: var(--gold); line-height: 1; }
  .lb-row.rank-1 .lb-score { color: var(--medal-gold); }
  .lb-row.rank-2 .lb-score { color: var(--medal-silver); }
  .lb-row.rank-3 .lb-score { color: var(--medal-bronze); }
  .lb-bar-wrap { width: 80px; height: 3px; background: var(--border); border-radius: 2px; overflow: hidden; }
  .lb-bar { height: 100%; background: var(--ocean); border-radius: 2px; transition: width 0.5s ease; }
  .lb-row.rank-1 .lb-bar { background: var(--medal-gold); }
  .lb-row.rank-2 .lb-bar { background: var(--medal-silver); }
  .lb-row.rank-3 .lb-bar { background: var(--medal-bronze); }
  .lb-row-unsailed { opacity: 0.6; }
  .lb-score-unsailed { font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 300; color: var(--text3); line-height: 1; }
  .lb-not-sailed { font-size: 10px; color: var(--text3); letter-spacing: 0.08em; text-transform: uppercase; margin-top: 4px; text-align: right; }

@media(max-width:600px) {
  .page-wrap { padding: 0 20px 60px; }
  .lb-row { grid-template-columns: 38px 1fr; gap: 12px; }
  .lb-score-wrap { grid-column: 2; align-items: flex-start; flex-direction: row; gap: 12px; }
  .lb-bar-wrap { width: 70px; align-self: center; }
}