/* ═══════════════════════════════════════════════════════════
   Rankings module — shared between homepage and /top-100.
   Imports design tokens from site.css; adds table, filter
   controls, prospect market radar, and supporting styles.
   ═══════════════════════════════════════════════════════════ */

/* ═══ Controls row (search + filter selects + clear) ═══ */
.controls {
    display: grid;
    grid-template-columns: 1fr 160px 160px 160px auto;
    gap: 8px;
    margin-bottom: 12px;
    align-items: center;
}
.controls input[type="text"],
.controls select {
    background-color: var(--input-fill);
}

/* ═══ Combobox (type-ahead search with dropdown toggle) ═══ */
.sb-combo { display: flex; position: relative; }
.sb-combo input { flex: 1; border-radius: var(--radius) 0 0 var(--radius) !important; }
.sb-combo-clear {
    position: absolute; right: 44px; top: 50%; transform: translateY(-50%);
    width: 22px; height: 22px; display: none; align-items: center; justify-content: center;
    background: var(--muted); border: none; border-radius: 50%; cursor: pointer;
    color: var(--muted-fg); font-size: 0.7rem; line-height: 1; padding: 0;
    transition: background 0.15s, color 0.15s; z-index: 2;
}
.sb-combo-clear:hover { background: var(--destructive); color: #fff; }
.sb-combo-clear.visible { display: flex; }
.sb-combo-toggle {
    width: 36px; display: flex; align-items: center; justify-content: center;
    background-color: var(--secondary); border: 1px solid var(--border);
    border-left: none; border-radius: 0 var(--radius) var(--radius) 0; cursor: pointer;
    color: var(--muted-fg); font-size: 0.625rem; transition: all 0.15s; padding: 0;
}
.sb-combo-toggle:hover { background-color: var(--accent); color: var(--foreground); }
.sb-combo-toggle.open { background-color: var(--accent); color: var(--primary); }
.sb-autocomplete { position: relative; }
.sb-suggestions {
    position: absolute; top: 100%; left: 0; right: 0; z-index: 100;
    background-color: var(--popover); border: 1px solid var(--border);
    border-radius: 0 0 var(--radius) var(--radius); max-height: 280px; overflow-y: auto;
    display: none; box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
.sb-suggestions.visible { display: block; }
.sb-suggestion {
    padding: 7px 12px; cursor: pointer; font-size: 0.8125rem;
    color: var(--foreground); transition: background-color 0.1s;
    display: flex; justify-content: space-between; align-items: center;
}
.sb-suggestion:hover { background-color: var(--accent); }
.sb-suggestion-team { font-size: 0.6875rem; color: var(--muted-fg); font-weight: 500; }

/* ═══ Clear filters button ═══ */
.clear-filters-btn {
    font-family: var(--font-display); font-size: 0.65rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .04em;
    background: transparent; color: var(--muted-fg); border: 1px solid var(--border); border-radius: 4px;
    padding: 4px 10px; cursor: pointer; white-space: nowrap; transition: all .15s;
}
.clear-filters-btn:hover { color: var(--destructive); border-color: var(--destructive); }

/* ═══ Rankings table ═══ */
.table-wrapper {
    border: 1px solid var(--border);
    border-radius: var(--radius); overflow: hidden;
}
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
table#prospectsTable,
table#graduatedTable { width: 100%; border-collapse: collapse; min-width: 720px; }
#prospectsTable thead,
#graduatedTable thead { background-color: var(--muted); position: sticky; top: 0; z-index: 10; }
#prospectsTable th,
#graduatedTable th {
    padding: 8px 10px; text-align: left; font-weight: 600; font-size: 0.75rem; font-family: var(--font-display);
    text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted-fg);
    user-select: none; white-space: nowrap;
    border-bottom: 1px solid var(--border);
}
#prospectsTable th { cursor: pointer; }
#prospectsTable th:hover { color: var(--foreground); }
#prospectsTable th.sortable::after { content: " \2195"; opacity: 0.4; }
#prospectsTable th.sort-asc::after { content: " \2191"; opacity: 1; color: var(--primary); }
#prospectsTable th.sort-desc::after { content: " \2193"; opacity: 1; color: var(--primary); }
#prospectsTable td,
#graduatedTable td { padding: 8px 10px; border-bottom: 1px solid var(--border); font-size: 0.8125rem; font-family: var(--font-mono); }
#prospectsTable tbody tr,
#graduatedTable tbody tr { transition: background-color 0.1s; }
#prospectsTable tbody tr:nth-child(even),
#graduatedTable tbody tr:nth-child(even) { background-color: var(--stripe); }
#prospectsTable tbody tr:hover,
#graduatedTable tbody tr:hover { background-color: var(--muted); }
#prospectsTable tbody tr:last-child td,
#graduatedTable tbody tr:last-child td { border-bottom: none; }
#prospectsTable td.rank,
#graduatedTable td.rank { font-weight: 700; color: var(--primary); width: 36px; font-variant-numeric: tabular-nums; }
#prospectsTable td.player-name,
#graduatedTable td.player-name { font-family: var(--font-display); font-weight: 600; color: var(--foreground); white-space: nowrap; }
#prospectsTable a.prospect-link,
#graduatedTable a.prospect-link { color: inherit; text-decoration: none; }
#prospectsTable a.prospect-link:hover,
#graduatedTable a.prospect-link:hover { color: var(--primary); }
#prospectsTable td.position,
#graduatedTable td.position { color: var(--muted-fg); font-size: 0.75rem; }
#prospectsTable td.team,
#graduatedTable td.team { font-weight: 600; letter-spacing: 0.025em; color: var(--muted-fg); }
#prospectsTable td.price-raw,
#graduatedTable td.price-raw { color: var(--primary); font-weight: 600; font-variant-numeric: tabular-nums; }
#prospectsTable td.price-low,
#graduatedTable td.price-low { color: var(--blue, #3b82f6); font-weight: 600; font-variant-numeric: tabular-nums; }
#prospectsTable td.price-auto,
#graduatedTable td.price-auto { color: #a855f7; font-weight: 600; font-variant-numeric: tabular-nums; }
#prospectsTable td.trend,
#graduatedTable td.trend { font-weight: 500; }
#prospectsTable .trend-up,
#graduatedTable .trend-up { color: var(--success, #22c55e); }
#prospectsTable .trend-down,
#graduatedTable .trend-down { color: var(--destructive, #ef4444); }
#prospectsTable .trend-neutral,
#graduatedTable .trend-neutral { color: var(--muted-fg); }

/* ═══ Prospect badges (MLB / Graduated pills next to names) ═══ */
.prospect-badge {
    display: inline-block; padding: 1px 6px; border-radius: 4px;
    font-size: 0.55rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
    margin-left: 6px; vertical-align: middle;
}
.badge-mlb { background: rgba(232,83,14,0.15); color: #e8530e; border: 1px solid rgba(232,83,14,0.3); }
.badge-graduated { background: rgba(139,92,246,0.15); color: #a78bfa; border: 1px solid rgba(139,92,246,0.3); }

/* ═══ Buttons used inside the rankings module ═══ */
.btn-primary {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 6px 14px; background-color: var(--primary); color: var(--primary-fg, #fff);
    border: none; border-radius: var(--radius); font-weight: 500; font-size: 0.8125rem;
    cursor: pointer; transition: background-color 0.15s, transform 0.1s;
    text-decoration: none; white-space: nowrap; height: 34px;
    font-family: var(--font-display);
}
.btn-primary:hover { background-color: var(--primary-hover, #ea580c); }
.btn-primary:active { transform: scale(0.98); }
.btn-slate {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 8px 16px; background-color: var(--muted); color: var(--muted-fg);
    border: 1px solid var(--border); border-radius: var(--radius); font-weight: 500; font-size: 0.8125rem;
    cursor: pointer; transition: all 0.15s;
    text-decoration: none; white-space: nowrap; height: 36px;
    font-family: var(--font-display);
}
.btn-slate:hover { background-color: var(--border); color: var(--foreground); }
.btn-slate:active { transform: scale(0.98); }
.btn-slate svg { width: 14px; height: 14px; transition: transform 0.2s; }
.btn-slate.expanded svg { transform: rotate(180deg); }
.btn-lg { height: 40px; padding: 10px 24px; font-size: 0.8125rem; }
.shop-btn { padding: 5px 10px; height: 28px; font-size: 0.75rem; }

.no-results { text-align: center; padding: 40px 20px; color: var(--muted-fg); }
.no-results h3 { font-size: 1rem; margin-bottom: 8px; color: var(--foreground); }

.show-all-container { text-align: center; margin: 20px 0; }

/* ═══ Prospect Market Radar — interactive bubble scatter chart ═══ */
.prospect-radar-wrap {
    margin-bottom: 16px; padding: 16px; border-radius: var(--radius-lg);
    background: var(--card); border: 1px solid var(--border);
}
.prospect-radar-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 12px; gap: 10px; flex-wrap: wrap;
}
.prospect-radar-title {
    font-family: var(--font-display); font-size: 0.95rem; font-weight: 700;
    color: var(--foreground); display: flex; align-items: center; gap: 8px;
}
.prospect-radar-title svg { color: var(--primary); }
.radar-filters { display: flex; gap: 4px; flex-wrap: wrap; }
.radar-filter {
    padding: 4px 10px; font-size: 0.65rem; font-weight: 600;
    font-family: var(--font-mono); background: var(--muted);
    border: 1px solid var(--border); border-radius: var(--radius);
    color: var(--muted-fg); cursor: pointer; transition: all 0.15s;
}
.radar-filter:hover { border-color: var(--muted-fg); color: var(--foreground); }
.radar-filter.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.radar-axis-toggle {
    padding: 4px 10px; font-size: 0.6rem; font-weight: 600;
    font-family: var(--font-mono); background: var(--muted);
    border: 1px solid var(--border); border-radius: var(--radius);
    color: var(--muted-fg); cursor: pointer; transition: all 0.15s;
    margin-left: 8px;
}
.radar-axis-toggle:hover { border-color: var(--muted-fg); color: var(--foreground); }
.radar-axis-toggle.active { background: rgba(59,130,246,0.15); color: #3b82f6; border-color: #3b82f6; }
.prospect-radar-canvas-wrap {
    position: relative; width: 100%; height: 380px;
    background: var(--background); border-radius: var(--radius);
    border: 1px solid var(--border); overflow: hidden;
}
.prospect-radar-canvas-wrap canvas {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%;
}
.radar-tooltip {
    position: fixed; pointer-events: none; z-index: 9999;
    background: var(--popover); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 10px 12px;
    font-family: var(--font-mono); font-size: 0.7rem;
    color: var(--foreground); box-shadow: 0 8px 24px rgba(0,0,0,0.4);
    max-width: 220px; display: none;
}
.radar-tooltip.visible { display: block; }
.rtt-name { font-family: var(--font-display); font-weight: 700; font-size: 0.8rem; margin-bottom: 4px; }
.rtt-meta { color: var(--muted-fg); font-size: 0.6rem; margin-bottom: 6px; }
.rtt-row { display: flex; justify-content: space-between; gap: 12px; padding: 2px 0; }
.rtt-label { color: var(--muted-fg); }
.rtt-val { font-weight: 600; }
.rtt-cta {
    margin-top: 6px; padding-top: 4px; font-size: 0.55rem; font-weight: 700;
    color: var(--primary); text-transform: uppercase; letter-spacing: 0.04em;
    border-top: 1px solid var(--border); text-align: center;
}
.prospect-radar-footer {
    display: flex; align-items: center; justify-content: space-between;
    margin-top: 8px; font-size: 0.55rem; color: var(--muted-fg);
    flex-wrap: wrap; gap: 6px;
}
.radar-legend { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.radar-legend-item { display: flex; align-items: center; gap: 4px; }
.radar-legend-dot { width: 8px; height: 8px; border-radius: 50%; }
.radar-quadrant-labels {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    pointer-events: none; z-index: 1;
}
.radar-quadrant-label {
    position: absolute; font-family: var(--font-display); font-size: 0.55rem;
    font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase;
    color: var(--muted-fg); opacity: 0.35;
}

/* ═══ RESPONSIVE — Tablet/Mobile (<=768px) ═══ */
@media (max-width: 768px) {
    .controls {
        grid-template-columns: 1fr 1fr;
        gap: 6px;
    }
    .controls .sb-autocomplete { grid-column: 1 / -1; }
    .clear-filters-btn { grid-column: 1 / -1; justify-self: end; }

    .prospect-radar-wrap { padding: 10px; }
    .prospect-radar-header { flex-direction: column; align-items: flex-start; gap: 6px; }
    .prospect-radar-title { font-size: 0.8rem; }
    .radar-filters { width: 100%; }
    .radar-filter { flex: 1; text-align: center; font-size: 0.55rem; padding: 5px 4px; min-height: 28px; }
    .radar-axis-toggle { margin-left: 0; font-size: 0.55rem; padding: 5px 8px; min-height: 28px; }
    .prospect-radar-canvas-wrap { height: 300px !important; }
    .prospect-radar-footer { font-size: 0.5rem; flex-direction: column; align-items: flex-start; }
    .radar-legend { gap: 6px; }
    .radar-legend-dot { width: 6px; height: 6px; }
    .radar-legend-item { font-size: 0.5rem; }
    .radar-quadrant-label { font-size: 0.45rem !important; }
    .radar-tooltip { max-width: 180px; font-size: 0.6rem; }
    .rtt-name { font-size: 0.7rem; }
    .rtt-meta { font-size: 0.5rem; }
    .rtt-row { font-size: 0.6rem; }
}
