/* JBL Universe Front Office — Custom Styles */

:root {
    --bg-primary: #142129;
    --bg-secondary: #1a2e3b;
    --bg-card: #1a2e3b;
    --bg-card-hover: #243d4d;
    --bg-table-row: #1a2e3b;
    --bg-table-row-alt: #162832;
    --bg-table-hover: #243d4d;
    --border-color: #2a4a5a;
    --text-primary: #f1f5f9;
    --text-secondary: #94a3b8;
    --text-muted: #64748b;
    --accent-gold: #7eb53a;
    --accent-orange: #f97316;
    --accent-blue: #3b82f6;
    --green: #7eb53a;
    --green-bg: rgba(126, 181, 58, 0.15);
    --amber: #f59e0b;
    --amber-bg: rgba(245, 158, 11, 0.15);
    --red: #ef4444;
    --red-bg: rgba(239, 68, 68, 0.15);
}

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 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, var(--bg-secondary) 0%, #1a2744 100%);
    border: 1px solid var(--border-color);
    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 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;
}

/* 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 Player Pages (Light Theme)
   ============================================================ */

/* Light theme wrapper — overrides dark theme for player pages */
.ctg-light {
    background: #f5f5f5;
    color: #1a1a1a;
    border-radius: 0.5rem;
    padding: 1.5rem;
    margin: -0.5rem;
}
.ctg-light .card {
    background: #ffffff;
    border-color: #e5e7eb;
    color: #1a1a1a;
}
.ctg-light .hero-card {
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
    border-color: #e5e7eb;
    color: #1a1a1a;
}
.ctg-light .hero-card h1 {
    color: #111827;
}
.ctg-light .text-gold, .ctg-light .text-amber {
    color: #d97706;
}
.ctg-light .tab-list {
    border-bottom-color: #e5e7eb;
}
.ctg-light .tab-btn {
    color: #6b7280;
}
.ctg-light .tab-btn:hover {
    color: #374151;
}
.ctg-light .tab-btn.active {
    color: #c2410c;
    border-bottom-color: #c2410c;
}
.ctg-light .stat-card {
    background: #f9fafb;
    border-color: #e5e7eb;
}
.ctg-light .stat-card .stat-value {
    color: #111827;
}
.ctg-light .stat-card .stat-label {
    color: #6b7280;
}
.ctg-light .pctl-label {
    color: #374151;
}
.ctg-light .pctl-value {
    color: #111827;
}
.ctg-light .pctl-category {
    color: #9ca3af;
    border-bottom-color: #e5e7eb;
}
.ctg-light .pctl-row {
    border-bottom-color: #f3f4f6;
}
.ctg-light .pctl-bar-track {
    background: #e5e7eb;
}
.ctg-light .tendency-track {
    background: #e5e7eb;
}
.ctg-light .tendency-label {
    color: #374151;
}
.ctg-light .tendency-values {
    color: #6b7280;
}
.ctg-light .pos-badge {
    background: rgba(194,65,12,0.12);
    color: #c2410c;
}
.ctg-light p.text-slate-400,
.ctg-light .text-slate-400 {
    color: #6b7280 !important;
}
.ctg-light .text-slate-500,
.ctg-light p.text-slate-500 {
    color: #9ca3af !important;
}
.ctg-light .text-slate-300 {
    color: #374151 !important;
}
.ctg-light .text-xs.font-semibold.text-slate-400 {
    color: #9ca3af !important;
}
.ctg-light a.text-gold {
    color: #c2410c !important;
}

/* 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) {
    text-align: right;
}
.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) */
/* Row shading — shared colors for both ctg-table rows and pctl-row divs */
.ctg-table tr.pctl-row-1,  .ctg-light .pctl-row.pctl-row-1  { background: color-mix(in srgb, #1a4d8f 8%, white); }
.ctg-table tr.pctl-row-2,  .ctg-light .pctl-row.pctl-row-2  { background: color-mix(in srgb, #2b6cb5 7%, white); }
.ctg-table tr.pctl-row-3,  .ctg-light .pctl-row.pctl-row-3  { background: color-mix(in srgb, #4a90d9 6%, white); }
.ctg-table tr.pctl-row-4,  .ctg-light .pctl-row.pctl-row-4  { background: color-mix(in srgb, #7ab3ef 5%, white); }
.ctg-table tr.pctl-row-5,  .ctg-light .pctl-row.pctl-row-5  { background: transparent; }
.ctg-table tr.pctl-row-6,  .ctg-light .pctl-row.pctl-row-6  { background: transparent; }
.ctg-table tr.pctl-row-7,  .ctg-light .pctl-row.pctl-row-7  { background: color-mix(in srgb, #e8a44c 5%, white); }
.ctg-table tr.pctl-row-8,  .ctg-light .pctl-row.pctl-row-8  { background: color-mix(in srgb, #e58333 6%, white); }
.ctg-table tr.pctl-row-9,  .ctg-light .pctl-row.pctl-row-9  { background: color-mix(in srgb, #d9621f 7%, white); }
.ctg-table tr.pctl-row-10, .ctg-light .pctl-row.pctl-row-10 { background: color-mix(in srgb, #c43e17 8%, white); }
.ctg-table tr[class*="pctl-row-"]:hover,
.ctg-light .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(245,158,11,0.15);
    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.35);
    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(126,181,58,0.08) 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;
}

/* Auth gate: hide everything except the overlay when locked */
html.auth-locked nav,
html.auth-locked main,
html.auth-locked footer { display: none !important; }
