/* ═══════════════════════════════════════════════════════════
   SHARPLINE · Design System
   ═══════════════════════════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{height:100%;}

:root{
  /* Colors */
  --bg0:#04070e;
  --bg1:#080e1a;
  --bg2:#0e1826;
  --bg3:#141f33;
  --bg4:#1a2740;
  --bg5:#1f304d;

  --gold:#f0b429;
  --goldD:#c9921a;
  --goldBg:rgba(240,180,41,.08);
  --goldBorder:rgba(240,180,41,.2);

  --green:#22c55e;
  --greenD:#166534;
  --greenBg:rgba(34,197,94,.08);
  --greenBorder:rgba(34,197,94,.2);

  --red:#ef4444;
  --redD:#7f1d1d;
  --redBg:rgba(239,68,68,.08);
  --redBorder:rgba(239,68,68,.2);

  --blue:#60a5fa;
  --blueBg:rgba(96,165,250,.08);

  --purple:#a78bfa;
  --purpleBg:rgba(167,139,250,.08);

  --orange:#f97316;

  --t1:#f1f5f9;
  --t2:#94a3b8;
  --t3:#4d6380;
  --t4:#2a3a52;

  --border:rgba(255,255,255,.055);
  --borderMid:rgba(255,255,255,.1);
  --borderHov:rgba(96,165,250,.3);

  /* Layout */
  --sidebar-w:240px;
  --sidebar-w-sm:60px;
  --header-h:52px;
  --radius:8px;
  --radius-lg:12px;

  /* Transitions */
  --ease:.18s ease;
}

body{
  background:var(--bg0);
  color:var(--t1);
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  height:100%;
  overflow:hidden;
  line-height:1.5;
  font-size:13px;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--bg5);}

/* ═══════════════════════════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════════════════════════ */

#app{display:flex;height:100vh;overflow:hidden;}

/* ── SIDEBAR ── */
#sidebar{
  width:var(--sidebar-w);
  background:var(--bg1);
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  flex-shrink:0;
  transition:width var(--ease);
  overflow:hidden;
  z-index:50;
  position:relative;
}

#sidebar.collapsed{width:var(--sidebar-w-sm);}

.sb-logo{
  padding:16px 18px;
  display:flex;
  align-items:center;
  gap:10px;
  border-bottom:1px solid var(--border);
  min-height:var(--header-h);
  cursor:pointer;
}

.sb-logo .bolt{font-size:20px;flex-shrink:0;}
.sb-logo .wordmark{font-size:17px;font-weight:900;letter-spacing:-0.5px;white-space:nowrap;overflow:hidden;}
.sb-logo .wordmark .s1{color:var(--gold);}
.sb-logo .wordmark .s2{color:var(--t1);}
.sb-logo .wordmark .tag{font-size:8px;color:var(--t3);letter-spacing:2px;vertical-align:super;margin-left:3px;}

#sidebar.collapsed .sb-logo .wordmark{opacity:0;width:0;}

.sb-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:10px 0;}
.sb-nav::-webkit-scrollbar{display:none;}

.nav-section-label{
  font-size:9px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:var(--t4);
  padding:10px 18px 4px;
  white-space:nowrap;
  transition:opacity var(--ease);
}

#sidebar.collapsed .nav-section-label{opacity:0;}

.nav-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 18px;
  cursor:pointer;
  border-radius:0;
  color:var(--t2);
  font-size:13px;
  font-weight:600;
  border-left:2px solid transparent;
  transition:all var(--ease);
  white-space:nowrap;
  overflow:hidden;
  position:relative;
}

.nav-item:hover{background:var(--bg3);color:var(--t1);}
.nav-item.active{background:var(--goldBg);color:var(--gold);border-left-color:var(--gold);}

.nav-item .ico{font-size:17px;flex-shrink:0;width:20px;text-align:center;}
.nav-item .lbl{overflow:hidden;white-space:nowrap;}

.nav-item .badge-ct{
  margin-left:auto;
  background:var(--red);
  color:#fff;
  font-size:9px;
  font-weight:800;
  min-width:18px;
  height:18px;
  border-radius:9px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 4px;
  flex-shrink:0;
}

#sidebar.collapsed .nav-item .lbl,
#sidebar.collapsed .nav-item .badge-ct{display:none;}

.nav-div{height:1px;background:var(--border);margin:6px 10px;}

/* Sub-items */
.nav-sub{
  background:rgba(0,0,0,.15);
  overflow:hidden;
  max-height:0;
  transition:max-height .25s ease;
}
.nav-sub.open{max-height:200px;}
.nav-sub-item{
  padding:7px 18px 7px 50px;
  font-size:12px;
  color:var(--t3);
  cursor:pointer;
  transition:color var(--ease),background var(--ease);
  white-space:nowrap;
}
.nav-sub-item:hover{color:var(--t1);background:var(--bg3);}
.nav-sub-item.active{color:var(--gold);}

.sb-bottom{
  border-top:1px solid var(--border);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.install-btn{
  background:linear-gradient(135deg,var(--gold),var(--goldD));
  color:#000;
  border:none;
  border-radius:var(--radius);
  padding:9px 12px;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:8px;
  font-family:inherit;
  transition:opacity var(--ease);
  white-space:nowrap;
  overflow:hidden;
}

.install-btn:hover{opacity:.85;}
#sidebar.collapsed .install-btn .lbl{display:none;}

/* ── MAIN AREA ── */
#main{
  flex:1;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  min-width:0;
}

/* ── TOP HEADER ── */
#topbar{
  background:var(--bg1);
  border-bottom:1px solid var(--border);
  height:var(--header-h);
  display:flex;
  align-items:center;
  padding:0 20px;
  gap:14px;
  flex-shrink:0;
  z-index:40;
}

#topbar .pg-title{font-size:16px;font-weight:800;color:var(--t1);}
#topbar .pg-sub{font-size:11px;color:var(--t3);margin-top:1px;}

.topbar-spacer{flex:1;}

.top-search{
  background:var(--bg3);
  border:1px solid var(--border);
  color:var(--t1);
  border-radius:var(--radius);
  padding:7px 12px;
  font-size:12px;
  outline:none;
  width:200px;
  font-family:inherit;
  transition:border-color var(--ease);
}
.top-search::placeholder{color:var(--t3);}
.top-search:focus{border-color:var(--borderHov);}

.topbar-pill{
  display:flex;
  align-items:center;
  gap:6px;
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:20px;
  padding:4px 12px;
  font-size:11px;
  font-weight:700;
  color:var(--t2);
  white-space:nowrap;
}

.live-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--red);
  animation:pulse 1.6s ease-in-out infinite;
}

@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(.8);}}

.topbar-btn{
  background:none;
  border:1px solid var(--border);
  color:var(--t2);
  border-radius:var(--radius);
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:16px;
  transition:all var(--ease);
}
.topbar-btn:hover{background:var(--bg3);color:var(--t1);border-color:var(--borderMid);}

/* ── CONTENT ── */
#content{
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
}

.section{display:none;padding:20px;animation:fadeUp .2s ease;}
.section.active{display:block;}

@keyframes fadeUp{from{opacity:0;transform:translateY(5px);}to{opacity:1;transform:translateY(0);}}

/* ═══════════════════════════════════════════════════════════
   COMPONENTS
   ═══════════════════════════════════════════════════════════ */

/* ── PAGE HEADER ── */
.ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px;}
.ph-left h2{font-size:18px;font-weight:800;}
.ph-left p{font-size:11.5px;color:var(--t3);margin-top:3px;}
.ph-right{display:flex;gap:8px;align-items:center;}

/* ── STATS ROW ── */
.kpi-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:18px;}
.kpi{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:14px 16px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.kpi.gold{border-color:var(--goldBorder);background:var(--goldBg);}
.kpi.green{border-color:var(--greenBorder);background:var(--greenBg);}
.kpi.red{border-color:var(--redBorder);background:var(--redBg);}
.kpi-val{font-size:26px;font-weight:900;line-height:1;color:var(--t1);}
.kpi.gold .kpi-val{color:var(--gold);}
.kpi.green .kpi-val{color:var(--green);}
.kpi.red .kpi-val{color:var(--red);}
.kpi-lbl{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.7px;font-weight:700;}
.kpi-delta{font-size:11px;font-weight:700;margin-top:4px;}
.kpi-delta.up{color:var(--green);}
.kpi-delta.down{color:var(--red);}

/* ── CARDS ── */
.card{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
}

.card-hdr{
  padding:12px 16px;
  background:var(--bg3);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.card-title{font-size:13px;font-weight:800;color:var(--t1);display:flex;align-items:center;gap:8px;}
.card-body{padding:16px;}

/* ── GAME CARDS ── */
.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:12px;}

.gc{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  cursor:pointer;
  transition:border-color var(--ease),transform var(--ease),box-shadow var(--ease);
}
.gc:hover{border-color:var(--borderHov);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3);}
.gc.sharp{border-color:rgba(240,180,41,.35);}
.gc.value{border-color:rgba(34,197,94,.25);}

.gc-top{
  background:var(--bg3);
  padding:7px 12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid var(--border);
}

.gc-time{font-size:11px;color:var(--t3);font-weight:600;}
.gc-badges{display:flex;gap:5px;}

.badge{
  padding:2px 7px;
  border-radius:3px;
  font-size:9.5px;
  font-weight:800;
  letter-spacing:.4px;
  white-space:nowrap;
}
.b-sharp{background:var(--goldBg);color:var(--gold);border:1px solid var(--goldBorder);}
.b-val{background:var(--greenBg);color:var(--green);border:1px solid var(--greenBorder);}
.b-fade{background:var(--redBg);color:var(--red);border:1px solid var(--redBorder);}
.b-hot{background:var(--purpleBg);color:var(--purple);border:1px solid rgba(167,139,250,.2);}

.gc-body{padding:12px;}

.matchup{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.team{display:flex;flex-direction:column;gap:2px;}
.team.a{align-items:flex-start;}
.team.h{align-items:flex-end;}
.t-city{font-size:10px;color:var(--t3);}
.t-name{font-size:17px;font-weight:900;letter-spacing:-.3px;}
.t-rec{font-size:10px;color:var(--t4);}
.t-sp{font-size:10.5px;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;}
.at-sym{font-size:12px;color:var(--t4);font-weight:700;padding:0 6px;}

.odds-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:8px;}
.oc{background:var(--bg1);border-radius:6px;padding:7px 8px;text-align:center;}
.oc-lbl{font-size:9.5px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;}
.oc-vals{display:flex;justify-content:space-between;align-items:center;gap:4px;}
.ov{font-size:12px;font-weight:800;}
.ov-fav{color:var(--red);}
.ov-dog{color:var(--green);}
.ov-neu{color:var(--t2);}

.gc-signal{
  margin-top:8px;
  padding:7px 10px;
  border-radius:0 6px 6px 0;
  border-left:2px solid;
  font-size:11px;
  font-weight:600;
  line-height:1.4;
}
.gs-gold{background:var(--goldBg);border-color:var(--gold);color:var(--gold);}
.gs-green{background:var(--greenBg);border-color:var(--green);color:var(--green);}
.gs-red{background:var(--redBg);border-color:var(--red);color:var(--red);}

.gc-actions{display:flex;gap:6px;margin-top:8px;}
.gc-btn{
  flex:1;
  background:var(--bg3);
  border:1px solid var(--border);
  color:var(--t2);
  border-radius:6px;
  padding:5px 8px;
  font-size:11px;
  font-weight:700;
  cursor:pointer;
  font-family:inherit;
  transition:all var(--ease);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:4px;
}
.gc-btn:hover{background:var(--bg4);color:var(--t1);}
.gc-btn.parlay{border-color:var(--goldBorder);color:var(--gold);}
.gc-btn.parlay:hover{background:var(--goldBg);}

/* ── TABLES ── */
.tbl-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:14px;}
table{width:100%;border-collapse:collapse;font-size:12.5px;}
thead{background:var(--bg3);}
th{
  padding:10px 14px;text-align:left;
  font-size:9.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:.7px;
  color:var(--t3);
  border-bottom:1px solid var(--border);
  cursor:pointer;
  user-select:none;
  white-space:nowrap;
}
th:hover{color:var(--t1);}
th.c{text-align:center;}
th.r{text-align:right;}
td{
  padding:10px 14px;
  border-bottom:1px solid var(--border);
  color:var(--t2);
  vertical-align:middle;
}
tr:last-child td{border-bottom:none;}
tr:hover td{background:rgba(255,255,255,.015);}
td.tn{color:var(--t1);font-weight:700;}
td.c{text-align:center;}
td.r{text-align:right;}
td.lv{color:var(--blue);font-weight:800;font-size:14px;text-align:center;}
td.pos{color:var(--green);font-weight:700;}
td.neg{color:var(--red);font-weight:700;}
td.muted{color:var(--t3);}

/* ── VERDICT TAGS ── */
.vt{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:4px;font-size:10.5px;font-weight:800;letter-spacing:.2px;white-space:nowrap;}
.vt-hammer{background:var(--goldBg);color:var(--gold);border:1px solid var(--goldBorder);}
.vt-fade{background:var(--redBg);color:var(--red);border:1px solid var(--redBorder);}
.vt-value{background:var(--greenBg);color:var(--green);border:1px solid var(--greenBorder);}
.vt-pass{background:rgba(71,85,105,.1);color:var(--t3);border:1px solid rgba(71,85,105,.15);}
.vt-hot{background:var(--purpleBg);color:var(--purple);border:1px solid rgba(167,139,250,.2);}

/* Edge tags */
.et{font-size:10px;font-weight:800;padding:2px 7px;border-radius:3px;white-space:nowrap;}
.et-strong{background:rgba(240,180,41,.12);color:var(--gold);}
.et-mod{background:rgba(34,197,94,.1);color:var(--green);}
.et-none{background:rgba(71,85,105,.08);color:var(--t3);}

/* ── FILTER BAR ── */
.fb{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;align-items:center;}
.fi{
  background:var(--bg2);border:1px solid var(--border);
  color:var(--t1);padding:7px 12px;border-radius:var(--radius);
  font-size:12px;outline:none;font-family:inherit;
  transition:border-color var(--ease);
}
.fi::placeholder{color:var(--t3);}
.fi:focus,.fi:hover{border-color:var(--borderHov);}
.fb-btn{
  background:var(--bg2);border:1px solid var(--border);
  color:var(--t2);padding:7px 13px;border-radius:var(--radius);
  font-size:11.5px;font-weight:700;cursor:pointer;
  font-family:inherit;transition:all var(--ease);white-space:nowrap;
}
.fb-btn:hover,.fb-btn.on{background:var(--bg4);color:var(--t1);border-color:var(--borderMid);}
.fb-btn.on{border-color:var(--borderHov);}

/* ── SHARP SIGNAL CARDS ── */
.sig-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:12px;}
.sc{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;}
.sc-hdr{padding:11px 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.sc-hdr.hammer{background:linear-gradient(135deg,rgba(240,180,41,.07),transparent);}
.sc-hdr.fade{background:linear-gradient(135deg,rgba(239,68,68,.07),transparent);}
.sc-hdr.value{background:linear-gradient(135deg,rgba(34,197,94,.07),transparent);}
.sc-type{font-size:9.5px;font-weight:900;text-transform:uppercase;letter-spacing:1.5px;}
.hammer .sc-type{color:var(--gold);}
.fade .sc-type{color:var(--red);}
.value .sc-type{color:var(--green);}
.sc-odds{font-size:19px;font-weight:900;}
.hammer .sc-odds{color:var(--gold);}
.fade .sc-odds,.value .sc-odds{color:var(--green);}
.sc-body{padding:13px 14px;}
.sc-play{font-size:15px;font-weight:800;color:var(--t1);margin-bottom:8px;line-height:1.3;}
.sc-bullets{list-style:none;}
.sc-bullets li{font-size:11.5px;color:var(--t2);padding:3px 0 3px 13px;position:relative;}
.sc-bullets li::before{content:'›';position:absolute;left:0;color:var(--t3);}
.sc-footer{padding:9px 14px;background:var(--bg1);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.sc-unit{font-size:11px;font-weight:800;}
.hammer .sc-unit{color:var(--gold);}
.fade .sc-unit,.value .sc-unit{color:var(--green);}
.sc-conf{font-size:11px;color:var(--t3);}
.sc-add-btn{
  background:var(--bg3);border:1px solid var(--border);color:var(--t2);
  padding:4px 10px;border-radius:5px;font-size:11px;font-weight:700;
  cursor:pointer;font-family:inherit;transition:all var(--ease);
}
.sc-add-btn:hover{border-color:var(--goldBorder);color:var(--gold);background:var(--goldBg);}

/* ── BVP ── */
.bvp-layout{display:grid;grid-template-columns:270px 1fr;gap:14px;}
.bvp-ctrl{display:flex;flex-direction:column;gap:10px;}
.bvp-lookup{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;}
.bvp-lookup h3{font-size:13px;font-weight:800;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.sel-grp{margin-bottom:10px;}
.sel-lbl{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);margin-bottom:5px;}
.sel-full{
  width:100%;background:var(--bg1);border:1px solid var(--border);
  color:var(--t1);padding:8px 12px;border-radius:var(--radius);
  font-size:12px;outline:none;cursor:pointer;font-family:inherit;
  transition:border-color var(--ease);
}
.sel-full:focus,.sel-full:hover{border-color:var(--borderHov);}
.lookup-btn{
  width:100%;background:var(--gold);color:#000;border:none;
  padding:10px;border-radius:var(--radius);font-size:13px;
  font-weight:800;cursor:pointer;font-family:inherit;
  margin-top:6px;transition:opacity var(--ease);
}
.lookup-btn:hover{opacity:.85;}

.bvp-featured{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;}
.bvp-featured h3{font-size:12px;font-weight:800;margin-bottom:10px;color:var(--t1);}
.feat-item{
  padding:9px 0;border-bottom:1px solid var(--border);
  cursor:pointer;transition:opacity var(--ease);
}
.feat-item:last-child{border-bottom:none;padding-bottom:0;}
.feat-item:hover{opacity:.7;}
.feat-title{font-size:12.5px;font-weight:700;color:var(--t1);margin-bottom:2px;}
.feat-sub{font-size:11px;color:var(--t2);}
.feat-badge{display:inline-block;font-size:10px;font-weight:800;padding:1px 6px;border-radius:3px;margin-left:6px;}
.fb-green{background:var(--greenBg);color:var(--green);}
.fb-red{background:var(--redBg);color:var(--red);}

.bvp-results{display:flex;flex-direction:column;gap:12px;}

.bvp-empty{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:50px 20px;
  text-align:center;color:var(--t3);
}
.bvp-empty .big-ico{font-size:40px;margin-bottom:14px;}
.bvp-empty h3{font-size:15px;font-weight:700;color:var(--t2);margin-bottom:6px;}
.bvp-empty p{font-size:12px;line-height:1.6;}

.bvp-stats-row{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;}
.stat-box{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:12px 8px;text-align:center;
}
.stat-box.hi{border-color:var(--goldBorder);}
.sb-val{font-size:22px;font-weight:900;line-height:1;margin-bottom:3px;}
.sb-val.gold{color:var(--gold);}
.sb-val.green{color:var(--green);}
.sb-val.red{color:var(--red);}
.sb-val.blue{color:var(--blue);}
.sb-val.def{color:var(--t1);}
.sb-lbl{font-size:9.5px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;}

.ab-log{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;}
.ab-log-title{padding:11px 14px;background:var(--bg3);border-bottom:1px solid var(--border);font-size:12px;font-weight:800;}
.ab-hdr{
  display:grid;grid-template-columns:90px 55px 70px 1fr 70px;gap:8px;
  padding:7px 14px;background:var(--bg3);border-bottom:1px solid var(--border);
}
.ab-hdr span{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);}
.ab-hdr .c{text-align:center;}
.ab-row{
  display:grid;grid-template-columns:90px 55px 70px 1fr 70px;gap:8px;
  align-items:center;padding:9px 14px;
  border-bottom:1px solid var(--border);
  transition:background var(--ease);
}
.ab-row:last-child{border-bottom:none;}
.ab-row:hover{background:rgba(255,255,255,.015);}
.ab-date{font-size:11px;color:var(--t3);}
.ab-inn,.ab-ct{font-size:11px;color:var(--t2);text-align:center;}
.ab-note{font-size:11px;color:var(--t2);}
.ab-res{
  padding:2px 8px;border-radius:4px;font-size:11px;font-weight:800;
  text-align:center;white-space:nowrap;
}
.r-hr{background:var(--goldBg);color:var(--gold);}
.r-h{background:var(--greenBg);color:var(--green);}
.r-2b{background:var(--blueBg);color:var(--blue);}
.r-k{background:var(--redBg);color:var(--red);}
.r-bb{background:var(--purpleBg);color:var(--purple);}
.r-out{background:rgba(71,85,105,.1);color:var(--t3);}

/* Tendency bar */
.tendency-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg1);border-top:1px solid var(--border);}
.tend-lbl{font-size:11px;color:var(--t3);width:60px;}
.tend-bar{flex:1;height:6px;background:var(--bg4);border-radius:3px;overflow:hidden;}
.tend-fill{height:100%;border-radius:3px;transition:width .5s ease;}

/* ── BET TRACKER ── */
.tracker-grid{display:grid;grid-template-columns:1fr 320px;gap:14px;}
.bet-form-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;}
.bet-form-wrap h3{font-size:13px;font-weight:800;margin-bottom:14px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;}
.form-group{display:flex;flex-direction:column;gap:4px;}
.form-label{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--t3);}
.form-input{
  background:var(--bg1);border:1px solid var(--border);color:var(--t1);
  padding:8px 10px;border-radius:var(--radius);font-size:12px;
  font-family:inherit;outline:none;transition:border-color var(--ease);
  width:100%;
}
.form-input:focus,.form-input:hover{border-color:var(--borderHov);}
.form-input::placeholder{color:var(--t3);}
.submit-bet-btn{
  width:100%;background:var(--green);color:#000;border:none;
  border-radius:var(--radius);padding:10px;font-size:13px;
  font-weight:800;cursor:pointer;font-family:inherit;margin-top:8px;
  transition:opacity var(--ease);
}
.submit-bet-btn:hover{opacity:.85;}

.tracker-summary{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;}
.tracker-summary h3{font-size:13px;font-weight:800;margin-bottom:14px;}
.pnl-num{font-size:32px;font-weight:900;line-height:1;margin-bottom:4px;}
.pnl-num.pos{color:var(--green);}
.pnl-num.neg{color:var(--red);}
.pnl-num.zero{color:var(--t2);}
.record-row{display:flex;gap:10px;margin:12px 0;}
.rec-box{flex:1;background:var(--bg3);border-radius:var(--radius);padding:10px;text-align:center;}
.rec-val{font-size:18px;font-weight:800;}
.rec-val.w{color:var(--green);}
.rec-val.l{color:var(--red);}
.rec-val.p{color:var(--t2);}
.rec-lbl{font-size:9.5px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;}

.bets-list{max-height:400px;overflow-y:auto;}
.bet-item{
  padding:10px 14px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;
}
.bet-item:last-child{border-bottom:none;}
.bet-item-info{flex:1;min-width:0;}
.bet-play{font-size:12.5px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bet-meta{font-size:11px;color:var(--t3);margin-top:1px;}
.bet-status{padding:3px 9px;border-radius:4px;font-size:10.5px;font-weight:800;white-space:nowrap;}
.bs-pending{background:var(--blueBg);color:var(--blue);border:1px solid rgba(96,165,250,.2);}
.bs-won{background:var(--greenBg);color:var(--green);border:1px solid var(--greenBorder);}
.bs-lost{background:var(--redBg);color:var(--red);border:1px solid var(--redBorder);}
.bs-push{background:rgba(71,85,105,.1);color:var(--t2);border:1px solid rgba(71,85,105,.2);}
.bet-units{font-size:13px;font-weight:800;color:var(--t1);min-width:45px;text-align:right;}
.bet-action-btns{display:flex;gap:4px;}
.bet-act{
  background:none;border:1px solid var(--border);color:var(--t3);
  border-radius:4px;padding:3px 7px;font-size:10.5px;font-weight:700;
  cursor:pointer;font-family:inherit;transition:all var(--ease);
}
.bet-act.win:hover{border-color:var(--greenBorder);color:var(--green);background:var(--greenBg);}
.bet-act.lose:hover{border-color:var(--redBorder);color:var(--red);background:var(--redBg);}
.bet-act.del:hover{border-color:var(--redBorder);color:var(--red);}

/* ── PARLAY BUILDER ── */
.parlay-wrap{display:grid;grid-template-columns:1fr 280px;gap:14px;}
.parlay-legs{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);}
.parlay-leg{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;}
.parlay-leg:last-child{border-bottom:none;}
.pl-num{
  width:24px;height:24px;border-radius:50%;
  background:var(--goldBg);border:1px solid var(--goldBorder);
  color:var(--gold);font-size:11px;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.pl-info{flex:1;}
.pl-play{font-size:13px;font-weight:700;color:var(--t1);}
.pl-odds{font-size:11px;color:var(--t2);margin-top:2px;}
.pl-remove{
  background:none;border:none;color:var(--t3);cursor:pointer;
  font-size:16px;transition:color var(--ease);padding:4px;
}
.pl-remove:hover{color:var(--red);}
.parlay-empty{padding:40px;text-align:center;color:var(--t3);}

.parlay-summary{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;}
.parlay-summary h3{font-size:13px;font-weight:800;margin-bottom:14px;}
.parlay-odds-big{font-size:36px;font-weight:900;color:var(--gold);margin-bottom:4px;}
.parlay-odds-lbl{font-size:11px;color:var(--t3);margin-bottom:16px;}
.parlay-calc{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.pc-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);}
.pc-row:last-child{border-bottom:none;}
.pc-lbl{font-size:12px;color:var(--t2);}
.pc-val{font-size:13px;font-weight:700;color:var(--t1);}
.pc-val.green{color:var(--green);}
.parlay-wager-row{display:flex;gap:8px;margin-bottom:8px;}
.parlay-wager-input{flex:1;}
.add-parlay-btn{
  width:100%;background:var(--goldBg);border:1px solid var(--goldBorder);
  color:var(--gold);padding:10px;border-radius:var(--radius);
  font-size:13px;font-weight:800;cursor:pointer;font-family:inherit;
  transition:all var(--ease);
}
.add-parlay-btn:hover{background:var(--gold);color:#000;}
.clear-parlay-btn{
  width:100%;background:none;border:1px solid var(--border);
  color:var(--t3);padding:8px;border-radius:var(--radius);
  font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;
  margin-top:6px;transition:all var(--ease);
}
.clear-parlay-btn:hover{border-color:var(--redBorder);color:var(--red);}

/* ── LINE MOVEMENT ── */
.lm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:12px;}
.lmc{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;}
.lmc-teams{font-size:13px;font-weight:800;color:var(--t1);margin-bottom:10px;}
.lmc-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;}
.lmc-lbl{font-size:11px;color:var(--t3);}
.lmc-vals{display:flex;align-items:center;gap:8px;}
.lmc-open{font-size:12px;color:var(--t4);text-decoration:line-through;}
.lmc-cur{font-size:13px;font-weight:800;color:var(--t1);}
.lmc-arr{font-size:12px;}
.lmc-arr.up{color:var(--green);}
.lmc-arr.dn{color:var(--red);}
.move-tag{font-size:10px;font-weight:800;padding:2px 7px;border-radius:3px;}
.mt-sharp{background:var(--goldBg);color:var(--gold);}
.mt-steam{background:var(--redBg);color:var(--red);}
.mt-pub{background:rgba(71,85,105,.1);color:var(--t3);}
.lmc-note{font-size:10.5px;color:var(--t3);margin-top:8px;padding-top:8px;border-top:1px solid var(--border);line-height:1.5;}

/* ── PP SECTION ── */
.pp-bar{
  background:linear-gradient(135deg,var(--purpleBg),rgba(167,139,250,.02));
  border:1px solid rgba(167,139,250,.15);
  border-radius:var(--radius-lg);padding:14px 18px;
  margin-bottom:16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.pp-logo-big{font-size:22px;font-weight:900;color:var(--purple);}
.pp-bar-info{flex:1;}
.pp-bar-info h3{font-size:13px;font-weight:800;color:var(--t1);margin-bottom:3px;}
.pp-bar-info p{font-size:11.5px;color:var(--t2);}
.pp-key{display:flex;gap:16px;font-size:11px;flex-wrap:wrap;}
.pp-key-item{display:flex;align-items:center;gap:5px;}

/* ── SETTINGS ── */
.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;}
.settings-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;}
.settings-card h3{font-size:13px;font-weight:800;margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);}
.setting-row:last-child{border-bottom:none;}
.sr-label{font-size:13px;color:var(--t1);}
.sr-sub{font-size:11px;color:var(--t3);margin-top:2px;}
.toggle{
  width:42px;height:24px;border-radius:12px;border:none;cursor:pointer;
  position:relative;transition:background var(--ease);flex-shrink:0;
}
.toggle.on{background:var(--green);}
.toggle.off{background:var(--bg4);}
.toggle::after{
  content:'';position:absolute;top:3px;left:3px;
  width:18px;height:18px;border-radius:50%;background:#fff;
  transition:transform var(--ease);
}
.toggle.on::after{transform:translateX(18px);}
.save-settings-btn{
  width:100%;background:var(--blue);color:#000;border:none;
  border-radius:var(--radius);padding:10px;font-size:13px;
  font-weight:800;cursor:pointer;font-family:inherit;margin-top:8px;
  transition:opacity var(--ease);
}
.save-settings-btn:hover{opacity:.85;}

/* ── TOAST ── */
#toast{
  position:fixed;bottom:24px;right:24px;z-index:9999;
  display:flex;flex-direction:column;gap:8px;pointer-events:none;
}
.toast-item{
  background:var(--bg3);border:1px solid var(--border);
  border-radius:var(--radius);padding:10px 16px;
  display:flex;align-items:center;gap:10px;
  font-size:12.5px;font-weight:600;color:var(--t1);
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  animation:slideIn .25s ease;
  min-width:220px;max-width:300px;
}
.toast-item.success{border-left:3px solid var(--green);}
.toast-item.error{border-left:3px solid var(--red);}
.toast-item.info{border-left:3px solid var(--blue);}
@keyframes slideIn{from{opacity:0;transform:translateX(20px);}to{opacity:1;transform:translateX(0);}}

/* ── PARLAY DRAWER (slide-in bottom) ── */
#parlay-bar{
  position:fixed;bottom:0;left:var(--sidebar-w);right:0;
  background:var(--bg2);border-top:1px solid var(--goldBorder);
  padding:12px 20px;display:flex;align-items:center;gap:14px;
  transform:translateY(100%);transition:transform var(--ease);
  z-index:100;flex-wrap:wrap;
}
#parlay-bar.visible{transform:translateY(0);}
#parlay-bar.collapsed{width:var(--sidebar-w-sm);left:var(--sidebar-w-sm);}
.pb-title{font-size:12px;font-weight:800;color:var(--gold);white-space:nowrap;}
.pb-legs-preview{display:flex;gap:6px;flex:1;flex-wrap:wrap;overflow:hidden;}
.pb-leg{
  background:var(--goldBg);border:1px solid var(--goldBorder);
  border-radius:4px;padding:3px 8px;font-size:11px;color:var(--gold);
  font-weight:700;white-space:nowrap;max-width:160px;
  overflow:hidden;text-overflow:ellipsis;
}
.pb-odds{font-size:17px;font-weight:900;color:var(--gold);white-space:nowrap;}
.pb-btn{
  background:var(--gold);color:#000;border:none;
  border-radius:var(--radius);padding:8px 14px;
  font-size:12px;font-weight:800;cursor:pointer;font-family:inherit;
  white-space:nowrap;transition:opacity var(--ease);
}
.pb-btn:hover{opacity:.85;}
.pb-clear{
  background:none;border:1px solid var(--border);color:var(--t3);
  border-radius:var(--radius);padding:8px 12px;font-size:12px;
  font-weight:700;cursor:pointer;font-family:inherit;transition:all var(--ease);
}
.pb-clear:hover{color:var(--red);border-color:var(--redBorder);}

/* ── WEATHER WIDGET ── */
.weather-strip{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:10px 16px;margin-bottom:14px;
  display:flex;gap:20px;flex-wrap:wrap;align-items:center;
}
.w-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--t2);}
.w-game{font-weight:700;color:var(--t1);}
.w-alert{color:var(--orange);font-weight:700;}

/* ══ LIVE STATUS DOT ══ */
.live-pill{
  display:flex;align-items:center;gap:6px;
  background:var(--bg3);border:1px solid var(--border);
  border-radius:20px;padding:4px 10px;
}
.live-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.dot-live{background:var(--green);animation:pulse 1.6s ease-in-out infinite;}
.dot-spin{background:var(--gold);animation:pulse .6s ease-in-out infinite;}
.dot-err{background:var(--red);}
.dot-idle{background:var(--t4);}
.live-in-prog{
  background:var(--greenBg);color:var(--green);
  border:1px solid var(--greenBorder);
  border-radius:3px;padding:1px 6px;font-size:9.5px;font-weight:800;
  margin-left:4px;
}
.refresh-btn{flex-direction:column;gap:2px;width:42px;height:42px;font-size:14px;}

/* ══ LIVE / FINAL GAME CARDS ══ */
.gc-live{border-color:rgba(34,197,94,.4)!important;box-shadow:0 0 0 1px rgba(34,197,94,.15);}
.gc-live .gc-top{background:linear-gradient(135deg,rgba(34,197,94,.08),transparent);}
.gc-final{opacity:.65;}
.gc-final .gc-top{background:var(--bg1);}

.b-live{background:var(--greenBg);color:var(--green);border:1px solid var(--greenBorder);animation:pulse 1.5s ease-in-out infinite;}
.b-final{background:rgba(71,85,105,.1);color:var(--t3);border:1px solid rgba(71,85,105,.15);}
.b-move{background:rgba(240,180,41,.12);color:var(--gold);border:1px solid var(--goldBorder);}

.live-badge-sm{
  background:var(--green);color:#000;
  border-radius:3px;padding:1px 5px;
  font-size:9px;font-weight:900;letter-spacing:.5px;
  animation:pulse 1.5s ease-in-out infinite;
}

/* ══ MULTI-BOOK COMPARISON ROW ══ */
.book-compare{
  display:flex;gap:6px;flex-wrap:wrap;
  padding:7px 0 4px;border-top:1px solid var(--border);
  margin-top:6px;
}
.bc-item{
  display:flex;align-items:center;gap:3px;
  background:var(--bg1);border-radius:5px;
  padding:4px 7px;font-size:10.5px;
}
.bc-book{color:var(--t4);font-size:9px;font-weight:800;text-transform:uppercase;margin-right:3px;}
.bc-sep{color:var(--t4);font-size:10px;}
.bc-odds{font-weight:800;}

/* ══ LIVE LINE MOVEMENT CARD ══ */
.lmc-live{border-color:var(--goldBorder);background:linear-gradient(135deg,var(--goldBg),var(--bg2));}
.lmc-live-tag{
  font-size:9.5px;font-weight:900;color:var(--green);
  text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;
  animation:pulse 1.5s ease-in-out infinite;
}

/* ══ RESPONSIVE ══ */
@media(max-width:900px){
  :root{--sidebar-w:60px;}
  #sidebar .sb-logo .wordmark,
  #sidebar .nav-section-label,
  #sidebar .nav-item .lbl,
  #sidebar .nav-item .badge-ct,
  #sidebar .install-btn .lbl{display:none;}
  .bvp-layout{grid-template-columns:1fr;}
  .tracker-grid{grid-template-columns:1fr;}
  .parlay-wrap{grid-template-columns:1fr;}
  .bvp-stats-row{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:640px){
  .games-grid{grid-template-columns:1fr;}
  .sig-grid{grid-template-columns:1fr;}
  .lm-grid{grid-template-columns:1fr;}
  .kpi-row{grid-template-columns:repeat(2,1fr);}
  .ab-hdr,.ab-row{grid-template-columns:80px 45px 55px 1fr 65px;gap:5px;}
  #topbar .top-search{display:none;}
  .topbar-pill .date-str{display:none;}
}
