/* ═══ Roster page — design handoff v31 ═══ */

:root { --purple:#4F2683; --green:#34D399; --red:#EF4444; --blue:#60A5FA; --violet:#A78BFA; --orange:#F59E0B; --pink:#EC4899; --teal:#14B8A6; }

@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:.3; } }

/* Page head */
.page-head { border-bottom:1px solid var(--border);padding:32px 0 28px;position:relative;overflow:hidden; }
.page-head::before { content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,184,0,.05),transparent 70%);pointer-events:none; }
.page-head-inner { display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap; }
.page-eyebrow { font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--gold);letter-spacing:.15em;text-transform:uppercase;margin-bottom:10px; }
.page-title { font-family:'Oswald',sans-serif;font-size:clamp(42px,6vw,72px);font-weight:700;text-transform:uppercase;line-height:.92;letter-spacing:-.02em;margin-bottom:10px; }
.page-dek { font-family:'DM Sans',sans-serif;font-size:15px;color:var(--text-2);max-width:580px; }
.page-stamp { font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3);letter-spacing:.05em; }
.page-stamp-dot { display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);margin-right:6px;animation:pulse 1.8s ease-in-out infinite; }
.roster-counts { display:flex;gap:18px;margin-top:20px;flex-wrap:wrap; }
.rc-item { display:flex;flex-direction:column; }
.rc-k { font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--text-3);letter-spacing:.1em;text-transform:uppercase; }
.rc-v { font-family:'Oswald',sans-serif;font-size:24px;font-weight:700;color:var(--text-1);line-height:1;margin-top:4px; }
.rc-v.gold { color:var(--gold); }

/* Section labels */
.section-label { font-family:'Oswald',sans-serif;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);display:flex;align-items:center;gap:12px;margin-bottom:20px; }
.section-label::after { content:'';flex:1;height:1px;background:var(--border); }

/* Offseason notice */
.rd-offseason { display:flex;align-items:center;gap:10px;padding:12px 16px;background:rgba(167,139,250,.04);border:1px solid rgba(167,139,250,.15);border-radius:var(--radius);margin-bottom:24px; }

/* Stat leader cards */
.leaders-grid { display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:40px; }
@media (min-width:600px) { .leaders-grid { grid-template-columns:1fr 1fr; } }
@media (min-width:1000px) { .leaders-grid { grid-template-columns:repeat(4,1fr); } }
.leader-card { background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--leader-color,var(--gold));border-radius:0 var(--radius) var(--radius) 0;padding:14px 16px;transition:all .15s; }
.leader-card:hover { border-color:var(--border-h);background:var(--surface-h); }
.leader-head { display:flex;align-items:center;gap:8px;margin-bottom:10px; }
.leader-dot { width:6px;height:6px;border-radius:50%;background:var(--leader-color,var(--gold)); }
.leader-label { font-family:'Oswald',sans-serif;font-size:10px;font-weight:700;color:var(--leader-color,var(--gold));text-transform:uppercase;letter-spacing:.06em; }
.leader-body { display:flex;align-items:center;gap:10px; }
.leader-jn { font-family:'Oswald',sans-serif;font-size:28px;font-weight:700;color:var(--purple);text-shadow:0 0 4px rgba(255,184,0,.25);line-height:1;min-width:36px;text-align:center;flex-shrink:0; }
.leader-name { font-family:'Oswald',sans-serif;font-size:14px;font-weight:700;color:var(--text-1);text-transform:uppercase;letter-spacing:.01em;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.leader-pos { font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--text-3);margin-top:2px;letter-spacing:.04em; }
.leader-stats { display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border); }
.leader-stat { flex:1;text-align:center; }
.leader-stat-v { font-family:'Oswald',sans-serif;font-size:15px;font-weight:700;color:var(--gold);line-height:1.1; }
.leader-stat-k { font-family:'JetBrains Mono',monospace;font-size:8px;color:var(--text-3);letter-spacing:.08em;margin-top:2px; }

/* Unit toggle */
.unit-toggle { display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:3px;gap:2px; }
.unit-toggle button { padding:8px 18px;background:transparent;border:none;border-radius:4px;font-family:'Oswald',sans-serif;font-size:12px;font-weight:700;color:var(--text-2);letter-spacing:.06em;text-transform:uppercase;transition:all .15s;cursor:pointer; }
.unit-toggle button:hover { color:var(--text-1); }
.unit-toggle button.active { background:var(--gold);color:#0B0D11; }

/* Depth chart field */
.depth-field { background:linear-gradient(180deg,#0f2418 0%,#0a1810 100%);border:1px solid rgba(52,211,153,.12);border-radius:var(--radius);padding:28px 20px;position:relative;overflow:hidden; }
.depth-field::before { content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent 0 calc(10% - 1px),rgba(255,255,255,.02) calc(10% - 1px) 10%);pointer-events:none; }
.depth-layout { display:grid;gap:14px;position:relative;z-index:1; }
.dc-row { display:grid;grid-template-columns:100px 1fr;gap:16px;align-items:center;min-width:0; }
.dc-label { font-family:'Oswald',sans-serif;font-size:11px;font-weight:700;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.08em;text-align:right;padding-right:4px; }
.dc-slots { display:flex;gap:8px;flex-wrap:wrap;min-width:0; }
.dc-slot { flex:1;min-width:120px;background:rgba(11,13,17,.55);border:1px solid var(--border);border-radius:6px;padding:8px 10px;display:flex;align-items:center;gap:8px;transition:all .15s;cursor:pointer;border-left:3px solid var(--ac,rgba(255,255,255,.2)); }
.dc-slot:hover { background:rgba(11,13,17,.75);border-color:var(--border-h); }
.dc-slot.starter { background:rgba(255,184,0,.06);border:1px solid rgba(255,184,0,.22);border-left:3px solid var(--gold); }
.dc-slot.starter:hover { background:rgba(255,184,0,.1); }
.dc-jn { font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;color:var(--purple);text-shadow:0 0 3px rgba(255,184,0,.3);line-height:1;min-width:20px;text-align:center; }
.dc-info { flex:1;min-width:0; }
.dc-name { font-family:'Oswald',sans-serif;font-size:11px;font-weight:700;color:var(--text-1);text-transform:uppercase;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.1; }
.dc-meta { font-family:'JetBrains Mono',monospace;font-size:8px;color:var(--text-3);margin-top:2px;letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.unit-panel { display:none; }
.unit-panel.active { display:block; }

/* Position spotlights (player cards) */
.pos-section { margin-bottom:28px; }
.pos-head { display:flex;align-items:center;gap:12px;margin-bottom:12px; }
.pos-badge { font-family:'Oswald',sans-serif;font-size:13px;font-weight:700;letter-spacing:.06em;padding:4px 10px;border-radius:4px;color:#0B0D11; }
.pos-title { font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;text-transform:uppercase;color:var(--text-1);letter-spacing:.02em; }
.pos-count { font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3);margin-left:auto;letter-spacing:.04em; }
.pgrid { display:grid;grid-template-columns:1fr;gap:10px; }
@media (min-width:600px) { .pgrid { grid-template-columns:1fr 1fr; } }
@media (min-width:900px) { .pgrid { grid-template-columns:1fr 1fr 1fr; } }

.pcard { background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--ac,var(--gold));border-radius:0 var(--radius) var(--radius) 0;padding:14px;display:flex;gap:12px;align-items:flex-start;transition:all .15s;cursor:pointer; }
.pcard:hover { border-color:var(--border-h);background:var(--surface-h);transform:translateY(-1px); }
.pcard-jn { font-family:'Oswald',sans-serif;font-size:32px;font-weight:700;color:var(--purple);text-shadow:0 0 4px rgba(255,184,0,.25);line-height:.95;min-width:40px;text-align:center;flex-shrink:0; }
.pcard-body { flex:1;min-width:0; }
.pcard-name { font-family:'Oswald',sans-serif;font-size:15px;font-weight:700;color:var(--text-1);text-transform:uppercase;letter-spacing:.01em;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.pcard-meta { font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--text-3);margin-top:3px;letter-spacing:.04em; }
.pcard-tag { font-family:'JetBrains Mono',monospace;font-size:8px;font-weight:700;padding:2px 5px;border-radius:2px;letter-spacing:.06em;flex-shrink:0; }

/* Table toolbar */
.tool-bar { display:flex;align-items:center;gap:8px;flex-wrap:wrap; }
.chip { padding:5px 12px;background:transparent;border:1px solid var(--border);border-radius:20px;font-family:'Oswald',sans-serif;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-2);transition:all .15s;white-space:nowrap;cursor:pointer; }
.chip:hover { border-color:var(--border-h);color:var(--text-1); }
.chip.active { background:var(--gold);color:#0B0D11;border-color:var(--gold); }
.chip-count { font-family:'JetBrains Mono',monospace;color:var(--text-3);font-size:10px;margin-left:4px; }
.chip.active .chip-count { color:rgba(11,13,17,.55); }
.search-wrap { display:flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--border);border-radius:20px;background:rgba(255,255,255,.02); }
.search-wrap input { background:transparent;border:none;color:var(--text-1);font-size:12px;outline:none;width:130px;font-family:'DM Sans',sans-serif; }

/* Full table */
.rtable-wrap { overflow-x:auto; }
.rtable { width:100%;min-width:820px;border-collapse:collapse; }
.rtable thead th { font-family:'Oswald',sans-serif;font-size:10px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;padding:12px 10px;text-align:left;border-bottom:1px solid var(--border);background:rgba(255,255,255,.015);cursor:pointer;user-select:none;white-space:nowrap; }
.rtable thead th:first-child { padding-left:20px; }
.rtable thead th:last-child  { padding-right:20px;text-align:right; }
.rtable thead th.num { text-align:right; }
.rtable thead th:hover { color:var(--gold); }
.rtable thead th .sort-ind { display:inline-block;margin-left:4px;color:var(--text-3);font-size:9px; }
.rtable thead th.sorted .sort-ind { color:var(--gold); }
.rtable tbody tr { border-bottom:1px solid var(--border);transition:background .1s; }
.rtable tbody tr:last-child { border-bottom:none; }
.rtable tbody tr:hover { background:rgba(255,255,255,.015); }
.rtable tbody td { padding:11px 10px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--text-1);vertical-align:middle; }
.rtable tbody td:first-child { padding-left:20px; }
.rtable tbody td:last-child  { padding-right:20px;text-align:right; }
.rtable tbody td.num { font-family:'JetBrains Mono',monospace;text-align:right;letter-spacing:-.01em; }
.rtable-jn { font-family:'Oswald',sans-serif;font-size:15px;font-weight:700;color:var(--purple);text-shadow:0 0 3px rgba(255,184,0,.2);min-width:24px;text-align:center; }
.rtable-pname { font-family:'Oswald',sans-serif;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.01em; }
.rtable-potw { font-family:'JetBrains Mono',monospace;font-size:8px;font-weight:700;color:#A78BFA;background:rgba(167,139,250,.1);padding:1px 5px;border-radius:3px;letter-spacing:.06em;margin-left:4px; }
.pos-pill { display:inline-block;padding:2px 6px;border-radius:3px;font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.04em; }
