/* ═══════════════════════════════════════════════
   Bet Finder — Cross-fixture analysis page
   ═══════════════════════════════════════════════ */

/* Override v3_fixture_analysis scroll lock — bet finder needs normal page scroll */
html:has(.bf-page),
html:has(.bf-page) body,
.v3-analysis:has(.bf-page),
.v3-analysis:has(.bf-page) .dashboard-wrap {
  overflow: visible !important;
  height: auto !important;
}

.bf-page {
  padding-bottom: 40px;
  padding-top: 30px;
}

/* ── Command Strip (unified header + controls + leagues) ── */
.bf-cmd{
  background:#1a1a1f;border:1px solid rgba(255,255,255,0.10);
  border-radius:14px;margin-bottom:16px;overflow:hidden;
}
.bf-cmd__top{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;
}
.bf-cmd__left{display:flex;align-items:center;gap:14px}
.bf-cmd__title{
  font-family:'Sora',sans-serif;font-size:20px;font-weight:800;
  color:var(--text-primary);letter-spacing:-.4px;
}
.bf-cmd__stats{display:flex;align-items:center;gap:6px}
.bf-cmd__stat-chip{display:flex;align-items:baseline;gap:3px}
.bf-cmd__stat-num{
  font-family:'Sora',sans-serif;font-size:14px;font-weight:800;
  color:rgba(255,255,255,0.7);letter-spacing:-.3px;
}
.bf-cmd__stat-chip--glow .bf-cmd__stat-num{color:rgba(0,255,136,0.9)}
.bf-cmd__stat-label{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:10px;font-weight:500;
  color:rgba(255,255,255,0.35);
}
.bf-cmd__stat-chip--glow .bf-cmd__stat-label{color:rgba(0,255,136,0.5)}
.bf-cmd__stat-dot{
  width:3px;height:3px;border-radius:50%;
  background:rgba(255,255,255,0.12);
}
.bf-cmd__right{display:flex;align-items:center;gap:0}
.bf-cmd__sep{
  width:1px;height:24px;background:rgba(255,255,255,0.06);
  margin:0 12px;flex-shrink:0;
}
.bf-cmd__ctrl{display:flex;align-items:center;gap:6px}
.bf-cmd__ctrl-label{
  font-family:'Sora',sans-serif;font-size:9px;font-weight:700;
  color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;
  white-space:nowrap;
}
.bf-cmd__days{display:flex;gap:4px}
.bf-cmd__day-pill{
  display:flex;flex-direction:column;align-items:center;
  padding:5px 14px;border-radius:8px;text-decoration:none;
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  transition:all .15s;cursor:pointer;
}
.bf-cmd__day-pill:hover{
  border-color:rgba(255,255,255,0.15);background:rgba(255,255,255,0.06);
}
.bf-cmd__day-pill.active{
  background:rgba(0,255,136,0.1);border-color:rgba(0,255,136,0.25);
}
.bf-cmd__day-name{
  font-family:'Sora',sans-serif;font-size:10px;font-weight:700;
  color:rgba(255,255,255,0.55);line-height:1.2;
}
.bf-cmd__day-pill.active .bf-cmd__day-name{color:rgba(0,255,136,0.9)}
.bf-cmd__day-date{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:8px;font-weight:500;
  color:rgba(255,255,255,0.3);line-height:1.2;
}
.bf-cmd__day-pill.active .bf-cmd__day-date{color:rgba(0,255,136,0.5)}
.bf-cmd__stat{
  display:flex;border-radius:8px;overflow:hidden;
  border:1px solid rgba(255,255,255,0.10);
}
.bf-cmd__stat-btn{
  background:rgba(255,255,255,0.04);border:none;
  color:var(--text-muted);
  font-family:'Sora',sans-serif;font-size:8px;font-weight:700;
  padding:8px 14px;cursor:pointer;transition:all .15s;
  letter-spacing:.3px;
}
.bf-cmd__stat-btn:first-child{border-right:1px solid rgba(255,255,255,0.10)}
.bf-cmd__stat-btn.active{
  background:rgba(0,255,136,0.12);color:rgba(0,255,136,0.9);
}
.bf-cmd__stat-btn:hover:not(.active){
  background:rgba(255,255,255,0.06);color:var(--text-dim);
}
.bf-cmd__populate{
  display:flex;align-items:center;gap:5px;
  padding:8px 14px;
  font-family:'Sora',sans-serif;font-size:11px;font-weight:700;
  color:rgba(255,255,255,0.7);
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.10);border-radius:8px;
  cursor:pointer;transition:all .15s;letter-spacing:.2px;
}
.bf-cmd__populate:hover{
  background:rgba(0,255,136,0.08);
  border-color:rgba(0,255,136,0.2);
  color:rgba(0,255,136,0.9);
}
.bf-cmd__populate svg{width:13px;height:13px}
.bf-cmd__leagues-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 18px 12px;border-top:1px solid rgba(255,255,255,0.05);
  padding-top:10px;gap:12px;
}
.bf-cmd__leagues{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  flex:1;min-width:0;
}
.bf-cmd__leagues-label{
  font-family:'Sora',sans-serif;font-size:7px;font-weight:700;
  color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;
  margin-right:2px;flex-shrink:0;
}
.bf-league-pill{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  border-radius:20px;color:rgba(255,255,255,0.55);
  font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:500;
  padding:4px 12px;cursor:pointer;transition:all .15s;white-space:nowrap;
}
.bf-league-pill:hover{border-color:rgba(0,255,136,0.2);color:rgba(255,255,255,0.7)}
.bf-league-pill.active{
  background:rgba(0,255,136,0.1);border-color:rgba(0,255,136,0.25);
  color:rgba(0,255,136,0.9);
}

/* Fixture toggle (right side of leagues row) */
.bf-cmd__fixtures-toggle{
  display:flex;align-items:center;gap:6px;
  padding:5px 12px;cursor:pointer;user-select:none;flex-shrink:0;
  background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);
  border-radius:8px;transition:all .15s;
}
.bf-cmd__fixtures-toggle:hover{
  border-color:rgba(255,255,255,0.15);background:rgba(255,255,255,0.05);
}
.bf-cmd__fixtures-icon{width:13px;height:13px;color:rgba(255,255,255,0.4)}
.bf-cmd__fixtures-label{
  font-family:'Sora',sans-serif;font-size:10px;font-weight:600;
  color:rgba(255,255,255,0.55);
}
.bf-cmd__fixtures-badge{
  font-family:'Sora',sans-serif;font-size:9px;font-weight:700;
  background:rgba(0,255,136,0.1);color:rgba(0,255,136,0.8);
  border-radius:10px;padding:1px 7px;
}
.bf-cmd__fixtures-chevron{
  width:12px;height:12px;color:rgba(255,255,255,0.35);
  transition:transform 0.2s;
}
.bf-cmd__fixtures-chevron.open{transform:rotate(180deg)}
.bf-fixture-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:12px;margin-top:6px;max-height:240px;overflow-y:auto;
  padding:0 18px 12px;
}
.bf-fixture-grid::-webkit-scrollbar{width:4px}
.bf-fixture-grid::-webkit-scrollbar-track{background:transparent}
.bf-fixture-grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:2px}
.bf-fixture-league-group{display:flex;flex-direction:column;gap:4px}
.bf-fixture-league-name{
  font-family:'Sora',sans-serif;font-size:8px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.5px;
  color:rgba(0,255,136,0.5);padding-bottom:2px;
  border-bottom:1px solid rgba(255,255,255,0.04);margin-bottom:2px;
}
.bf-fixture-check{
  display:flex;align-items:center;gap:6px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;
  color:rgba(255,255,255,0.6);cursor:pointer;
}
.bf-fixture-check input[type="checkbox"]{
  accent-color:rgba(0,255,136,0.8);width:14px;height:14px;
}
.bf-fixture-check__time{color:rgba(255,255,255,0.35);font-size:10px}

/* ── Filter Bar (collapsible, expanded by default) ── */
.bf-fb{
  background:#1a1a1f;border:1px solid rgba(255,255,255,0.10);
  border-radius:14px;margin-bottom:20px;overflow:hidden;
  transition:border-color .2s;
}
.bf-fb:hover{border-color:rgba(255,255,255,0.15)}
.bf-fb__trigger{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 18px;cursor:pointer;user-select:none;
  transition:background .15s;
}
.bf-fb__trigger:hover{background:rgba(255,255,255,0.01)}
.bf-fb__left{display:flex;align-items:center;gap:8px}
.bf-fb__right{display:flex;align-items:center;gap:8px;margin-left:auto}
.bf-fb__icon{width:14px;height:14px;color:var(--text-muted);flex-shrink:0}
.bf-fb__title{
  font-family:'Sora',sans-serif;font-size:11px;font-weight:600;
  color:rgba(255,255,255,0.65);
}
.bf-fb__pills{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}
.bf-fb__sep{
  width:1px;height:16px;background:rgba(255,255,255,0.08);
  margin:0 6px;flex-shrink:0;
}
.bf-fb__secondary-controls{
  display:flex;align-items:center;gap:6px;
}
.bf-fb__ctrl-label{
  font-family:'Sora',sans-serif;font-size:9px;font-weight:700;
  color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:.8px;
  white-space:nowrap;
}
/* Odds-only toggle */
.bf-odds-toggle{
  display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none;
}
.bf-odds-toggle__check{
  width:14px;height:14px;border-radius:4px;flex-shrink:0;
  border:1.5px solid rgba(255,255,255,0.18);
  background:rgba(255,255,255,0.03);
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.bf-odds-toggle__check.active{
  background:rgba(0,255,136,0.15);border-color:rgba(0,255,136,0.5);
}
.bf-odds-toggle__check.active::after{
  content:'';display:block;width:6px;height:6px;border-radius:1.5px;
  background:rgba(0,255,136,0.8);
}
.bf-odds-toggle__label{
  font-family:'Sora',sans-serif;font-size:8px;font-weight:700;
  color:rgba(255,255,255,0.4);letter-spacing:.3px;white-space:nowrap;
}

.bf-filter-pill{
  background:rgba(0,255,136,0.1);border-radius:10px;
  padding:2px 8px;font-family:'Sora',sans-serif;font-size:8px;font-weight:700;
  color:rgba(0,255,136,0.8);letter-spacing:.2px;
}
.bf-fb__toggle{
  display:flex;align-items:center;gap:4px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:10px;color:rgba(255,255,255,0.4);
}
.bf-fb__chevron{width:14px;height:14px;transition:transform .25s ease}
.bf-fb.open .bf-fb__chevron{transform:rotate(180deg)}
.bf-fb__expand-text{display:inline}
.bf-fb__collapse-text{display:none}
.bf-fb.open .bf-fb__expand-text{display:none}
.bf-fb.open .bf-fb__collapse-text{display:inline}
.bf-fb__body{display:none;padding:0 18px 16px}
.bf-fb.open .bf-fb__body{display:block}

/* Presets row */
.bf-fb__presets{display:flex;align-items:center;gap:6px;margin-bottom:10px}
.bf-fb__preset{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  border-radius:6px;color:rgba(255,255,255,0.6);
  font-family:'Sora',sans-serif;font-size:9px;font-weight:600;
  padding:5px 11px;cursor:pointer;transition:all .15s;
}
.bf-fb__preset:hover{
  border-color:rgba(0,255,136,0.2);color:rgba(255,255,255,0.85);
  background:rgba(0,255,136,0.04);
}
.bf-fb__reset{
  margin-left:auto;display:flex;align-items:center;
  background:none;border:1px solid rgba(255,255,255,0.08);border-radius:6px;
  color:rgba(255,255,255,0.4);cursor:pointer;padding:4px 6px;transition:all .15s;
}
.bf-fb__reset:hover{border-color:rgba(255,255,255,0.15);color:rgba(255,255,255,0.6)}
.bf-fb__reset svg{width:14px;height:14px}
.bf-fb__div{border-top:1px solid rgba(255,255,255,0.06);margin:0 0 12px}

/* Filter grid (4 columns per row) */
.bf-fg{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.bf-fg + .bf-fb__div{margin-top:14px}

/* Each filter cell */
.bf-fc{padding:0 16px;border-right:1px solid rgba(255,255,255,0.04)}
.bf-fc:first-child{padding-left:0}
.bf-fc:last-child{padding-right:0;border-right:none}
.bf-fc__top{
  display:flex;align-items:center;gap:6px;
  margin-bottom:8px;min-height:22px;
}
.bf-fc__label{
  font-family:'Sora',sans-serif;font-size:8px;font-weight:700;
  color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;
  flex-shrink:0;white-space:nowrap;
}
.bf-fc__val{
  font-family:'Sora',sans-serif;font-size:9px;font-weight:700;
  color:var(--text-dim);margin-left:auto;white-space:nowrap;
  transition:color .15s;
}
.bf-fc__val.active{color:rgba(0,255,136,0.9)}

/* Segment toggles (threshold, pctile/rate) — matches .bf-cmd__stat style */
.bf-seg{
  display:flex;border-radius:8px;overflow:hidden;
  border:1px solid rgba(255,255,255,0.10);flex-shrink:0;
}
.bf-seg__btn{
  background:rgba(255,255,255,0.04);border:none;
  color:rgba(255,255,255,0.5);
  font-family:'Sora',sans-serif;font-size:8px;font-weight:700;
  padding:6px 12px;cursor:pointer;transition:all .15s;
  letter-spacing:.3px;border-right:1px solid rgba(255,255,255,0.10);
}
.bf-seg__btn:last-child{border-right:none}
.bf-seg__btn.active{
  background:rgba(0,255,136,0.12);color:rgba(0,255,136,0.9);
}
.bf-seg__btn:hover:not(.active){
  background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.7);
}

/* ── Dual range slider (matches ft-dual from v3_fixture_analysis) ── */
.bf-dual{position:relative;height:4px;margin:4px 0 2px}
.bf-dual__track{position:absolute;top:50%;left:0;right:0;
  height:3px;transform:translateY(-50%);background:rgba(255,255,255,0.06);border-radius:1.5px}
.bf-dual__fill{position:absolute;height:100%;
  background:rgba(0,255,136,0.25);border-radius:1.5px;transition:left .05s,right .05s}
.bf-dual__center{position:absolute;top:50%;transform:translateY(-50%);
  width:1px;height:10px;background:rgba(255,255,255,0.15);z-index:1;pointer-events:none}
.bf-dual__input{-webkit-appearance:none;appearance:none;
  position:absolute;top:0;left:0;width:100%;height:100%;
  background:transparent;pointer-events:none;margin:0}
.bf-dual__input::-webkit-slider-thumb{-webkit-appearance:none;
  width:11px;height:11px;border-radius:50%;background:rgba(0,255,136,0.8);cursor:grab;
  box-shadow:0 0 6px rgba(0,255,136,0.3),0 0 0 2px rgba(0,0,0,0.4);
  pointer-events:auto;position:relative;z-index:2}
.bf-dual__input::-moz-range-thumb{width:11px;height:11px;border-radius:50%;
  background:rgba(0,255,136,0.8);cursor:grab;border:none;
  box-shadow:0 0 6px rgba(0,255,136,0.3),0 0 0 2px rgba(0,0,0,0.4);
  pointer-events:auto}
.bf-dual__input:active::-webkit-slider-thumb{cursor:grabbing;transform:scale(1.2)}
.bf-dual__input:active::-moz-range-thumb{cursor:grabbing;transform:scale(1.2)}

/* ── Distribution dots on slider track ── */
.bf-dual__dots{position:absolute;top:50%;left:0;right:0;height:0;
  pointer-events:none;z-index:1}
.bf-dist-dot{position:absolute;top:50%;transform:translate(-50%,-50%);
  width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,0.18)}

/* ── Tick marks under sliders ── */
.bf-tk{
  display:flex;justify-content:space-between;
  padding:0 1px;margin-top:10px;
}
.bf-tk__item{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  min-width:0;
}
.bf-tk__dot{width:4px;height:4px;border-radius:50%;flex-shrink:0}
.bf-tk__dot--red{background:#ff6b6b}
.bf-tk__dot--amber{background:#ffb432}
.bf-tk__dot--green{background:#3ddc97}
.bf-tk__dot--glow{background:#00ff88}
.bf-tk__text{
  font-family:'Sora',sans-serif;font-size:7px;font-weight:600;
  color:#ffffff85;opacity:.55;white-space:nowrap;
  letter-spacing:.2px;
}
/* Positioned tick marks (for non-linear scales like odds) */
.bf-tk--positioned{
  position:relative;height:20px;display:block;
  margin-top:10px;padding:0;
}
.bf-tk--positioned .bf-tk__item{
  position:absolute;transform:translateX(-50%);
}

/* ── Stats bar (above card grid) ── */
.bf-stats-bar{
  display:flex;align-items:center;gap:6px;
  margin-bottom:10px;
}

/* ── Card Grid ── */
.bf-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
}
@media (max-width: 1919px) { .bf-grid { grid-template-columns: repeat(5, 1fr); } }
@media (max-width: 1599px) { .bf-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 1199px) { .bf-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 899px) { .bf-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 599px) { .bf-grid { grid-template-columns: 1fr; } }

.bf-no-match {
  grid-column: 1 / -1;
  text-align: center;
  padding: 48px 20px;
  color: rgba(255,255,255,0.4);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
}
.bf-no-match svg {
  display: block;
  margin: 0 auto 8px;
  opacity: 0.3;
}

/* ── Animations ── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ── Shared Metric Bars ── */
.met{display:flex;align-items:center;gap:6px}
.met__label{
  font-family:'Sora',sans-serif;font-size:8px;font-weight:600;
  color:rgba(255,255,255,0.4);width:58px;text-align:right;flex-shrink:0;
  text-transform:uppercase;letter-spacing:.3px;
}
.met__bar{flex:1;height:5px;background:rgba(255,255,255,0.04);border-radius:3px;overflow:hidden}
.met__fill{height:100%;border-radius:3px;transition:width .4s ease}
.met__val{
  font-family:'Sora',sans-serif;font-size:10px;font-weight:700;
  width:32px;text-align:right;flex-shrink:0;
}
.met__val sup{font-size:7px;font-weight:500}

/* ── Player Card (Version A — Signal Strength) ── */
.va-card{
  background:#1a1a1f;border:1px solid rgba(255,255,255,0.10);
  border-radius:14px;overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,0.15);transition:border-color .2s,box-shadow .2s,transform .2s;
  position:relative;
  -webkit-user-drag:none;
}
/* Prevent native drag on card elements (images, links) */
.va-card img,.va-card a{-webkit-user-drag:none}
/* Initial load animation — added by JS, not on Turbo replace */
.va-card--enter{animation:fadeInUp .4s ease both}
/* Turbo-replaced card: smooth crossfade instead of flash */
.va-card--replaced{animation:none !important;opacity:0;transition:opacity .3s ease}
.va-card--replaced.va-card--visible{opacity:1}
.va-card:hover{border-color:rgba(255,255,255,0.15);transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,0.25)}


/* Card body */
.va-card__body{padding:16px;display:flex;flex-direction:column;gap:12px}

/* Player identity */
.va-card__identity{min-width:0}
.va-card__fixture{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:9px;
  color:rgba(255,255,255,0.4);margin-bottom:4px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.va-card__name-row{
  display:flex;align-items:center;gap:8px;margin-bottom:2px;
}
.va-card__avatar{
  width:28px;height:28px;border-radius:50%;overflow:hidden;
  background:rgba(255,255,255,0.04);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.va-card__avatar img{width:100%;height:100%;object-fit:cover}
.va-card__avatar-fallback{
  font-family:'Sora',sans-serif;font-size:9px;font-weight:800;
  color:rgba(255,255,255,0.25);
}
.va-card__name{
  font-family:'Sora',sans-serif;font-size:14px;font-weight:800;
  color:rgba(255,255,255,0.95);letter-spacing:-.3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.va-card__meta{
  font-size:11px;color:rgba(255,255,255,0.4);margin-top:1px;
  display:flex;align-items:center;gap:6px;
}
.va-card__pos-tag{
  font-family:'Sora',sans-serif;font-size:8px;font-weight:700;
  color:#f97316;background:rgba(249,115,22,0.1);
  padding:1px 5px;border-radius:3px;
}

/* Win rate display */
.va-card__winrate{
  display:flex;align-items:baseline;gap:4px;
  padding:8px 12px;background:rgba(255,255,255,0.02);
  border-radius:8px;border:1px solid rgba(255,255,255,0.05);
}
.va-card__winrate-num{
  font-family:'Sora',sans-serif;font-size:28px;font-weight:800;
  line-height:1;letter-spacing:-1px;
}
.va-card__winrate-pct{
  font-family:'Sora',sans-serif;font-size:14px;font-weight:700;
  opacity:.6;
}
.va-card__winrate-right{
  display:flex;flex-direction:column;align-items:flex-end;gap:2px;
  margin-left:auto;
}
.va-card__winrate-sample{
  font-family:'Sora',sans-serif;font-size:8px;font-weight:600;
  color:rgba(255,255,255,0.25);letter-spacing:.3px;
}
.va-card__winrate-label{
  font-family:'Sora',sans-serif;font-size:9px;font-weight:600;
  color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:.5px;
}

/* Metrics */
.va-card__metrics{display:flex;flex-direction:column;gap:4px}

/* Edge grid (3 values) */
.va-card__edge-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:6px;
  padding-top:8px;border-top:1px solid rgba(255,255,255,0.05);
}
.va-edge-cell{text-align:center}
.va-edge-cell__label{
  font-family:'Sora',sans-serif;font-size:7px;font-weight:700;
  color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;
  display:block;margin-bottom:2px;
}
.va-edge-cell__val{
  font-family:'Sora',sans-serif;font-size:14px;font-weight:800;line-height:1;
}

/* Verdict */
.va-card__verdict{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:9px;
  color:rgba(255,255,255,0.48);line-height:1.4;
  padding:6px 10px;margin-top:6px;
  background:rgba(255,255,255,0.02);
  border-left:2px solid rgba(255,255,255,0.06);
  border-radius:0 6px 6px 0;font-style:italic;
  height:52px;overflow:hidden;
  display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;
}
.va-card__verdict[title]:hover{cursor:help}

/* Odds comparison (ours vs bookie) */
.va-card__odds-compare{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 10px;background:rgba(255,255,255,0.02);border-radius:8px;
  border:1px solid rgba(255,255,255,0.04);
}
.va-odds__side{display:flex;align-items:baseline;gap:5px;min-width:0}
.va-odds__side--right{justify-content:flex-end}
.va-odds__side-label{
  font-family:'Sora',sans-serif;font-size:7px;font-weight:700;
  color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:.5px;
  flex-shrink:0;
}
.va-odds__side-frac{
  font-family:'Sora',sans-serif;font-size:15px;font-weight:800;
  color:rgba(0,255,136,0.8);line-height:1;
}
.va-odds__side--right .va-odds__side-frac{color:rgba(255,180,50,0.8)}
.va-odds__side-prob{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:10px;font-weight:600;
  color:rgba(255,255,255,0.35);
}
.va-odds__vs{
  font-family:'Sora',sans-serif;font-size:8px;font-weight:600;
  color:rgba(255,255,255,0.15);text-transform:uppercase;flex-shrink:0;
  padding:0 4px;
}

/* ── Legend ── */
.bf-legend{
  display:flex;align-items:center;gap:16px;
  padding:8px 0;margin-bottom:8px;
}
.bf-legend__item{display:flex;align-items:center;gap:5px}
.bf-legend__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.bf-legend__dot--green{background:rgba(0,255,136,0.7)}
.bf-legend__dot--amber{background:rgba(255,180,50,0.6)}
.bf-legend__dot--red{background:rgba(255,107,107,0.5)}
.bf-legend__dot--grey{background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.15)}
.bf-legend__text{
  font-family:'Sora',sans-serif;font-size:9px;font-weight:600;
  color:rgba(255,255,255,0.4);letter-spacing:.2px;
}

/* Sample size tooltip */
.va-sample-tip{
  position:absolute;left:50%;bottom:calc(100% + 6px);transform:translateX(-50%);
  background:#2a2a32;border:1px solid rgba(255,255,255,0.12);border-radius:6px;
  padding:5px 10px;white-space:nowrap;z-index:20;
  font-family:'Sora',sans-serif;font-size:9px;font-weight:600;
  color:rgba(255,180,50,0.9);letter-spacing:.2px;
  box-shadow:0 4px 12px rgba(0,0,0,0.3);
  pointer-events:none;animation:fadeIn .15s ease;
}
.va-sample-tip::after{
  content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:4px solid transparent;border-top-color:#2a2a32;
}

/* Open fixture button — hover-only, top-right corner */
.va-card__open-btn{
  position:absolute;top:8px;right:8px;z-index:5;
  display:flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:6px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);
  color:rgba(255,255,255,0.35);text-decoration:none;
  opacity:0;transition:all .15s;cursor:pointer;
}
.va-card:hover .va-card__open-btn{opacity:1}
.va-card__open-btn:hover{background:rgba(0,255,136,0.1);border-color:rgba(0,255,136,0.2);color:rgba(0,255,136,0.9)}
.va-card__open-btn svg{width:11px;height:11px}

/* Update overlay (shown during Turbo stream replacement) */
.va-card__update-overlay{
  position:absolute;inset:0;z-index:10;
  background:rgba(19,19,22,0.5);backdrop-filter:blur(2px);
  display:flex;align-items:center;justify-content:center;
  border-radius:14px;
  animation:overlayIn .2s ease both;
}
.va-card__update-overlay span{
  font-family:'Sora',sans-serif;font-size:10px;font-weight:600;
  color:rgba(0,255,136,0.7);letter-spacing:.3px;
}
@keyframes overlayIn{from{opacity:0}to{opacity:1}}

/* Missing metric placeholder */
.met--na .met__fill{background:none}
.met--na .met__label{opacity:.35}
.met--na .met__bar{background:rgba(255,255,255,0.02)}
.met--na .met__val{
  color:rgba(255,255,255,0.15);font-size:8px;font-weight:500;
  font-style:italic;
}

/* Stagger delays (only on initial load via .va-card--enter) */
.va-card--enter:nth-child(1){animation-delay:.03s}
.va-card--enter:nth-child(2){animation-delay:.06s}
.va-card--enter:nth-child(3){animation-delay:.09s}
.va-card--enter:nth-child(4){animation-delay:.12s}
.va-card--enter:nth-child(5){animation-delay:.15s}
.va-card--enter:nth-child(6){animation-delay:.18s}
.va-card--enter:nth-child(7){animation-delay:.21s}
.va-card--enter:nth-child(8){animation-delay:.24s}
.va-card--enter:nth-child(9){animation-delay:.27s}
.va-card--enter:nth-child(10){animation-delay:.30s}
.va-card--enter:nth-child(11){animation-delay:.33s}
.va-card--enter:nth-child(12){animation-delay:.36s}

/* ── Empty state ── */
.bf-empty {
  text-align: center;
  padding: 80px 20px;
}
.bf-empty__title {
  font-family: 'Sora', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: rgba(255,255,255,0.65);
  margin-bottom: 8px;
}
.bf-empty__text {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  color: rgba(255,255,255,0.4);
}

/* ── Populate Button ── */
.bf-populate-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,0.8);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s ease;
}
.bf-populate-btn:hover {
  background: rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.95);
  border-color: rgba(255,255,255,0.2);
}
.bf-populate-btn--lg {
  padding: 10px 24px;
  font-size: 14px;
  margin-top: 12px;
}

/* ── Flash Notice ── */
.bf-flash {
  padding: 10px 16px;
  margin-bottom: 16px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: rgba(0,255,136,0.9);
  background: rgba(0,255,136,0.08);
  border: 1px solid rgba(0,255,136,0.15);
  border-radius: 8px;
}

/* ── Responsive: Filter grid 4→2 cols ── */
@media (max-width: 1080px) {
  .bf-fg{grid-template-columns:repeat(2,1fr)}
  /* Remove right border on even (last-in-row) cells in 2-col layout */
  .bf-fc:nth-child(2n){border-right:none}
  /* Add top spacing between row pairs */
  .bf-fc:nth-child(n+3){padding-top:12px}
  /* Command strip: stack left/right */
  .bf-cmd__top{flex-wrap:wrap;gap:10px}
  .bf-cmd__right{flex-wrap:wrap;gap:8px}
  /* Presets row: wrap */
  .bf-fb__presets{flex-wrap:wrap}
  /* Leagues row: stack leagues full-width, fixtures below */
  .bf-cmd__leagues-row{flex-wrap:wrap}
  .bf-cmd__leagues{flex:1 1 100%;min-width:0}
  .bf-cmd__fixtures-toggle{margin-left:auto}
  /* Filter trigger: wrap secondary controls to new line */
  .bf-fb__left{flex-wrap:wrap;gap:8px}
  .bf-fb__sep--secondary{display:none}
  .bf-fb__secondary-controls{
    width:100%;padding-top:4px;
    border-top:1px solid rgba(255,255,255,0.04);
  }
}

@media (max-width: 768px) {
  .bf-cmd__top{padding:12px 14px}
  .bf-cmd__title{font-size:16px}
  .bf-cmd__days{flex-wrap:wrap;gap:4px}
  .bf-cmd__day-pill{padding:4px 10px}
  .bf-fb__body{padding:0 12px 14px}
  .bf-fc{padding:0 10px}
  .bf-fc:first-child{padding-left:0}
  .bf-cmd__leagues-row{padding:0 14px 10px;position:relative}
  /* League pills: smaller on mobile */
  .bf-league-pill{font-size:10px;padding:3px 9px}
  /* Fixture panel: dropdown overlay on mobile */
  .bf-cmd{position:relative;overflow:visible}
  .bf-fixture-grid{
    position:absolute;left:0;right:0;top:100%;z-index:30;
    background:#1a1a1f;border:1px solid rgba(255,255,255,0.12);
    border-radius:0 0 14px 14px;border-top:none;
    max-height:300px;overflow-y:auto;
    box-shadow:0 12px 32px rgba(0,0,0,0.4);
    margin-top:0;padding:12px 14px;
  }
}
