/* ══════════════════════════════════════════════════════════════
   MLB Leaderboards — leaderboards.css
   Dark-first with full light-mode support via html[data-theme='light']
   ══════════════════════════════════════════════════════════════ */

/* ── Theme tokens ──────────────────────────────────────────── */
.lb-page {
    --lb-bg:            #07080C;
    --lb-surface:       #0F111A;
    --lb-elevated:      #141927;
    --lb-surface-alt:   #0C0E16;
    --lb-border:        rgba(255,255,255,0.07);
    --lb-border-md:     rgba(255,255,255,0.11);
    --lb-border-hi:     rgba(255,255,255,0.18);
    --lb-text-1:        #F0F2F8;
    --lb-text-2:        #8B92A4;
    --lb-text-3:        #4E5567;
    --lb-accent:        #4582F0;
    --lb-accent-dim:    rgba(69,130,240,0.14);
    --lb-accent-glow:   rgba(69,130,240,0.22);
    --lb-hot:           #30D158;
    --lb-hot-dim:       rgba(48,209,88,0.11);
    --lb-hot-border:    rgba(48,209,88,0.28);
    --lb-cold:          #FF453A;
    --lb-cold-dim:      rgba(255,69,58,0.10);
    --lb-cold-border:   rgba(255,69,58,0.26);
    --lb-gold:          #F5A31B;
    --lb-silver:        #9BA8BB;
    --lb-bronze:        #C96B3B;
    --lb-rank-bg:       rgba(255,255,255,0.06);
    --lb-row-hover:     rgba(255,255,255,0.028);
    --lb-skeleton:      rgba(255,255,255,0.06);
    --lb-skeleton-shine:rgba(255,255,255,0.10);
    --lb-radius:        16px;
    --lb-radius-sm:     10px;
    --lb-radius-xs:     6px;
    --lb-shadow:        0 8px 32px rgba(0,0,0,0.36);
    --lb-transition:    180ms ease;
}

html[data-theme='light'] .lb-page {
    --lb-bg:            #eef3fb;
    --lb-surface:       #ffffff;
    --lb-elevated:      #f4f8ff;
    --lb-surface-alt:   #f8faff;
    --lb-border:        rgba(15,23,42,0.09);
    --lb-border-md:     rgba(15,23,42,0.14);
    --lb-border-hi:     rgba(15,23,42,0.22);
    --lb-text-1:        #0f172a;
    --lb-text-2:        #475569;
    --lb-text-3:        #94a3b8;
    --lb-accent:        #2563eb;
    --lb-accent-dim:    rgba(37,99,235,0.08);
    --lb-accent-glow:   rgba(37,99,235,0.14);
    --lb-hot:           #16a34a;
    --lb-hot-dim:       rgba(22,163,74,0.08);
    --lb-hot-border:    rgba(22,163,74,0.24);
    --lb-cold:          #dc2626;
    --lb-cold-dim:      rgba(220,38,38,0.07);
    --lb-cold-border:   rgba(220,38,38,0.22);
    --lb-gold:          #d97706;
    --lb-silver:        #64748b;
    --lb-bronze:        #92400e;
    --lb-rank-bg:       rgba(15,23,42,0.06);
    --lb-row-hover:     rgba(15,23,42,0.025);
    --lb-skeleton:      rgba(15,23,42,0.07);
    --lb-skeleton-shine:rgba(15,23,42,0.04);
    --lb-shadow:        0 4px 20px rgba(15,23,42,0.10);
}


/* ── Page shell ────────────────────────────────────────────── */
.lb-page {
    min-height: 100vh;
    background: var(--lb-bg);
    color: var(--lb-text-1);
    font-family: 'Manrope', 'Outfit', system-ui, sans-serif;
}

/* ── Hero header ───────────────────────────────────────────── */
.lb-hero {
    padding: 2.4rem 2rem 0;
    max-width: 1340px;
    margin: 0 auto;
}

.lb-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: var(--lb-accent);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 0.5rem;
}

.lb-hero__eyebrow svg {
    width: 14px;
    height: 14px;
    opacity: 0.85;
}

.lb-hero__title {
    margin: 0 0 0.35rem;
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.025em;
    color: var(--lb-text-1);
}

.lb-hero__lead {
    margin: 0;
    font-size: 0.96rem;
    color: var(--lb-text-2);
    max-width: 52rem;
    line-height: 1.6;
}


/* ── Controls bar (tabs + season) ──────────────────────────── */
.lb-controls {
    position: sticky;
    top: 0;
    z-index: 80;
    background: var(--lb-bg);
    border-bottom: 1px solid var(--lb-border);
}

.lb-controls__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    max-width: 1340px;
    margin: 0 auto;
    padding: 0 2rem;
    min-height: 3.6rem;
}

/* Category tabs */
.lb-cat-tabs {
    position: relative !important;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.2rem;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding: 0.6rem 0;
    flex: 1 1 0%;
    min-width: 0;
    /* Override global nav { } rule in nav.css */
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    height: auto !important;
    width: auto !important;
    inset: unset !important;
    z-index: auto !important;
    box-sizing: border-box;
}

.lb-cat-tabs::-webkit-scrollbar { display: none; }

.lb-cat-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.42rem 0.9rem;
    border: 1px solid transparent;
    border-radius: var(--lb-radius-sm);
    background: var(--lb-rank-bg);
    color: var(--lb-text-1);
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: color var(--lb-transition), background var(--lb-transition), border-color var(--lb-transition);
    font-family: inherit;
    letter-spacing: 0.01em;
    opacity: 0.7;
}

.lb-cat-tab svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    opacity: 0.7;
    transition: opacity var(--lb-transition);
}

.lb-cat-tab:hover {
    color: var(--lb-text-1);
    background: var(--lb-elevated);
    opacity: 1;
}

.lb-cat-tab.is-active {
    color: var(--lb-accent);
    background: var(--lb-accent-dim);
    border-color: rgba(69,130,240,0.22);
    opacity: 1;
}

html[data-theme='light'] .lb-cat-tab.is-active {
    border-color: rgba(37,99,235,0.2);
}

.lb-cat-tab.is-active svg { opacity: 1; }

/* Season toggle */
.lb-season-toggle--inactive {
    opacity: 0.35;
    pointer-events: none;
}

.lb-season-toggle {
    display: flex;
    gap: 0.2rem;
    flex-shrink: 0;
    background: var(--lb-rank-bg);
    border: 1px solid var(--lb-border);
    border-radius: var(--lb-radius-sm);
    padding: 3px;
}

.lb-season-btn {
    padding: 0.3rem 0.8rem;
    border: none;
    border-radius: calc(var(--lb-radius-sm) - 3px);
    background: none;
    color: var(--lb-text-2);
    font-size: 0.8rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    transition: color var(--lb-transition), background var(--lb-transition);
}

.lb-season-btn.is-active {
    background: var(--lb-accent);
    color: #fff;
}


/* ── Sub-tab bar ───────────────────────────────────────────── */
.lb-subtabs-bar {
    background: transparent;
}

.lb-subtabs-bar__inner {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    max-width: 1340px;
    margin: 0 auto;
    padding: 0.9rem 2rem 0;
}

/* Pill group container */
.lb-subtabs-bar__inner::before {
    content: '';
    display: none;
}

.lb-subtab {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.36rem 1rem;
    border-radius: 20px;
    border: 1px solid var(--lb-border-md);
    background: var(--lb-rank-bg);
    color: var(--lb-text-2);
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
    transition: color var(--lb-transition), background var(--lb-transition), border-color var(--lb-transition);
}

.lb-subtab:hover {
    color: var(--lb-text-1);
    border-color: var(--lb-border-hi);
    background: var(--lb-elevated);
}

.lb-subtab.is-active {
    background: var(--lb-accent-dim);
    border-color: rgba(69,130,240,0.3);
    color: var(--lb-accent);
}

html[data-theme='light'] .lb-subtab.is-active {
    background: rgba(37,99,235,0.08);
    border-color: rgba(37,99,235,0.22);
    color: var(--lb-accent);
}

.lb-subtab__pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.3rem;
    height: 1.3rem;
    padding: 0 0.3rem;
    background: var(--lb-rank-bg);
    border-radius: 20px;
    font-size: 0.67rem;
    font-weight: 700;
    color: var(--lb-text-3);
}

.lb-subtab.is-active .lb-subtab__pill {
    background: var(--lb-accent-dim);
    color: var(--lb-accent);
}


/* ── Main content area ─────────────────────────────────────── */
.lb-content {
    max-width: 1340px;
    margin: 0 auto;
    padding: 1.75rem 2rem 3rem;
}

.lb-section { display: none; }
.lb-section.is-active { display: block; }


/* ── Table pair grid ───────────────────────────────────────── */
.lb-tables {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
    align-items: start;
}

.lb-tables--single {
    grid-template-columns: 1fr;
    max-width: 860px;
}

@media (max-width: 900px) {
    .lb-tables { grid-template-columns: 1fr; }
}


/* ── Table card ────────────────────────────────────────────── */
.lb-tcard {
    background: var(--lb-surface);
    border: 1px solid var(--lb-border);
    border-radius: var(--lb-radius);
    overflow: hidden;
    box-shadow: var(--lb-shadow);
    transition: border-color var(--lb-transition);
}

.lb-tcard--best {
    border-top: 2px solid var(--lb-hot);
}

.lb-tcard--worst {
    border-top: 2px solid var(--lb-cold);
}

.lb-tcard--grades {
    border-top: 2px solid var(--lb-gold);
}

.lb-tcard--props {
    border-top: 2px solid var(--lb-accent);
}

/* Card header */
.lb-tcard__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.15rem 0.85rem;
    border-bottom: 1px solid var(--lb-border);
}

.lb-tcard__title-wrap {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.lb-tcard__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 8px;
    flex-shrink: 0;
}

.lb-tcard--best .lb-tcard__badge  { background: var(--lb-hot-dim); }
.lb-tcard--worst .lb-tcard__badge { background: var(--lb-cold-dim); }
.lb-tcard--grades .lb-tcard__badge{ background: rgba(245,163,27,0.12); }
.lb-tcard--props .lb-tcard__badge  { background: var(--lb-accent-dim); }

.lb-tcard__badge svg {
    width: 13px;
    height: 13px;
}

.lb-tcard--best .lb-tcard__badge svg  { color: var(--lb-hot); }
.lb-tcard--worst .lb-tcard__badge svg { color: var(--lb-cold); }
.lb-tcard--grades .lb-tcard__badge svg{ color: var(--lb-gold); }
.lb-tcard--props .lb-tcard__badge svg  { color: var(--lb-accent); }

.lb-tcard__title {
    font-size: 0.87rem;
    font-weight: 700;
    color: var(--lb-text-1);
    letter-spacing: 0.01em;
}

.lb-tcard__sub {
    font-size: 0.74rem;
    color: var(--lb-text-3);
    font-weight: 500;
}

.lb-tcard__count {
    font-size: 0.74rem;
    font-weight: 600;
    color: var(--lb-text-3);
    background: var(--lb-rank-bg);
    padding: 0.18rem 0.52rem;
    border-radius: 20px;
}


/* ── Table styles ──────────────────────────────────────────── */
.lb-table-wrap {
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--lb-border-md) transparent;
}

.lb-table-wrap::-webkit-scrollbar { height: 4px; }
.lb-table-wrap::-webkit-scrollbar-track { background: transparent; }
.lb-table-wrap::-webkit-scrollbar-thumb { background: var(--lb-border-md); border-radius: 2px; }

.lb-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.82rem;
}

.lb-table thead th {
    padding: 0.52rem 0.8rem;
    text-align: left;
    font-size: 0.67rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: var(--lb-text-3);
    background: var(--lb-surface-alt);
    border-bottom: 1px solid var(--lb-border);
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
    transition: color var(--lb-transition);
}

.lb-table thead th:hover { color: var(--lb-text-2); }

.lb-table thead th.is-sorted { color: var(--lb-text-2); }

.lb-table thead th.num,
.lb-table td.num {
    text-align: right;
}

.lb-table thead th.center,
.lb-table td.center {
    text-align: center;
}

.lb-table tbody tr {
    border-bottom: 1px solid var(--lb-border);
    transition: background var(--lb-transition);
}

.lb-table tbody tr:last-child { border-bottom: none; }

.lb-table tbody tr:hover {
    background: var(--lb-row-hover);
}

.lb-table td {
    padding: 0.62rem 0.8rem;
    color: var(--lb-text-1);
    white-space: nowrap;
    vertical-align: middle;
}

/* Rank badge */
.lb-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 8px;
    background: var(--lb-rank-bg);
    font-size: 0.74rem;
    font-weight: 700;
    color: var(--lb-text-2);
    flex-shrink: 0;
}

.lb-rank--1 { background: rgba(245,163,27,0.14); color: var(--lb-gold); }
.lb-rank--2 { background: rgba(155,168,187,0.12); color: var(--lb-silver); }
.lb-rank--3 { background: rgba(201,107,59,0.12);  color: var(--lb-bronze); }

/* Player cell */
.lb-player-cell {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    min-width: 140px;
}

.lb-player-cell__name {
    font-weight: 600;
    color: var(--lb-text-1);
    text-decoration: none;
    transition: color var(--lb-transition);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 140px;
}

.lb-player-cell__name:hover { color: var(--lb-accent); }

.lb-team-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.15rem 0.38rem;
    border-radius: var(--lb-radius-xs);
    background: var(--lb-elevated);
    border: 1px solid var(--lb-border);
    font-size: 0.65rem;
    font-weight: 700;
    color: var(--lb-text-2);
    letter-spacing: 0.04em;
    flex-shrink: 0;
    white-space: nowrap;
}

/* Stat value cells */
.lb-stat {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--lb-text-2);
    font-variant-numeric: tabular-nums;
    text-align: right;
}

.lb-stat--key {
    color: var(--lb-text-1);
    font-weight: 700;
}

/* OPS / key value color coding */
.lb-val {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.25rem;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.lb-val--elite  { color: #30D158; }
.lb-val--great  { color: #34C87A; }
.lb-val--good   { color: #60B868; }
.lb-val--avg    { color: var(--lb-text-2); }
.lb-val--below  { color: #E87543; }
.lb-val--poor   { color: #FF5E52; }

html[data-theme='light'] .lb-val--elite  { color: #15803d; }
html[data-theme='light'] .lb-val--great  { color: #166534; }
html[data-theme='light'] .lb-val--good   { color: #14532d; }
html[data-theme='light'] .lb-val--below  { color: #c2410c; }
html[data-theme='light'] .lb-val--poor   { color: #b91c1c; }

/* Hit rate bar (prop rates) */
.lb-rate-cell {
    display: flex;
    flex-direction: column;
    gap: 0.28rem;
    min-width: 90px;
}

.lb-rate-cell__top {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
}

.lb-rate-cell__pct {
    font-weight: 700;
    font-size: 0.86rem;
    font-variant-numeric: tabular-nums;
}

.lb-rate-cell__games {
    font-size: 0.68rem;
    color: var(--lb-text-3);
}

.lb-rate-bar {
    height: 3px;
    border-radius: 2px;
    background: var(--lb-border);
    overflow: hidden;
    width: 100%;
}

.lb-rate-bar__fill {
    height: 100%;
    border-radius: 2px;
    background: var(--lb-accent);
    transition: width 400ms ease;
}

.lb-rate-bar__fill--elite { background: var(--lb-hot); }
.lb-rate-bar__fill--great { background: #34C87A; }
.lb-rate-bar__fill--good  { background: var(--lb-accent); }
.lb-rate-bar__fill--avg   { background: var(--lb-text-3); }

/* Grade label chip */
.lb-grade-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.18rem 0.52rem;
    border-radius: var(--lb-radius-xs);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.lb-grade-chip--aplus  { background: rgba(48,209,88,0.15);  color: var(--lb-hot); }
.lb-grade-chip--a      { background: rgba(48,209,88,0.10);  color: var(--lb-hot); }
.lb-grade-chip--b      { background: var(--lb-accent-dim);  color: var(--lb-accent); }
.lb-grade-chip--c      { background: rgba(245,163,27,0.12); color: var(--lb-gold); }
.lb-grade-chip--d      { background: rgba(255,69,58,0.10);  color: var(--lb-cold); }
.lb-grade-chip--f      { background: rgba(255,69,58,0.15);  color: var(--lb-cold); }

html[data-theme='light'] .lb-grade-chip--aplus { background: rgba(22,163,74,0.12); color: #15803d; }
html[data-theme='light'] .lb-grade-chip--a     { background: rgba(22,163,74,0.08); color: #166534; }
html[data-theme='light'] .lb-grade-chip--b     { background: rgba(37,99,235,0.09); color: #1d4ed8; }
html[data-theme='light'] .lb-grade-chip--c     { background: rgba(180,83,9,0.09);  color: #b45309; }
html[data-theme='light'] .lb-grade-chip--d     { background: rgba(220,38,38,0.09); color: #b91c1c; }
html[data-theme='light'] .lb-grade-chip--f     { background: rgba(220,38,38,0.12); color: #991b1b; }


/* ── BvP section specifics ─────────────────────────────────── */
.lb-bvp-meta {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.73rem;
    color: var(--lb-text-3);
    margin-bottom: 1.25rem;
}

.lb-bvp-meta__dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--lb-hot);
    animation: lb-pulse 2.2s ease-in-out infinite;
    flex-shrink: 0;
}

@keyframes lb-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: 0.5; transform: scale(0.8); }
}

/* BvP matchup cell */
.lb-matchup-cell {
    display: flex;
    flex-direction: column;
    gap: 0.12rem;
}

.lb-matchup-cell__pitcher {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--lb-text-1);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 130px;
}

.lb-matchup-cell__team {
    font-size: 0.67rem;
    color: var(--lb-text-3);
}


/* ── Section header row ────────────────────────────────────── */
.lb-section-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.lb-section-header__title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--lb-text-1);
    letter-spacing: -0.01em;
}

.lb-section-header__desc {
    margin: 0.25rem 0 0;
    font-size: 0.82rem;
    color: var(--lb-text-2);
    max-width: 44rem;
    line-height: 1.55;
}


/* ── Loading skeleton ──────────────────────────────────────── */
.lb-skeleton {
    padding: 0.8rem 1.15rem;
}

.lb-skeleton__row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.62rem 0;
    border-bottom: 1px solid var(--lb-border);
}

.lb-skeleton__row:last-child { border-bottom: none; }

.lb-skel-block {
    background: var(--lb-skeleton);
    border-radius: 6px;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
}

.lb-skel-block::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        transparent 25%,
        var(--lb-skeleton-shine) 50%,
        transparent 75%
    );
    background-size: 200% 100%;
    animation: lb-shimmer 1.6s infinite;
}

@keyframes lb-shimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.lb-skel-block--rank  { width: 1.75rem; height: 1.75rem; border-radius: 8px; }
.lb-skel-block--name  { flex: 0 0 130px; height: 0.9rem; }
.lb-skel-block--chip  { width: 40px; height: 1.2rem; border-radius: var(--lb-radius-xs); }
.lb-skel-block--stat  { width: 50px; height: 0.9rem; }
.lb-skel-block--val   { width: 42px; height: 0.9rem; }
.lb-skel-block--wide  { flex: 0 0 160px; height: 0.9rem; }
.lb-skel-block--bar   { flex: 0 0 90px; height: 0.55rem; border-radius: 3px; }


/* ── Empty state ───────────────────────────────────────────── */
.lb-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3.5rem 1.5rem;
    text-align: center;
    gap: 0.5rem;
}

.lb-empty__icon {
    width: 36px;
    height: 36px;
    color: var(--lb-text-3);
    margin-bottom: 0.25rem;
    opacity: 0.6;
}

.lb-empty__title {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--lb-text-2);
    margin: 0;
}

.lb-empty__sub {
    font-size: 0.78rem;
    color: var(--lb-text-3);
    margin: 0;
    max-width: 22rem;
    line-height: 1.5;
}


/* ── Prop hit rate section header (prop tabs) ──────────────── */
.lb-prop-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 1.4rem;
}

.lb-prop-tab {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.8rem;
    border: 1px solid var(--lb-border);
    border-radius: 20px;
    background: none;
    color: var(--lb-text-2);
    font-size: 0.77rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: color var(--lb-transition), background var(--lb-transition), border-color var(--lb-transition);
    white-space: nowrap;
}

.lb-prop-tab:hover {
    color: var(--lb-text-1);
    border-color: var(--lb-border-md);
}

.lb-prop-tab.is-active {
    background: var(--lb-accent-dim);
    border-color: rgba(69,130,240,0.3);
    color: var(--lb-accent);
}

html[data-theme='light'] .lb-prop-tab.is-active {
    border-color: rgba(37,99,235,0.25);
}


/* ── Pitch type sub-tabs ───────────────────────────────────── */
.lb-pitch-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 1.4rem;
}

.lb-pitch-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.85rem;
    border: 1px solid var(--lb-border);
    border-radius: 20px;
    background: none;
    color: var(--lb-text-2);
    font-size: 0.77rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: color var(--lb-transition), background var(--lb-transition), border-color var(--lb-transition);
    white-space: nowrap;
}

.lb-pitch-tab:hover {
    color: var(--lb-text-1);
    border-color: var(--lb-border-md);
}

.lb-pitch-tab.is-active {
    background: rgba(245,163,27,0.12);
    border-color: rgba(245,163,27,0.3);
    color: var(--lb-gold);
}

html[data-theme='light'] .lb-pitch-tab.is-active {
    background: rgba(180,83,9,0.08);
    border-color: rgba(180,83,9,0.22);
    color: #b45309;
}


/* ── Min PA / Min games badge ──────────────────────────────── */
.lb-filter-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.71rem;
    font-weight: 600;
    color: var(--lb-text-3);
    background: var(--lb-rank-bg);
    border: 1px solid var(--lb-border);
    border-radius: 20px;
    padding: 0.22rem 0.6rem;
}

/* ── Min PA dropdown filter ────────────────────────────────── */
.lb-pa-filter {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-shrink: 0;
}

.lb-pa-filter__label {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--lb-text-3);
    white-space: nowrap;
}

.lb-pa-select {
    appearance: none;
    -webkit-appearance: none;
    background: var(--lb-rank-bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238B92A4' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 0.5rem center;
    border: 1px solid var(--lb-border-md);
    border-radius: 8px;
    color: var(--lb-text-2);
    font-size: 0.78rem;
    font-weight: 600;
    font-family: inherit;
    padding: 0.28rem 1.6rem 0.28rem 0.65rem;
    cursor: pointer;
    transition: border-color var(--lb-transition), background var(--lb-transition);
    outline: none;
}

.lb-pa-select:hover {
    border-color: var(--lb-border-hi);
    background-color: var(--lb-elevated);
}

.lb-pa-select:focus {
    border-color: var(--lb-accent);
}

html[data-theme='light'] .lb-pa-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23475569' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}


/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .lb-hero                { padding: 2rem 1.5rem 0; }
    .lb-controls__inner     { padding: 0 1.5rem; }
    .lb-subtabs-bar__inner  { padding: 0 1.5rem; }
    .lb-content             { padding: 1.5rem 1.5rem 3rem; }
}

@media (max-width: 640px) {
    .lb-hero                { padding: 1.5rem 1rem 0; }
    .lb-hero__title         { font-size: 1.6rem; }
    .lb-controls__inner     { flex-wrap: wrap; gap: 0.5rem; min-height: unset; padding: 0.5rem 1rem; }
    .lb-subtabs-bar__inner  { padding: 0 1rem; }
    .lb-content             { padding: 1.25rem 1rem 2.5rem; }
    .lb-cat-tab             { padding: 0.38rem 0.7rem; font-size: 0.78rem; }
    .lb-table td, .lb-table thead th { padding: 0.52rem 0.6rem; }
    .lb-player-cell__name   { max-width: 110px; }
}

@media (max-width: 480px) {
    /* On very small screens, hide some stat columns */
    .lb-table .col-hide-xs { display: none; }
}
