/* bball.css — basketball-specific components layered on the ColesAlgoPicks
   design system (tennis.css supplies tokens, topbar, layout, buttons). */

/* topbar: we don't carry tennis's nav-search, so push the nav to the right
   edge instead of letting it bunch against the logo on desktop. */
.topbar{display:flex;align-items:center}
.nav{margin-left:auto}
@media(max-width:760px){.nav{margin-left:0}}

/* ---- grade chip + edge/conf coloring (Fanatic: instant color verdict) ---- */
.grade{display:inline-block;min-width:2.1em;text-align:center;font-weight:800;border-radius:6px;padding:2px 6px;font-size:.82rem;font-family:'JetBrains Mono',monospace}
.grade.Ap,.grade.A{background:#173d2a;color:#5fe39a;border:1px solid #2e6b48}
.grade.B{background:#1c3520;color:#8fd6a0;border:1px solid #2e5b3a}
.grade.C{background:#34320f;color:#e7d77a;border:1px solid #5a541d}
.grade.D{background:#3a2417;color:#e9a06a;border:1px solid #6a3f23}
.grade.F{background:#3a1820;color:#e87f8c;border:1px solid #6a2c38}
.edge-pos{color:#5fe39a;font-weight:700}.edge-neg{color:#e87f8c}
.conf-High{color:#5fe39a}.conf-Medium{color:#e7d77a}.conf-Low{color:#9aa3af}
.side-over{color:#5fe39a;font-weight:700}.side-under{color:#e89a6a;font-weight:700}

/* ---- the Board table ---- */
.board-tools{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin:.6rem 0}
.board-tools .seg button,.board-tools input,.board-tools select{font-size:.85rem}
table.board{width:100%;border-collapse:collapse;font-size:.86rem}
table.board th{position:sticky;top:0;background:var(--card,#12161d);text-align:right;padding:.5rem .55rem;cursor:pointer;white-space:nowrap;color:#9aa3af;border-bottom:1px solid #232a34;font-weight:600}
table.board th:first-child,table.board td:first-child{text-align:left}
table.board td{padding:.45rem .55rem;text-align:right;border-bottom:1px solid #1a2029;white-space:nowrap}
table.board tr:hover td{background:#151a22}
table.board .pl a{font-weight:700}
.mini{color:#7f8893;font-size:.78rem}

/* ---- hit-rate bar (proportion green) ---- */
.hitbar{display:inline-flex;gap:2px;vertical-align:middle}
.hitbar i{width:7px;height:14px;border-radius:2px;background:#2a313c;display:inline-block}
.hitbar i.h{background:#3ea76e}

/* ---- player page ---- */
.pl-hero{display:flex;gap:1.2rem;align-items:center;background:linear-gradient(135deg,rgba(95,227,154,.07),rgba(122,162,255,.04));border:1px solid #232a34;border-radius:16px;padding:1rem 1.3rem;margin:.5rem 0 1.2rem}
.pl-shot{width:94px;height:94px;border-radius:50%;object-fit:cover;object-position:center top;background:#1a2029;border:2px solid #2e6b48;flex-shrink:0}
.pl-shot.noimg{visibility:hidden;width:0;border:0;margin:0}
.pl-hero-main{flex:1;min-width:0}
.pl-hero-top{display:flex;align-items:center;gap:.6rem}
.pl-hero-top h1{margin:0;font-size:2rem;line-height:1.05;font-family:'Bricolage Grotesque'}
.pl-sub{color:#9aa3af;font-size:.88rem;margin:.3rem 0 .7rem}
.pl-stats{display:flex;gap:.45rem;flex-wrap:wrap}
.pl-stat{background:#12161d;border:1px solid #232a34;border-radius:10px;padding:.4rem .7rem;text-align:center;min-width:52px}
.pl-stat-v{font-family:'JetBrains Mono',monospace;font-weight:800;font-size:1.15rem;color:#eaf0f6}
.pl-stat-l{font-size:.6rem;letter-spacing:.05em;color:#7f8893;text-transform:uppercase;margin-top:1px}
.watch-star{cursor:pointer;font-size:1.55rem;color:#3a4250;user-select:none;line-height:1;transition:.15s}
.watch-star:hover{transform:scale(1.12)}.watch-star.on{color:#f5c542}
@media(max-width:560px){.pl-shot{width:62px;height:62px}.pl-hero-top h1{font-size:1.5rem}.pl-hero{padding:.8rem .9rem;gap:.8rem}}
.pl-head{display:flex;flex-wrap:wrap;gap:1rem;align-items:baseline;margin:.4rem 0 1rem}
.pl-head h1{margin:0}.pl-meta{color:#9aa3af;font-size:.9rem;display:flex;gap:1rem;flex-wrap:wrap}
.mkt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.8rem}
.mkt-card{background:var(--card,#12161d);border:1px solid #232a34;border-radius:12px;padding:.8rem .9rem}
.mkt-card h3{margin:.1rem 0 .3rem;font-size:1rem;display:flex;justify-content:space-between;align-items:center}
.mkt-line{font-size:1.5rem;font-weight:800}
.mkt-row{display:flex;justify-content:space-between;font-size:.82rem;color:#aeb6c0;margin:.15rem 0}
.why{margin-top:.5rem;font-size:.76rem;color:#7f8893;border-top:1px dashed #232a34;padding-top:.4rem;display:none}
.why.show{display:block}
.why b{color:#aeb6c0}
.why-toggle{cursor:pointer;color:#7aa2ff;font-size:.76rem;user-select:none}

/* ---- shot chart (Props.Cash-style: zone FG% + ▲/●/▼ advantage) ---- */
.court-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;margin:.2rem 0 .5rem}
.court-vs b{font-size:1rem}
.court-legend{display:flex;gap:.7rem;font-size:.72rem}
.court-legend .lg-up{color:#5fe39a}.court-legend .lg-neu{color:#9aa3af}.court-legend .lg-dn{color:#e87f8c}
.court-ctrls{display:flex;gap:.7rem;align-items:center;margin:.2rem 0 .6rem;flex-wrap:wrap}
.seg{display:inline-flex;border:1px solid #2a313c;border-radius:8px;overflow:hidden}
.seg button{background:transparent;border:0;color:#aeb6c0;padding:.32rem .66rem;cursor:pointer;font-weight:600;font-size:.82rem}
.seg button.on{background:#1d6f46;color:#eafff2}
.court-toggle{color:#9aa3af;font-size:.82rem;display:flex;gap:.3rem;align-items:center}
.court-wrap{position:relative;max-width:440px}
.court-svg{width:100%;height:auto;display:block;background:#0c1117;border:1px solid #1c232d;border-radius:12px}
.zlab{position:absolute;transform:translate(-50%,-50%);text-align:center;pointer-events:auto;cursor:default;white-space:nowrap}
.zname{font-size:.6rem;letter-spacing:.04em;color:#8c95a0;font-weight:700}
.zval{font-family:'JetBrains Mono',monospace;font-weight:800;font-size:1rem;text-shadow:0 1px 3px #000}
.zval.up{color:#5fe39a}.zval.neu{color:#cdd4dd}.zval.dn{color:#e87f8c}
.court-tip{position:absolute;z-index:9;background:#0a0d12;border:1px solid #2a313c;border-radius:8px;padding:.45rem .6rem;font-size:.76rem;pointer-events:none;max-width:240px}

/* ---- teammate with/without chips ---- */
.mate-chip{display:inline-flex;align-items:center;gap:.3rem;background:#0e1218;border:1px solid #2a313c;border-radius:999px;padding:.12rem .45rem;font-size:.74rem;margin:2px 3px 2px 0}
.mate-chip.with{border-color:#2e6b48}.mate-chip.without{border-color:#6a2c38}
.mate-chip .mc-tog{background:#173d2a;color:#5fe39a;border:0;border-radius:5px;font-size:.58rem;font-weight:800;cursor:pointer;padding:1px 5px}
.mate-chip.without .mc-tog{background:#3a1820;color:#e87f8c}
.mate-chip .mc-rm{background:transparent;border:0;color:#9aa3af;cursor:pointer;font-size:.9rem;line-height:1}

/* ---- player-profile game-log filter bar (horizontal) ---- */
.glf{display:flex;flex-wrap:wrap;gap:.5rem .9rem;align-items:flex-end;margin:.4rem 0 .7rem;padding:.6rem .7rem;background:var(--card,#12161d);border:1px solid #232a34;border-radius:10px}
.glf .gi{display:flex;flex-direction:column;gap:.2rem}
.glf label{font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;color:#7f8893}
.glf .seg button{font-size:.74rem;padding:.26rem .5rem}
.glf select,.glf input[type=number]{background:#0e1218;border:1px solid #2a313c;color:#e6e9ee;border-radius:7px;padding:.28rem}
.fil input[type=number]{background:#0e1218;border:1px solid #2a313c;color:#e6e9ee;border-radius:7px;padding:.28rem;width:50%}
.minrange{display:flex;gap:.35rem;align-items:center}.minrange span{color:#7f8893;font-size:.72rem}
/* dual-handle range slider (min/max on one track) */
.dr{position:relative;height:22px}
.dr input[type=range]{position:absolute;left:0;top:4px;width:100%;height:14px;margin:0;background:none;pointer-events:none;-webkit-appearance:none;appearance:none}
.dr input[type=range]::-webkit-slider-runnable-track{height:4px;background:#2a313c;border-radius:3px}
.dr input[type=range]::-moz-range-track{height:4px;background:#2a313c;border-radius:3px}
.dr input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;pointer-events:auto;width:14px;height:14px;border-radius:50%;background:#5fe39a;border:2px solid #0c1117;margin-top:-5px;cursor:pointer}
.dr input[type=range]::-moz-range-thumb{pointer-events:auto;width:14px;height:14px;border-radius:50%;background:#5fe39a;border:2px solid #0c1117;cursor:pointer}
.dr-lab{font-family:'JetBrains Mono',monospace;color:#9aa3af}
.glf .mates-wrap{flex:1;min-width:180px}
table.glog tr{cursor:pointer}table.glog tr:hover td{background:#151a22}

/* ---- box-score modal (shared by prop chart + explorer) ---- */
.bxwrap{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:50}
.bxwrap.open{display:flex}
.bx{background:#12161d;border:1px solid #2a313c;border-radius:14px;padding:1.2rem;max-width:440px;width:92%;max-height:88vh;overflow:auto}
.bx h3{margin:.1rem 0 .6rem}
.bx table{width:100%;border-collapse:collapse;font-size:.85rem}
.bx td{padding:.25rem .4rem;border-bottom:1px solid #1a2029}
.bx td:last-child{text-align:right;font-family:'JetBrains Mono',monospace}
.bx-close{float:right;cursor:pointer;color:#9aa3af;font-size:1.2rem}

/* ---- per-game prop chart with adjustable line (HRK/Props.Cash style) ---- */
.pc-tabs{flex-wrap:wrap;margin-bottom:.5rem}
.pc-controls{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin:.3rem 0 .6rem}
.pc-line{display:flex;align-items:center;gap:.5rem}
.pc-line input[type=range]{width:150px;accent-color:#f5c542}
.pc-lineval{font-family:'JetBrains Mono',monospace;font-weight:800;font-size:1.15rem;min-width:2.6em;text-align:center;color:#f5c542}
.pc-step{background:#1a2029;border:1px solid #2a313c;color:#e6e9ee;width:28px;height:28px;border-radius:7px;cursor:pointer;font-weight:800;font-size:1rem;line-height:1}
.pc-step:hover{background:#222b36}
.pc-hits{display:flex;gap:.7rem;font-size:.85rem;flex-wrap:wrap;color:#9aa3af}
.pc-hits b{font-family:'JetBrains Mono',monospace;color:#cdd4dd}
.pc-chart{position:relative;height:210px;display:flex;align-items:flex-end;gap:3px}
.pc-bar{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;min-width:0;height:100%}
.pc-bar .pcv{font-size:.66rem;font-family:'JetBrains Mono',monospace;color:#cdd4dd;margin-bottom:2px}
.pc-bar .pcb{width:80%;border-radius:3px 3px 0 0;min-height:2px;transition:height .15s,background .15s}
.pc-bar.over .pcb{background:#3ea76e}.pc-bar.under .pcb{background:#c84a52}
.pc-line-ovl{position:absolute;left:0;right:0;border-top:2px dashed #f5c542;z-index:3;pointer-events:none}
.pc-line-ovl span{position:absolute;right:0;top:-9px;background:#f5c542;color:#0a0d12;font-size:.66rem;font-weight:800;padding:0 5px;border-radius:3px}
.pc-dates{display:flex;gap:3px;margin-top:4px}
.pc-date{flex:1;text-align:center;font-size:.58rem;color:#7f8893;min-width:0;overflow:hidden;white-space:nowrap}

/* ---- play style / shot profile ---- */
.ps-row{display:grid;grid-template-columns:118px 1fr 42px 168px 56px;gap:.6rem;align-items:center;padding:.4rem 0;border-top:1px solid #1a2029;font-size:.85rem}
.ps-name{font-weight:600}
.ps-bar{background:#1a2029;border-radius:5px;height:10px;overflow:hidden}
.ps-bar span{display:block;height:100%;background:#3ea76e;border-radius:5px}
.ps-freq{font-family:'JetBrains Mono',monospace;text-align:right;font-weight:700}
.ps-fg{color:#aeb6c0}
@media(max-width:560px){.ps-row{grid-template-columns:84px 1fr 38px}.ps-fg,.ps-row .ps-att{display:none}}

/* ---- gamelog ---- */
table.glog{width:100%;border-collapse:collapse;font-size:.82rem;margin-top:.4rem}
table.glog th,table.glog td{padding:.35rem .5rem;text-align:right;border-bottom:1px solid #1a2029}
table.glog th:first-child,table.glog td:first-child{text-align:left}

/* ---- best bets cards ---- */
.bet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.8rem}
.bet-card{background:var(--card,#12161d);border:1px solid #232a34;border-radius:12px;padding:.9rem;border-left:4px solid #2e6b48}
.bet-card .top{display:flex;justify-content:space-between;align-items:center}
.bet-card .pick{font-size:1.15rem;font-weight:800;margin:.2rem 0}
.bet-card .nums{display:flex;gap:1rem;margin:.4rem 0;font-size:.84rem}
.bet-card .nums b{display:block;font-size:1.05rem}
.section-h{margin:1.4rem 0 .5rem;font-size:1.1rem}
