/* JBL Universe Front Office — Custom Styles */

:root {
    --bg-primary: #ffffff;
    --bg-secondary: #f8fafc;
    --bg-card: #ffffff;
    --bg-card-hover: #f1f5f9;
    --bg-table-row: #ffffff;
    --bg-table-row-alt: #f8fafc;
    --bg-table-hover: #f1f5f9;
    --border-color: #e2e8f0;
    --text-primary: #334155;
    --text-secondary: #64748b;
    --text-muted: #94a3b8;
    --accent-gold: #c2410c;
    --accent-orange: #ea580c;
    --accent-blue: #2563eb;
    --green: #16a34a;
    --green-bg: rgba(22, 163, 74, 0.08);
    --amber: #d97706;
    --amber-bg: rgba(245, 158, 11, 0.08);
    --red: #dc2626;
    --red-bg: rgba(239, 68, 68, 0.08);
}

body {
    background-color: var(--bg-primary);
    color: var(--text-primary);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* Navigation */
.nav-brand {
    font-weight: 700;
    letter-spacing: -0.02em;
}

.nav-link {
    transition: color 0.15s, border-color 0.15s;
    border-bottom: 2px solid transparent;
    padding-bottom: 2px;
}
.nav-link:hover, .nav-link.active {
    color: var(--accent-gold);
    border-bottom-color: var(--accent-gold);
}

/* Cards */
.card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 1.25rem;
}
.card-hover:hover {
    background: var(--bg-card-hover);
    transition: background 0.2s;
}

/* Badge system */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem 0.5rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.badge-clean { background: var(--green-bg); color: var(--green); }
.badge-borderline { background: var(--amber-bg); color: var(--amber); }
.badge-fail { background: var(--red-bg); color: var(--red); }
.badge-unknown { background: rgba(100,116,139,0.2); color: var(--text-muted); }
.badge-auto-reject { background: var(--red-bg); color: var(--red); }

/* Data tables (TB board style) */
.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8125rem;
    line-height: 1.4;
}
.data-table thead th {
    background: var(--bg-primary);
    color: var(--text-secondary);
    font-weight: 600;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.625rem 0.75rem;
    border-bottom: 2px solid var(--border-color);
    position: sticky;
    top: 0;
    z-index: 10;
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}
.data-table thead th:hover {
    color: var(--accent-gold);
}
.data-table thead th .sort-arrow {
    margin-left: 0.25rem;
    opacity: 0.4;
}
.data-table thead th.sort-asc .sort-arrow,
.data-table thead th.sort-desc .sort-arrow {
    opacity: 1;
    color: var(--accent-gold);
}
.data-table tbody tr {
    border-bottom: 1px solid var(--border-color);
    transition: background 0.1s;
}
.data-table tbody tr:nth-child(even) {
    background: var(--bg-table-row-alt);
}
.data-table tbody tr:hover {
    background: var(--bg-table-hover);
    cursor: pointer;
}
.data-table .col-name {
    min-width: 160px;
    white-space: nowrap;
}
.data-table td {
    padding: 0.5rem 0.75rem;
    white-space: nowrap;
}
.data-table td.text-wrap {
    white-space: normal;
}

/* Rating bars */
.rating-bar-container {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.rating-bar {
    height: 0.5rem;
    border-radius: 0.25rem;
    background: var(--border-color);
    flex: 1;
    max-width: 100px;
    overflow: hidden;
}
.rating-bar-fill {
    height: 100%;
    border-radius: 0.25rem;
    transition: width 0.3s;
}
.rating-bar-fill.elite { background: var(--green); }
.rating-bar-fill.good { background: var(--accent-blue); }
.rating-bar-fill.avg { background: var(--amber); }
.rating-bar-fill.poor { background: var(--red); }

.rating-value {
    font-weight: 600;
    font-size: 0.8125rem;
    min-width: 1.5rem;
    text-align: right;
}

/* Filter bar */
.filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    padding: 1rem;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    margin-bottom: 1rem;
}
.filter-bar input,
.filter-bar select {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    padding: 0.375rem 0.75rem;
    border-radius: 0.375rem;
    font-size: 0.8125rem;
}
.filter-bar input:focus,
.filter-bar select:focus {
    outline: none;
    border-color: var(--accent-gold);
    box-shadow: 0 0 0 1px var(--accent-gold);
}
.filter-bar label {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    display: block;
    margin-bottom: 0.25rem;
}

/* Pagination */
.pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 0;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}
.pagination button {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    padding: 0.375rem 0.75rem;
    border-radius: 0.375rem;
    cursor: pointer;
    font-size: 0.8125rem;
}
.pagination button:hover:not(:disabled) {
    background: var(--bg-card-hover);
    border-color: var(--accent-gold);
}
.pagination button:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* Hero card (HoopsHype style) */
.hero-card {
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
    border: 1px solid var(--border-color);
    border-left: 3px solid var(--accent-gold);
    border-radius: 0.75rem;
    padding: 2rem;
}
.hero-card h1 {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}
.hero-stat {
    text-align: center;
}
.hero-stat .value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--accent-gold);
}
.hero-stat .label {
    font-size: 0.6875rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

/* Tabs */
.tab-list {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--border-color);
}
.tab-btn {
    padding: 0.625rem 1.25rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text-secondary);
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    background: none;
    border-left: none;
    border-right: none;
    border-top: none;
}
.tab-btn:hover {
    color: var(--text-primary);
}
.tab-btn.active {
    color: var(--accent-gold);
    border-bottom-color: var(--accent-gold);
}

/* Accordion (reports) */
.accordion-item {
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    margin-bottom: 0.5rem;
    overflow: hidden;
}
.accordion-header {
    background: var(--bg-secondary);
    padding: 0.75rem 1rem;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: 600;
    font-size: 0.875rem;
}
.accordion-header:hover {
    background: var(--bg-card-hover);
}
.accordion-body {
    padding: 1rem;
    font-size: 0.8125rem;
    line-height: 1.6;
    white-space: pre-wrap;
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    max-height: 600px;
    overflow-y: auto;
}

/* Knowledge docs rendered as HTML inside accordions */
.prose-knowledge {
    white-space: normal;
    font-family: 'Inter', sans-serif;
}
.prose-knowledge h1, .prose-knowledge h2, .prose-knowledge h3 {
    color: var(--text-primary);
    margin-top: 1rem;
    margin-bottom: 0.5rem;
    font-weight: 600;
}
.prose-knowledge h1 { font-size: 1.25rem; }
.prose-knowledge h2 { font-size: 1.1rem; }
.prose-knowledge h3 { font-size: 0.95rem; }
.prose-knowledge p { margin-bottom: 0.5rem; }
.prose-knowledge ul, .prose-knowledge ol { padding-left: 1.5rem; margin-bottom: 0.5rem; }
.prose-knowledge li { margin-bottom: 0.25rem; }
.prose-knowledge table { border-collapse: collapse; margin: 0.5rem 0; width: 100%; }
.prose-knowledge th, .prose-knowledge td {
    border: 1px solid var(--border-color);
    padding: 0.35rem 0.5rem;
    font-size: 0.75rem;
}
.prose-knowledge th { background: var(--bg-secondary); font-weight: 600; }
.prose-knowledge code {
    background: var(--bg-primary);
    padding: 0.1rem 0.3rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-family: 'JetBrains Mono', monospace;
}
.prose-knowledge pre {
    background: var(--bg-primary);
    padding: 0.75rem;
    border-radius: 0.375rem;
    overflow-x: auto;
    margin: 0.5rem 0;
}
.prose-knowledge pre code { background: none; padding: 0; }
.prose-knowledge strong { color: var(--text-primary); }
.prose-knowledge a { color: var(--accent-gold); text-decoration: underline; }

/* Knowledge base */
.kb-sidebar {
    min-width: 220px;
}
.kb-sidebar a {
    display: block;
    padding: 0.5rem 0.75rem;
    border-radius: 0.375rem;
    color: var(--text-secondary);
    font-size: 0.8125rem;
    transition: all 0.15s;
}
.kb-sidebar a:hover, .kb-sidebar a.active {
    background: var(--bg-card-hover);
    color: var(--text-primary);
}

/* Recruiting pipeline */
.pipeline-phase {
    background: var(--accent-gold);
    color: var(--bg-primary);
    font-weight: 700;
    padding: 0.5rem 1rem;
    border-radius: 0.375rem;
    display: inline-block;
    font-size: 0.875rem;
}

/* Dashboard summary cards */
.summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

/* Responsive */
@media (max-width: 768px) {
    .data-table {
        font-size: 0.75rem;
    }
    .data-table td, .data-table thead th {
        padding: 0.375rem 0.5rem;
    }
    .filter-bar {
        flex-direction: column;
    }
    .hero-card {
        padding: 1rem;
    }
    .hero-card h1 {
        font-size: 1.5rem;
    }
}

/* Scrollable table wrapper */
.table-wrapper {
    overflow-x: auto;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
}
.table-top-scroll {
    overflow-x: auto;
    overflow-y: hidden;
    height: 12px;
    margin-bottom: -1px;
}
.table-top-scroll-inner {
    height: 1px;
}

/* Utility */
.text-gold { color: var(--accent-gold); }
.text-green { color: var(--green); }
.text-red { color: var(--red); }
.text-amber { color: var(--amber); }
.text-muted { color: var(--text-muted); }
.text-secondary { color: var(--text-secondary); }
.mono { font-family: 'JetBrains Mono', 'Fira Code', monospace; }

/* ============================================================
   CTG-Style Tables & Percentile Shading
   ============================================================ */

/* CTG-style stat table */
.ctg-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}
.ctg-table thead th {
    background: #f9fafb;
    color: #9ca3af;
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.625rem 1rem;
    border-bottom: 2px solid #e5e7eb;
    text-align: left;
}
.ctg-table thead th:nth-child(2),
.ctg-table thead th:nth-child(3),
.ctg-table thead th:nth-child(4) {
    text-align: center;
}
.ctg-table td.ctg-stat-val {
    text-align: center;
}
.ctg-table tbody tr {
    border-bottom: 1px solid #f3f4f6;
}
.ctg-table tbody tr:hover {
    background: #f9fafb;
}
.ctg-section-row {
    background: #f3f4f6 !important;
}
.ctg-section-row td {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #9ca3af;
    padding: 0.5rem 1rem;
}
.ctg-stat-name {
    padding: 0.5rem 1rem;
    color: #374151;
    font-weight: 500;
}
.ctg-stat-val {
    padding: 0.5rem 1rem;
    text-align: right;
    font-weight: 700;
    color: #111827;
    font-family: 'JetBrains Mono', monospace;
}
.ctg-stat-pctl {
    padding: 0.5rem 1rem;
    text-align: right;
    width: 5rem;
}

/* Row shading by percentile tier (10 deciles) */
.ctg-table tr.pctl-row-1,  .pctl-row.pctl-row-1  { background: color-mix(in srgb, #1a4d8f 8%, white); }
.ctg-table tr.pctl-row-2,  .pctl-row.pctl-row-2  { background: color-mix(in srgb, #2b6cb5 7%, white); }
.ctg-table tr.pctl-row-3,  .pctl-row.pctl-row-3  { background: color-mix(in srgb, #4a90d9 6%, white); }
.ctg-table tr.pctl-row-4,  .pctl-row.pctl-row-4  { background: color-mix(in srgb, #7ab3ef 5%, white); }
.ctg-table tr.pctl-row-5,  .pctl-row.pctl-row-5  { background: transparent; }
.ctg-table tr.pctl-row-6,  .pctl-row.pctl-row-6  { background: transparent; }
.ctg-table tr.pctl-row-7,  .pctl-row.pctl-row-7  { background: color-mix(in srgb, #e8a44c 5%, white); }
.ctg-table tr.pctl-row-8,  .pctl-row.pctl-row-8  { background: color-mix(in srgb, #e58333 6%, white); }
.ctg-table tr.pctl-row-9,  .pctl-row.pctl-row-9  { background: color-mix(in srgb, #d9621f 7%, white); }
.ctg-table tr.pctl-row-10, .pctl-row.pctl-row-10 { background: color-mix(in srgb, #c43e17 8%, white); }
.ctg-table tr[class*="pctl-row-"]:hover,
.pctl-row[class*="pctl-row-"]:hover { filter: brightness(0.97); }

/* Percentile color tiers (CTG-style: blue→gray→orange, 10 deciles) */
.pctl-1  { --pctl-color: #1a4d8f; } /* 1-10:   deep blue */
.pctl-2  { --pctl-color: #2b6cb5; } /* 11-20:  dark blue */
.pctl-3  { --pctl-color: #4a90d9; } /* 21-30:  medium blue */
.pctl-4  { --pctl-color: #7ab3ef; } /* 31-40:  light blue */
.pctl-5  { --pctl-color: #9ca3af; } /* 41-50:  cool gray */
.pctl-6  { --pctl-color: #9ca3af; } /* 51-60:  warm gray */
.pctl-7  { --pctl-color: #e8a44c; } /* 61-70:  light orange */
.pctl-8  { --pctl-color: #e58333; } /* 71-80:  medium orange */
.pctl-9  { --pctl-color: #d9621f; } /* 81-90:  dark orange */
.pctl-10 { --pctl-color: #c43e17; } /* 91-100: deep orange */

/* Percentile badge (colored number) */
.pctl-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.9375rem;
    font-weight: 700;
    font-family: 'JetBrains Mono', monospace;
    background: color-mix(in srgb, var(--pctl-color) 8%, transparent);
    color: var(--pctl-color);
}

/* Percentile bar row */
.pctl-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.375rem 0.5rem;
    border-bottom: 1px solid rgba(148,163,184,0.15);
    border-radius: 0.25rem;
}
.pctl-row:last-child { border-bottom: none; }

.pctl-label {
    width: 11rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    text-align: right;
    flex-shrink: 0;
}

.pctl-bar-track {
    flex: 1;
    height: 1.25rem;
    background: rgba(148,163,184,0.15);
    border-radius: 0.25rem;
    overflow: hidden;
    position: relative;
}

.pctl-bar-fill {
    height: 100%;
    border-radius: 0.25rem;
    background: var(--pctl-color);
    opacity: 0.85;
    transition: width 0.4s ease;
}

.pctl-value {
    min-width: 1.5rem;
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--text-primary);
    text-align: right;
    font-family: 'JetBrains Mono', monospace;
}

.pctl-rank {
    min-width: 2.5rem;
    text-align: right;
}

/* Category header in ratings */
.pctl-category {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    padding: 0.75rem 0 0.25rem;
    margin-top: 0.25rem;
    border-bottom: 1px solid var(--border-color);
}
.pctl-category:first-child { margin-top: 0; padding-top: 0; }

/* Stat cards (overview grid) */
.stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    gap: 0.75rem;
}
.stat-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 0.75rem;
    text-align: center;
}
.stat-card .stat-value {
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--text-primary);
    font-family: 'JetBrains Mono', monospace;
    line-height: 1.2;
}
.stat-card .stat-label {
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
    margin-bottom: 0.25rem;
}
.stat-card .pctl-badge {
    margin-top: 0.375rem;
}

/* Tendency bars */
.tendency-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.625rem 0;
    border-bottom: 1px solid rgba(148,163,184,0.15);
}
.tendency-row:last-child { border-bottom: none; }

.tendency-label {
    width: 11rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    text-align: right;
    flex-shrink: 0;
}

.tendency-track {
    flex: 1;
    height: 1.5rem;
    background: rgba(148,163,184,0.15);
    border-radius: 0.25rem;
    overflow: hidden;
    display: flex;
    position: relative;
}

.tendency-left {
    height: 100%;
    background: #3b82f6;
    opacity: 0.7;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.6875rem;
    font-weight: 600;
    color: white;
    min-width: 2rem;
}

.tendency-right {
    height: 100%;
    background: #8b5cf6;
    opacity: 0.7;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.6875rem;
    font-weight: 600;
    color: white;
}

.tendency-values {
    min-width: 4rem;
    font-size: 0.8125rem;
    font-family: 'JetBrains Mono', monospace;
    color: var(--text-secondary);
    text-align: right;
}

/* Position badge */
.pos-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    background: rgba(194,65,12,0.08);
    color: var(--accent-gold);
}

/* ============================================================
   Player Card Grid (CraftedNBA-inspired)
   ============================================================ */
.player-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 180px));
    gap: 0.75rem;
}
@media (max-width: 1024px) {
    .player-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
    .player-grid { grid-template-columns: repeat(2, 1fr); gap: 0.75rem; }
}

.player-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.625rem;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
    display: block;
}
.player-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    border-color: var(--green);
}

.player-card-img {
    aspect-ratio: 1 / 1;
    max-height: 160px;
    background: var(--bg-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.player-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.player-card-initial {
    font-size: 3rem;
    font-weight: 700;
    color: var(--text-muted);
    opacity: 0.4;
    user-select: none;
}

.player-card-info {
    padding: 0.5rem 0.625rem;
    background: linear-gradient(135deg, rgba(22,163,74,0.04) 0%, transparent 100%);
}
.player-card-name {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.player-card-meta {
    font-size: 0.6875rem;
    color: var(--text-muted);
    margin-top: 0.125rem;
}

/* ============================================================
   Lineup Cards (CraftedNBA-inspired)
   ============================================================ */

/* Hero header */
.lineup-hero {
    text-align: center;
    padding: 2rem 1rem 1.5rem;
}
.lineup-hero-title {
    font-size: 1.75rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-primary);
}
.lineup-hero-sub {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}
.lineup-hero-updated {
    font-size: 0.6875rem;
    color: var(--text-muted);
    margin-top: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Pill tabs */
.lineup-tabs {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}
.lineup-tab {
    padding: 0.5rem 1.25rem;
    border-radius: 9999px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    cursor: pointer;
    transition: all 0.15s;
}
.lineup-tab:hover:not(:disabled) {
    color: var(--text-primary);
    border-color: var(--accent-gold);
}
.lineup-tab.active {
    background: var(--accent-gold);
    color: var(--bg-primary);
    border-color: var(--accent-gold);
}
.lineup-tab:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

/* Filters bar */
.lineup-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    padding: 0.75rem 1rem;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    margin-bottom: 1.25rem;
    align-items: flex-end;
}
.lineup-filter-group {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.lineup-filter-group label {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
    font-weight: 600;
}
.lineup-filter-group select,
.lineup-filter-group input {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    padding: 0.375rem 0.625rem;
    border-radius: 0.375rem;
    font-size: 0.8125rem;
    min-width: 120px;
}
.lineup-filter-group select:focus,
.lineup-filter-group input:focus {
    outline: none;
    border-color: var(--accent-gold);
}

/* Section label */
.lineup-section-label {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: 1rem;
    padding-left: 0.25rem;
}

/* Card grid — 2 columns */
.lineup-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}
@media (max-width: 768px) {
    .lineup-grid {
        grid-template-columns: 1fr;
    }
}

/* Individual lineup card */
.lu-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.625rem;
    overflow: hidden;
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.lu-card:hover {
    border-color: rgba(22, 163, 74, 0.4);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

/* Top accent bar */
.lu-card-top {
    height: 3px;
    background: var(--accent-gold);
}
.lu-card-top.lu-negative {
    background: var(--red);
}

/* Card header: rank + team + net rating */
.lu-card-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem 0.5rem;
}
.lu-rank {
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: linear-gradient(135deg, #c9a227, #e8c547);
    color: #1a1a1a;
    font-size: 0.8125rem;
    font-weight: 800;
    flex-shrink: 0;
}
.lu-team-info {
    flex: 1;
    min-width: 0;
}
.lu-team-abbrev {
    font-size: 0.875rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    color: var(--text-primary);
}
.lu-team-full {
    font-size: 0.625rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.lu-net-rtg {
    font-size: 1.5rem;
    font-weight: 800;
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    flex-shrink: 0;
}
.lu-positive { color: var(--green); }
.lu-negative { color: var(--red); }

/* Headshot row */
.lu-headshots {
    display: flex;
    justify-content: center;
    gap: 0.375rem;
    padding: 0.25rem 1rem;
}
.lu-headshot-link {
    text-decoration: none;
}
.lu-headshot {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border-color);
    background: var(--bg-primary);
    transition: border-color 0.15s;
}
.lu-headshot-link:hover .lu-headshot {
    border-color: var(--accent-gold);
}
.lu-headshot-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.6875rem;
    font-weight: 700;
    color: var(--text-muted);
}

/* Player names row */
.lu-names {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0.25rem;
    padding: 0.375rem 0.75rem;
    font-size: 0.6875rem;
}
.lu-player-name {
    color: var(--text-secondary);
    text-decoration: none;
    white-space: nowrap;
    transition: color 0.15s;
}
.lu-player-name:hover {
    color: var(--accent-gold);
}
.lu-name-dot {
    color: var(--text-muted);
    font-size: 0.5rem;
}

/* Minutes row with expand chevron */
.lu-minutes-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    border-top: 1px solid var(--border-color);
    font-size: 0.75rem;
}
.lu-minutes-label {
    color: var(--text-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 0.625rem;
}
.lu-minutes-value {
    color: var(--text-primary);
    font-weight: 700;
    font-family: 'JetBrains Mono', monospace;
}
.lu-expand-btn {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 0.125rem;
    display: flex;
    align-items: center;
    transition: transform 0.2s, color 0.15s;
}
.lu-expand-btn:hover {
    color: var(--accent-gold);
}
.lu-expand-btn.lu-expanded {
    transform: rotate(180deg);
}

/* Expanded detail section */
.lu-details {
    border-top: 1px solid var(--border-color);
    padding: 0.75rem 1rem;
    background: rgba(0, 0, 0, 0.02);
}
.lu-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.5rem;
}
.lu-stat-item {
    text-align: center;
}
.lu-stat-label {
    font-size: 0.5625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
    margin-bottom: 0.125rem;
}
.lu-stat-value {
    font-size: 0.9375rem;
    font-weight: 700;
    font-family: 'JetBrains Mono', monospace;
    color: var(--text-primary);
}

/* Opponent stats row */
.lu-opp-row {
    display: flex;
    justify-content: center;
    gap: 1rem;
    margin-top: 0.625rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--border-color);
    font-size: 0.6875rem;
    color: var(--text-muted);
}
.lu-opp-label {
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
}


/* ============================================================
   Leaderboard Index & Detail (CraftedNBA-inspired)
   ============================================================ */

/* Page wrapper */
.lb-page {
    border-radius: 0.75rem;
    padding: 0 1.5rem 2rem;
    margin: -0.25rem -0.25rem 0;
}

.lb-page-title {
    font-family: 'Inter', sans-serif;
    font-size: 2rem;
    font-weight: 800;
    color: var(--text-primary);
    letter-spacing: -0.02em;
}
.lb-page-sub {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

/* Underline-style category tabs */
.lb-tab-bar {
    display: flex;
    justify-content: center;
    gap: 2rem;
    border-bottom: 2px solid var(--border-color);
    margin-bottom: 1.5rem;
    padding-bottom: 0;
}
.lb-tab {
    background: none;
    border: none;
    padding: 0.75rem 0.25rem;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--text-muted);
    cursor: pointer;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    transition: color 0.15s, border-color 0.15s;
}
.lb-tab:hover {
    color: var(--text-primary);
}
.lb-tab-active {
    color: var(--accent-gold);
    border-bottom-color: var(--accent-gold);
}

/* Card grid — 3 columns */
.lb-card-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.875rem;
}
@media (max-width: 1024px) {
    .lb-card-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .lb-card-grid { grid-template-columns: 1fr; }
}

/* Individual card */
.lb-card {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 1rem 1.125rem;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.625rem;
    text-decoration: none;
    color: inherit;
    transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
}
.lb-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
    border-color: var(--accent-gold);
}

/* Icon circle */
.lb-card-icon-wrap {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(194,65,12,0.08) 0%, rgba(194,65,12,0.15) 100%);
    border-radius: 0.5rem;
    color: var(--accent-gold);
}
.lb-card-icon-wrap svg {
    width: 22px;
    height: 22px;
}

/* Card text */
.lb-card-body {
    flex: 1;
    min-width: 0;
}
.lb-card-cat {
    display: block;
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--accent-gold);
    line-height: 1;
    margin-bottom: 0.25rem;
}
.lb-card-title {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.3;
    margin: 0;
}
.lb-card-desc {
    font-size: 0.75rem;
    color: var(--text-muted);
    line-height: 1.3;
    margin: 0.125rem 0 0;
}

/* Chevron arrow */
.lb-card-arrow {
    flex-shrink: 0;
    color: var(--text-muted);
    transition: color 0.15s, transform 0.15s;
}
.lb-card:hover .lb-card-arrow {
    color: var(--accent-gold);
    transform: translateX(2px);
}

/* Hero icon on detail page */
.lb-hero-icon {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    color: var(--accent-gold);
}
.lb-hero-icon svg {
    width: 100%;
    height: 100%;
}

/* ============================================================
   SIUE Roster Analysis — Comparison Bars, Depth Chart, Fit %
   ============================================================ */

/* Comparison bars (SIUE vs OVC) */
.comp-category {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    padding: 0.75rem 0 0.25rem;
    margin-top: 0.25rem;
    border-bottom: 1px solid var(--border-color);
}
.comp-category:first-child { margin-top: 0; padding-top: 0; }

.comp-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.25rem 0;
}
.comp-label {
    width: 9rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-align: right;
    flex-shrink: 0;
}
.comp-bars {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.comp-bar-track {
    height: 0.5rem;
    border-radius: 0.25rem;
    background: rgba(148,163,184,0.1);
    overflow: hidden;
}
.comp-bar-fill {
    height: 100%;
    border-radius: 0.25rem;
    transition: width 0.3s;
}
.comp-bar-fill.comp-compare {
    background: rgba(148,163,184,0.4);
}
.comp-values {
    min-width: 4.5rem;
    display: flex;
    align-items: center;
    gap: 0.375rem;
    flex-shrink: 0;
}
.comp-val {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--text-primary);
    font-family: 'JetBrains Mono', monospace;
    min-width: 1.5rem;
    text-align: right;
}
.comp-delta {
    font-size: 0.6875rem;
    font-weight: 600;
    font-family: 'JetBrains Mono', monospace;
}

/* Depth chart grid */
.depth-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.75rem;
}
@media (max-width: 768px) {
    .depth-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 480px) {
    .depth-grid {
        grid-template-columns: 1fr;
    }
}

.depth-slot {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 0.75rem;
}
.depth-slot-header {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--accent-gold);
    margin-bottom: 0.5rem;
    padding-bottom: 0.375rem;
    border-bottom: 1px solid var(--border-color);
}

.depth-player {
    padding: 0.375rem 0;
    border-bottom: 1px solid rgba(148,163,184,0.1);
}
.depth-player:last-child { border-bottom: none; }
.depth-player.depth-starter {
    font-weight: 600;
}
.depth-player.depth-graduating {
    border-left: 3px solid var(--amber);
    padding-left: 0.5rem;
}
.depth-player-name {
    font-size: 0.8125rem;
    color: var(--text-primary);
}
.depth-player-meta {
    font-size: 0.6875rem;
    color: var(--text-muted);
}

/* Fit % badge */
.fit-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
    font-weight: 800;
    font-family: 'JetBrains Mono', monospace;
    min-width: 4rem;
    padding: 0.25rem 0.75rem;
    border-radius: 0.5rem;
}
.fit-badge.fit-good { background: var(--green-bg); color: var(--green); }
.fit-badge.fit-ok { background: var(--amber-bg); color: var(--amber); }
.fit-badge.fit-poor { background: var(--red-bg); color: var(--red); }

/* Ideal profile threshold table */
.threshold-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8125rem;
}
.threshold-table th {
    background: var(--bg-primary);
    color: var(--text-secondary);
    font-weight: 600;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.5rem 0.75rem;
    border-bottom: 2px solid var(--border-color);
    text-align: center;
}
.threshold-table th:first-child { text-align: left; }
.threshold-table td {
    padding: 0.375rem 0.75rem;
    text-align: center;
    border-bottom: 1px solid var(--border-color);
    font-family: 'JetBrains Mono', monospace;
    font-weight: 600;
}
.threshold-table td:first-child {
    text-align: left;
    font-family: 'Inter', sans-serif;
    color: var(--text-secondary);
}
.threshold-status {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem 0.5rem;
    border-radius: 9999px;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
}
.threshold-status.elite { background: var(--green-bg); color: var(--green); }
.threshold-status.meets { background: rgba(59,130,246,0.15); color: var(--accent-blue); }
.threshold-status.below { background: var(--red-bg); color: var(--red); }

/* Ridge score bars */
.ridge-bar-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.25rem 0;
}
.ridge-bar-name {
    width: 10rem;
    font-size: 0.8125rem;
    color: var(--text-primary);
    text-align: right;
    flex-shrink: 0;
}
.ridge-bar-track {
    flex: 1;
    height: 1.25rem;
    background: rgba(148,163,184,0.1);
    border-radius: 0.25rem;
    overflow: hidden;
}
.ridge-bar-fill {
    height: 100%;
    border-radius: 0.25rem;
    background: var(--green);
    transition: width 0.3s;
}
.ridge-bar-fill.graduating {
    background: var(--amber);
}
.ridge-bar-value {
    min-width: 3rem;
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--text-primary);
    font-family: 'JetBrains Mono', monospace;
    text-align: right;
}

/* CJBL player page badges */
.graduating-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem 0.5rem;
    border-radius: 9999px;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background: var(--amber-bg);
    color: var(--amber);
}
.strength-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.625rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    background: rgba(34, 197, 94, 0.1);
    color: #16a34a;
}
.weakness-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.625rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

/* ============================================================
   Prospect Grid (CraftedNBA-inspired)
   ============================================================ */

.prospect-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.75rem;
}
@media (max-width: 1280px) {
    .prospect-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 1024px) {
    .prospect-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
    .prospect-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .prospect-grid { grid-template-columns: 1fr; }
}

.prospect-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.625rem;
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
    position: relative;
    display: flex;
    flex-direction: column;
}
.prospect-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    border-color: var(--accent-gold);
}

/* Tier accent bar */
.prospect-card-tier {
    height: 3px;
}
.prospect-card-tier.tier-1 { background: #c43e17; }
.prospect-card-tier.tier-2 { background: #d9621f; }
.prospect-card-tier.tier-3 { background: #e8a44c; }
.prospect-card-tier.tier-4 { background: #9ca3af; }
.prospect-card-tier.tier-5 { background: #4a5568; }

/* Rank badge */
.prospect-card-rank {
    position: absolute;
    top: 8px;
    left: 8px;
    background: rgba(0,0,0,0.7);
    color: #fff;
    font-size: 0.6875rem;
    font-weight: 700;
    padding: 0.125rem 0.375rem;
    border-radius: 0.25rem;
    z-index: 2;
}

/* Photo area */
.prospect-card-img {
    aspect-ratio: 1 / 1;
    max-height: 180px;
    background: var(--bg-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.prospect-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.prospect-card-initial {
    font-size: 3rem;
    font-weight: 700;
    color: var(--text-muted);
    opacity: 0.4;
    user-select: none;
}

/* Info section */
.prospect-card-info {
    padding: 0.625rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.prospect-card-name {
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.prospect-card-meta {
    font-size: 0.6875rem;
    color: var(--text-muted);
    margin-top: 0.125rem;
}
.prospect-card-tier-label {
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 0.25rem;
}
.tier-text-1 { color: #c43e17; }
.tier-text-2 { color: #d9621f; }
.tier-text-3 { color: #e8a44c; }
.tier-text-4 { color: #9ca3af; }
.tier-text-5 { color: #4a5568; }

/* Overall score */
.prospect-card-score-row {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 0.375rem;
}
.prospect-card-score {
    font-size: 1.75rem;
    font-weight: 800;
    font-family: 'JetBrains Mono', monospace;
    line-height: 1;
}

/* Score color classes */
.score-elite { color: #c43e17; }
.score-good { color: #d9621f; }
.score-avg { color: #e8a44c; }
.score-poor { color: #7ab3ef; }

/* Score circles (modal) */
.prospect-score-circle {
    text-align: center;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    border: 3px solid var(--border-color);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.prospect-score-circle.score-elite { border-color: #c43e17; }
.prospect-score-circle.score-good { border-color: #d9621f; }
.prospect-score-circle.score-avg { border-color: #e8a44c; }
.prospect-score-circle.score-poor { border-color: #7ab3ef; }
.prospect-score-circle.score-offense { border-color: var(--green); }
.prospect-score-circle.score-defense { border-color: var(--red); }
.prospect-score-val {
    font-size: 1.375rem;
    font-weight: 800;
    font-family: 'JetBrains Mono', monospace;
    color: var(--text-primary);
    line-height: 1.1;
}
.prospect-score-lbl {
    font-size: 0.5rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
}

/* Rank comparison */
.prospect-card-rank-cmp {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 0.25rem;
}

/* Off/Def split bar */
.prospect-card-splits {
    margin-top: 0.375rem;
}
.prospect-split-bar {
    height: 4px;
    background: var(--red);
    border-radius: 2px;
    overflow: hidden;
}
.prospect-split-off {
    height: 100%;
    background: var(--green);
    border-radius: 2px 0 0 2px;
}
.prospect-split-labels {
    display: flex;
    justify-content: space-between;
    font-size: 0.5625rem;
    font-weight: 700;
    margin-top: 0.125rem;
}

/* Denver Fit badge on grid cards */
.prospect-card-dfit {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    margin-top: 0.375rem;
    font-size: 0.75rem;
}
.prospect-dfit-label {
    font-size: 0.5625rem;
    font-weight: 700;
    color: #64748b;
    letter-spacing: 0.05em;
}

/* Tier badge (modal) */
.prospect-tier-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem 0.5rem;
    border-radius: 9999px;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.tier-bg-1 { background: rgba(196,62,23,0.15); color: #c43e17; }
.tier-bg-2 { background: rgba(217,98,31,0.15); color: #d9621f; }
.tier-bg-3 { background: rgba(232,164,76,0.15); color: #e8a44c; }
.tier-bg-4 { background: rgba(156,163,175,0.15); color: #9ca3af; }
.tier-bg-5 { background: rgba(74,85,104,0.15); color: #4a5568; }

/* Modal overlay */
.prospect-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.4);
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}
.prospect-modal {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 0.75rem;
    padding: 1.5rem;
    max-width: 640px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
}

/* Similar player mini-cards */
.similar-player-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 0.5rem;
    text-align: center;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.15s;
}
.similar-player-card:hover {
    border-color: var(--accent-gold);
}
.similar-player-img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    margin: 0 auto 0.375rem;
    background: var(--bg-secondary);
}
.similar-player-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-muted);
}
.similar-player-name {
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.similar-player-meta {
    font-size: 0.5625rem;
    color: var(--text-muted);
}

/* Rank sparkline (inline SVG) */
.rank-sparkline {
    display: inline-block;
}
.rank-sparkline svg {
    vertical-align: middle;
}

/* ============================================================
   SIUE Roster Cards (CraftedNBA-style)
   ============================================================ */
.roster-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
}
@media (max-width: 768px) {
    .roster-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .roster-grid { grid-template-columns: 1fr; }
}
.roster-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.625rem;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
    display: block;
    position: relative;
}
.roster-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    border-color: var(--accent-gold);
}
.roster-card-img {
    aspect-ratio: 1 / 1;
    max-height: 160px;
    background: var(--bg-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.roster-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.roster-card-initial {
    font-size: 3rem;
    font-weight: 700;
    color: var(--text-muted);
    opacity: 0.4;
    user-select: none;
}
.roster-card-info {
    padding: 0.625rem;
    background: linear-gradient(135deg, rgba(220,38,38,0.03) 0%, transparent 100%);
}
.roster-card-name {
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.roster-card-meta {
    font-size: 0.6875rem;
    color: var(--text-muted);
    margin-top: 0.125rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.roster-card-archetype {
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}
.roster-card-scores {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    margin-top: 0.375rem;
    padding-top: 0.375rem;
    border-top: 1px solid var(--border-color);
}
.roster-card-score {
    text-align: center;
}
.roster-card-score .val {
    font-size: 1rem;
    font-weight: 800;
    font-family: 'JetBrains Mono', monospace;
    line-height: 1.1;
}
.roster-card-score .lbl {
    font-size: 0.5rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
}
.roster-card-score .val.ridge { color: var(--accent-gold); }
.roster-card-ridge-bar {
    margin-top: 0.375rem;
    height: 3px;
    background: rgba(148,163,184,0.15);
    border-radius: 2px;
    overflow: hidden;
}
.roster-card-ridge-fill {
    height: 100%;
    background: var(--accent-gold);
    border-radius: 2px;
    transition: width 0.3s;
}
.roster-card-graduating {
    border-left: 3px solid var(--amber);
}
.roster-card-bench {
    opacity: 0.45;
}
.class-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.0625rem 0.375rem;
    border-radius: 0.25rem;
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
}
.class-badge.senior { background: var(--amber-bg); color: var(--amber); }
.class-badge.junior { background: rgba(59,130,246,0.15); color: var(--accent-blue); }

/* Sort controls */
.sort-controls {
    display: flex;
    gap: 0.375rem;
    margin-bottom: 0.75rem;
}
.sort-btn {
    padding: 0.25rem 0.625rem;
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 0.25rem;
    cursor: pointer;
    transition: all 0.15s;
}
.sort-btn:hover { color: var(--text-primary); border-color: var(--accent-gold); }
.sort-btn.active { background: var(--accent-gold); color: var(--bg-primary); border-color: var(--accent-gold); }

/* ============================================================
   SIUE Pipeline Cards
   ============================================================ */
.pipeline-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 0.75rem;
}
.pipeline-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.625rem;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
    display: block;
    position: relative;
}
.pipeline-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    border-color: var(--accent-gold);
}
.pipeline-card-tier {
    height: 3px;
}
.pipeline-card-tier.tier-1 { background: var(--accent-gold); }
.pipeline-card-tier.tier-2 { background: var(--accent-blue); }
.pipeline-card-tier.tier-3 { background: var(--text-muted); }
.pipeline-card-body {
    padding: 0.75rem;
}
.pipeline-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}
.pipeline-card-name {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--text-primary);
}
.pipeline-card-status {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
}
.status-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}
.status-dot.offered { background: var(--green); }
.status-dot.scouting { background: var(--amber); }
.status-dot.committed { background: var(--accent-blue); }
.pipeline-card-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
    font-size: 0.6875rem;
    color: var(--text-muted);
}
.pipeline-stars {
    display: inline-flex;
    gap: 1px;
}
.pipeline-star {
    color: var(--amber);
    font-size: 0.625rem;
}
.pipeline-star.empty { color: var(--text-muted); opacity: 0.3; }

/* Interest meter */
.interest-meter {
    margin: 0.5rem 0;
}
.interest-meter-label {
    display: flex;
    justify-content: space-between;
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-muted);
    margin-bottom: 0.25rem;
}
.interest-meter-bar {
    height: 4px;
    background: rgba(148,163,184,0.15);
    border-radius: 2px;
    overflow: hidden;
}
.interest-meter-fill {
    height: 100%;
    border-radius: 2px;
    transition: width 0.3s;
}
.interest-very-high { background: var(--green); }
.interest-high { background: var(--amber); }
.interest-medium { background: var(--accent-orange); }
.interest-low { background: var(--red); }
.pipeline-card-footer {
    font-size: 0.6875rem;
    color: var(--text-secondary);
    padding-top: 0.5rem;
    border-top: 1px solid var(--border-color);
}

/* ============================================================
   Recruit-to-Role Matching
   ============================================================ */
.role-match-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 0.75rem;
}
.role-match-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 0.75rem;
}
.role-match-header {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.role-match-recruit {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.375rem 0;
    border-bottom: 1px solid rgba(148,163,184,0.1);
}
.role-match-recruit:last-child { border-bottom: none; }
.role-match-name {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text-primary);
    flex: 1;
}
.role-match-fit {
    font-size: 0.75rem;
    font-weight: 700;
    font-family: 'JetBrains Mono', monospace;
}
.role-match-indicators {
    display: flex;
    gap: 0.25rem;
    margin-top: 0.25rem;
}
.role-match-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}
.role-match-dot.met { background: var(--green); }
.role-match-dot.below { background: var(--red); }

/* ============================================================
   Radar Chart
   ============================================================ */
.radar-chart-container {
    max-width: 400px;
    margin: 0 auto;
}

/* ============================================================
   SIUE Red/White Theme Override (accent-only on light base)
   ============================================================ */
.siue-theme {
    --accent-gold: #c41530;
}
.siue-theme .ridge-bar-fill { background: #c41530; }
.siue-theme .ridge-bar-fill.graduating { background: var(--amber); }
.siue-theme .roster-card-ridge-fill { background: #c41530; }
.siue-theme .roster-card-score .val.ridge { color: #c41530; }
.siue-theme .player-card-info { background: linear-gradient(135deg, rgba(196,21,48,0.04) 0%, transparent 100%); }
.siue-theme .comp-bar-fill:not(.comp-compare) { background: #c41530; }
.siue-theme .lb-card-icon-wrap {
    background: linear-gradient(135deg, rgba(196,21,48,0.08) 0%, rgba(196,21,48,0.15) 100%);
}
.siue-theme .pos-badge {
    background: rgba(196,21,48,0.08);
}

/* Breadcrumbs */
.breadcrumb {
    font-size: 0.75rem;
    color: var(--text-muted);
    padding: 0.5rem 0;
}
.breadcrumb a {
    color: var(--text-secondary);
    text-decoration: none;
}
.breadcrumb a:hover {
    color: var(--accent-gold);
}
.breadcrumb .sep {
    margin: 0 0.375rem;
    color: var(--text-muted);
}


/* Tooltip (CSS-only) */
[data-tip] {
    position: relative;
    cursor: help;
}
[data-tip]::after {
    content: attr(data-tip);
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    padding: 0.25rem 0.5rem;
    background: #1e293b;
    color: #f1f5f9;
    font-size: 0.6875rem;
    border-radius: 0.25rem;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.15s;
    z-index: 20;
}
[data-tip]:hover::after {
    opacity: 1;
}

/* ============================================================
   SIUE Hub — Phase Card, Action Items, Navigation Cards
   ============================================================ */

/* Phase indicator card */
.phase-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.625rem;
    padding: 1.25rem;
    border-left: 4px solid var(--text-muted);
}
.phase-card.phase-recruiting { border-left-color: var(--green); }
.phase-card.phase-offseason { border-left-color: var(--accent-blue); }
.phase-card.phase-season { border-left-color: var(--accent-gold); }
.phase-card.phase-preseason { border-left-color: var(--amber); }

.phase-card-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}
.phase-card-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.5rem;
    background: var(--bg-secondary);
    color: var(--text-secondary);
    flex-shrink: 0;
}
.phase-recruiting .phase-card-icon { color: var(--green); background: var(--green-bg); }
.phase-offseason .phase-card-icon { color: var(--accent-blue); background: rgba(37,99,235,0.08); }
.phase-season .phase-card-icon { color: var(--accent-gold); background: rgba(194,65,12,0.08); }

.phase-card-label {
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
}
.phase-card-value {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text-primary);
}
.phase-confidence {
    margin-left: auto;
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
    background: var(--bg-secondary);
    padding: 0.125rem 0.5rem;
    border-radius: 9999px;
}

.phase-card-stats {
    display: flex;
    gap: 1.5rem;
    margin-top: 1rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--border-color);
    flex-wrap: wrap;
}
.phase-stat {
    text-align: center;
}
.phase-stat-value {
    display: block;
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text-primary);
    font-family: 'JetBrains Mono', monospace;
}
.phase-stat-label {
    font-size: 0.5625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
}

/* Action items */
.action-items {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.action-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.625rem 0.875rem;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    border-left: 3px solid var(--text-muted);
}
.action-item.action-high { border-left-color: var(--red); }
.action-item.action-medium { border-left-color: var(--amber); }
.action-item.action-low { border-left-color: var(--text-muted); }

.action-priority {
    font-size: 0.5625rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    padding: 0.125rem 0.375rem;
    border-radius: 0.25rem;
    flex-shrink: 0;
}
.action-high .action-priority { background: var(--red-bg); color: var(--red); }
.action-medium .action-priority { background: var(--amber-bg); color: var(--amber); }
.action-low .action-priority { background: var(--bg-secondary); color: var(--text-muted); }

.action-text {
    font-size: 0.8125rem;
    color: var(--text-primary);
}

/* Navigation cards grid */
.siue-nav-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
}
@media (max-width: 1024px) {
    .siue-nav-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .siue-nav-cards { grid-template-columns: 1fr; }
}

.siue-nav-card {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 1rem 1.125rem;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 0.625rem;
    text-decoration: none;
    color: inherit;
    transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
}
.siue-nav-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
    border-color: var(--accent-gold);
}

.siue-nav-card-icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(196,21,48,0.06) 0%, rgba(196,21,48,0.12) 100%);
    border-radius: 0.5rem;
    color: #c41530;
}

.siue-nav-card-body {
    flex: 1;
    min-width: 0;
}
.siue-nav-card-title {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.3;
}
.siue-nav-card-desc {
    font-size: 0.6875rem;
    color: var(--text-muted);
    line-height: 1.3;
    margin-top: 0.125rem;
}
.siue-nav-card-stat {
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-top: 0.375rem;
}
.siue-nav-card-detail {
    color: var(--text-muted);
    font-weight: 400;
    margin-left: 0.375rem;
}

.siue-nav-card-arrow {
    flex-shrink: 0;
    color: var(--text-muted);
    transition: color 0.15s, transform 0.15s;
}
.siue-nav-card:hover .siue-nav-card-arrow {
    color: var(--accent-gold);
    transform: translateX(2px);
}

/* Auth gate: hide everything except the overlay when locked */
html.auth-locked nav,
html.auth-locked main,
html.auth-locked footer { display: none !important; }

/* ============================================================
   Workout Sidebar (Draft Board)
   ============================================================ */

.workout-sidebar {
    width: 360px;
    flex-shrink: 0;
    border-left: 1px solid var(--border-color);
    background: var(--bg-secondary);
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 120px);
    position: sticky;
    top: 60px;
    margin-left: 1rem;
    border-radius: 0.5rem;
    overflow: hidden;
}

.workout-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-primary);
    flex-shrink: 0;
}

.workout-tab-bar {
    display: flex;
    gap: 0;
    background: var(--bg-secondary);
    border-radius: 0.375rem;
    padding: 2px;
}

.workout-tab {
    flex: 1;
    padding: 0.35rem 0.5rem;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-muted);
    background: transparent;
    border: none;
    border-radius: 0.3rem;
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
}

.workout-tab:hover {
    color: var(--text-primary);
}

.workout-tab-active {
    background: var(--bg-primary);
    color: var(--accent-gold);
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}

.workout-tab-count {
    font-size: 0.625rem;
    opacity: 0.7;
}

.workout-sidebar-list {
    flex: 1;
    overflow-y: auto;
    padding: 0.5rem;
}

.workout-sidebar-footer {
    padding: 0.5rem;
    border-top: 1px solid var(--border-color);
    background: var(--bg-primary);
    flex-shrink: 0;
}

/* Tier separator */
.workout-tier-sep {
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    padding: 0.625rem 0.5rem 0.25rem;
    margin-top: 0.25rem;
    border-bottom: 1px solid var(--border-color);
}
.workout-tier-sep:first-child {
    margin-top: 0;
}

/* Workout card */
.workout-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 0.375rem;
    padding: 0.5rem 0.625rem;
    margin-bottom: 0.375rem;
    cursor: default;
    transition: border-color 0.15s, opacity 0.15s, box-shadow 0.15s;
}
.workout-card:hover {
    border-color: var(--accent-gold);
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.workout-card-completed {
    border-left: 3px solid var(--green);
    opacity: 0.75;
}
.workout-card-completed:hover {
    opacity: 1;
}
.workout-card-dragging {
    opacity: 0.4;
    border-color: var(--accent-gold);
}

/* Card top row */
.workout-card-top-row {
    display: flex;
    align-items: center;
    gap: 0.375rem;
}
.workout-drag-handle {
    cursor: grab;
    color: var(--text-muted);
    font-size: 1.125rem;
    line-height: 1;
    user-select: none;
    flex-shrink: 0;
}
.workout-drag-handle:active {
    cursor: grabbing;
}
.workout-card-rank {
    font-size: 0.6875rem;
    font-weight: 700;
    color: var(--text-secondary);
    flex-shrink: 0;
}
.workout-card-name {
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--text-primary);
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-decoration: none;
}
.workout-card-name:hover {
    color: var(--accent-gold);
    text-decoration: underline;
}
.workout-card-status {
    flex-shrink: 0;
    font-size: 0.5625rem;
    padding: 0.0625rem 0.375rem;
}
.workout-card-remove {
    flex-shrink: 0;
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 1rem;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    opacity: 0;
    transition: opacity 0.15s, color 0.15s;
}
.workout-card:hover .workout-card-remove {
    opacity: 1;
}
.workout-card-remove:hover {
    color: var(--red);
}

/* Card meta */
.workout-card-meta {
    font-size: 0.6875rem;
    color: var(--text-muted);
    margin-top: 0.125rem;
    padding-left: 1.5rem;
}

/* Denver Fit row */
.workout-card-fit {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    margin-top: 0.25rem;
    padding-left: 1.5rem;
    font-size: 0.625rem;
}
.workout-fit-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.125rem;
    padding: 0.0625rem 0.375rem;
    border-radius: 0.25rem;
    font-weight: 700;
    font-size: 0.6875rem;
}
.fit-excellent {
    background: var(--green-bg);
    color: var(--green);
}
.fit-good {
    background: rgba(234,179,8,0.15);
    color: #ca8a04;
}
.fit-moderate {
    background: rgba(148,163,184,0.15);
    color: var(--text-secondary);
}
.workout-fit-sub {
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
}
.workout-fit-arch {
    color: var(--accent-blue);
    font-style: italic;
    margin-left: auto;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 7rem;
}

/* Ratings chips */
.workout-card-ratings {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    margin-top: 0.375rem;
    padding-left: 1.5rem;
}
.workout-rating-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.125rem;
    padding: 0.0625rem 0.375rem;
    border-radius: 0.25rem;
    font-size: 0.625rem;
    font-weight: 600;
}
.chip-elite {
    background: var(--green-bg);
    color: var(--green);
}
.chip-good {
    background: rgba(59,130,246,0.1);
    color: var(--accent-blue);
}
.chip-avg {
    background: rgba(148,163,184,0.15);
    color: var(--text-secondary);
}

/* Rationale */
.workout-card-rationale {
    font-size: 0.6875rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
    padding-left: 1.5rem;
    font-style: italic;
    line-height: 1.4;
}

/* Result row */
.workout-card-result {
    font-size: 0.6875rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
    padding-left: 1.5rem;
    padding-top: 0.25rem;
    border-top: 1px solid var(--border-color);
}

/* Notes input */
.workout-card-notes {
    width: calc(100% - 1.5rem);
    margin-left: 1.5rem;
    margin-top: 0.25rem;
    background: var(--bg-secondary);
    border: 1px solid transparent;
    border-radius: 0.25rem;
    font-size: 0.6875rem;
    color: var(--text-secondary);
    padding: 0.1875rem 0.375rem;
    transition: border-color 0.15s;
}
.workout-card-notes:focus {
    outline: none;
    border-color: var(--accent-gold);
    background: var(--bg-primary);
}
.workout-card-notes::placeholder {
    color: var(--text-muted);
}

/* Responsive: sidebar overlay on small screens */
@media (max-width: 1280px) {
    .workout-sidebar {
        position: fixed;
        right: 0;
        top: 0;
        bottom: 0;
        max-height: 100vh;
        margin-left: 0;
        border-radius: 0;
        z-index: 40;
        box-shadow: -4px 0 24px rgba(0,0,0,0.12);
    }
}
@media (max-width: 768px) {
    .workout-sidebar {
        width: 100%;
    }
}

/* ========================================================================
   Mismatch Risk Badge Styles
   ======================================================================== */

/* Risk badge component */
.risk-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 3px;
    font-size: 0.85em;
    font-weight: 600;
    text-transform: uppercase;
    cursor: help;
}
.risk-low {
    background-color: rgba(46, 204, 113, 0.2);
    color: #2ecc71;
    border: 1px solid #2ecc71;
}
.risk-medium {
    background-color: rgba(241, 196, 15, 0.2);
    color: #f1c40f;
    border: 1px solid #f1c40f;
}
.risk-high {
    background-color: rgba(231, 76, 60, 0.2);
    color: #e74c3c;
    border: 1px solid #e74c3c;
}
.risk-badge:hover {
    opacity: 0.8;
}

/* Risk indicator icon (for workout sidebar) */
.risk-indicator {
    font-size: 0.9em;
    margin-left: 4px;
}
.risk-indicator.risk-low {
    color: #2ecc71;
}
.risk-indicator.risk-medium {
    color: #f1c40f;
}
.risk-indicator.risk-high {
    color: #e74c3c;
}

/* Risk Assessment Section (Prospect Detail Page) */
.risk-summary {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}
.risk-score-display {
    text-align: center;
}
.risk-value {
    font-size: 2rem;
    font-weight: 700;
}
.risk-tier {
    font-size: 0.9rem;
    font-weight: 600;
}
.risk-explanation {
    font-style: italic;
    color: #aaa;
}
.risk-breakdown h4 {
    margin-top: 1rem;
    margin-bottom: 0.5rem;
}
.no-flags {
    color: #888;
    font-style: italic;
}
