/* x8goal — shared styles */
:root {
  --blue:#1565c0; --blue2:#1976d2; --green:#2e7d32; --red:#c62828;
  --orange:#e65100; --gold:#f57f17; --purple:#6a1b9a;
  --text:#1a2540; --text2:#4a6080; --muted:#90a4b8;
  --border:#d8e3ee; --border2:#c5d5e5; --bg:#f0f4f8; --card:#fff;
  --odds-up:#1b5e20; --odds-dn:#b71c1c; --odds-n:#1565c0;
  --shadow:0 2px 12px rgba(21,101,192,.08);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Sarabun',sans-serif;background:var(--bg);color:var(--text);min-height:100vh}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:#e8eef5}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* ── HEADER ── */
.hdr{background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:sticky;top:0;z-index:100;height:54px;display:flex;align-items:center;padding:0 16px;gap:10px}
.logo{display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}
.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,#1565c0,#0d47a1);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(21,101,192,.3)}
.logo-text{font-family:'Kanit',sans-serif;font-weight:900;font-size:20px;color:var(--text)}
.logo-text b{color:var(--blue)}
.badge{font-size:10px;font-weight:800;padding:2px 8px;border-radius:5px;line-height:1.4}
.badge-live{background:var(--red);color:#fff}
.badge-admin{background:#37474f;color:#fff}
.badge-casino{background:var(--gold);color:#fff}
.hdr-nav{display:flex;gap:2px;margin-left:8px}
.nav-btn{background:none;border:none;color:var(--text2);font-family:'Sarabun',sans-serif;font-size:13px;padding:7px 12px;border-radius:7px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;font-weight:600;text-decoration:none}
.nav-btn:hover{background:#eef3fa;color:var(--text)}
.nav-btn.active{background:#e3ecfb;color:var(--blue);font-weight:700}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:8px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:6px;border:none;font-family:'Sarabun',sans-serif;font-weight:700;cursor:pointer;border-radius:7px;transition:all .2s;text-decoration:none}
.btn-sm{font-size:12px;padding:6px 14px}
.btn-md{font-size:13px;padding:8px 18px}
.btn-lg{font-size:15px;padding:13px 28px}
.btn-primary{background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;box-shadow:0 2px 8px rgba(21,101,192,.3)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 5px 16px rgba(21,101,192,.4)}
.btn-outline{background:none;border:1.5px solid var(--blue);color:var(--blue)}
.btn-outline:hover{background:var(--blue);color:#fff}
.btn-ghost{background:none;border:1.5px solid var(--border);color:var(--text2)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn-red{background:linear-gradient(135deg,#c62828,#b71c1c);color:#fff}
.btn-red:hover{transform:translateY(-1px)}
.btn-green{background:linear-gradient(135deg,#2e7d32,#1b5e20);color:#fff}
.btn-green:hover{transform:translateY(-1px)}
.btn-gold{background:#ff8f00;color:#fff;box-shadow:0 2px 8px rgba(255,143,0,.3)}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 5px 16px rgba(255,143,0,.4)}
.btn-full{width:100%;justify-content:center;padding:13px;font-size:14px;font-weight:800}

/* ── LIVE PILL ── */
.live-pill{background:#e8f5e9;border:1px solid #a5d6a7;border-radius:20px;padding:5px 12px;font-size:12px;color:var(--green);display:flex;align-items:center;gap:5px;font-weight:700;cursor:pointer}
.live-dot{width:7px;height:7px;background:var(--green);border-radius:50%;animation:pulse 1.2s infinite;flex-shrink:0}
.live-dot.red{background:var(--red)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ── LAYOUT ── */
.layout{display:flex;min-height:calc(100vh - 54px)}
.sbl{width:210px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);position:sticky;top:54px;height:calc(100vh - 54px);overflow-y:auto}
.main{flex:1;min-width:0}
.sbr{width:284px;flex-shrink:0;background:#fff;border-left:1px solid var(--border);position:sticky;top:54px;height:calc(100vh - 54px);overflow-y:auto;display:flex;flex-direction:column}

/* ── SIDEBAR MENU ── */
.menu-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;color:var(--text2);font-size:13px;font-weight:600;border-left:3px solid transparent;transition:all .2s;text-decoration:none}
.menu-item:hover{background:#eef3fa;color:var(--text)}
.menu-item.active{background:#e3ecfb;color:var(--blue);border-left-color:var(--blue);font-weight:700}
.menu-badge{margin-left:auto;background:var(--red);color:#fff;font-size:10px;font-weight:800;padding:1px 7px;border-radius:10px}
.menu-badge.blue{background:var(--blue)}
.menu-badge.green{background:var(--green)}
.menu-sec{padding:12px 14px 4px;font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px}

/* ── SECTION ── */
.section{background:#fff;border-bottom:6px solid var(--bg)}
.section-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 0}
.section-title{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:800;color:var(--text)}

/* ── BET TABS ── */
.bet-tabs{display:flex;gap:5px;padding:10px 12px 0;overflow-x:auto}
.bet-tab{padding:6px 14px;border-radius:20px;font-size:12px;cursor:pointer;white-space:nowrap;background:none;border:1.5px solid var(--border);font-family:'Sarabun',sans-serif;color:var(--text2);font-weight:600;display:flex;align-items:center;gap:6px;transition:all .2s}
.bet-tab.active{background:var(--blue);color:#fff;border-color:var(--blue);font-weight:800}
.bet-tab:hover:not(.active){background:#eef3fa;border-color:var(--blue);color:var(--blue)}

/* ── STATUS BADGES ── */
.st-live{background:#fee;color:var(--red);border:1px solid #ffcdd2;padding:2px 7px;border-radius:12px;font-size:11px;font-weight:800;display:inline-flex;align-items:center;gap:4px}
.st-up{background:#e3ecfb;color:var(--blue);border:1px solid #bbdefb;padding:2px 7px;border-radius:12px;font-size:11px;font-weight:800}
.st-fin{background:#e8f5e9;color:var(--green);border:1px solid #c8e6c9;padding:2px 7px;border-radius:12px;font-size:11px;font-weight:800}
.st-oth{background:#f3f4f6;color:var(--muted);border:1px solid var(--border);padding:2px 7px;border-radius:12px;font-size:11px;font-weight:800}

/* ── ODDS CELL ── */
.odds-cell{background:#f4f7fb;border:1px solid var(--border);border-radius:6px;padding:6px 8px;text-align:center;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:1px}
.odds-cell:hover{background:#e3ecfb;border-color:var(--blue)}
.odds-cell.selected{background:#daeaff;border-color:var(--blue)}
.odds-label{font-size:9px;color:var(--muted);font-weight:700;text-transform:uppercase}
.odds-val{font-size:13px;font-weight:800}
.odds-val.up{color:var(--odds-up)}.odds-val.dn{color:var(--odds-dn)}.odds-val.n{color:var(--odds-n)}
.odds-change{font-size:9px;font-weight:800}
.odds-change.up{color:var(--odds-up)}.odds-change.dn{color:var(--odds-dn)}

/* ── MATCH ROW ── */
.match-row{background:#fff;border-bottom:1px solid #eef3fa;padding:10px 12px;cursor:pointer;transition:background .2s;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}
.match-row:hover{background:#f4f8ff}
.match-row.disabled{opacity:.45;pointer-events:none;background:#fff8f8}
.team-side{display:flex;align-items:center;gap:8px}
.team-side.right{flex-direction:row-reverse}
.team-logo{width:28px;height:28px;object-fit:contain;flex-shrink:0}
.team-logo-ph{width:28px;height:28px;background:linear-gradient(135deg,#e8f0fe,#dbeafe);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;border:1px solid var(--border)}
.team-name-txt{font-size:12px;font-weight:700;color:var(--text);line-height:1.3}
.match-ctr{display:flex;flex-direction:column;align-items:center;gap:3px;min-width:90px}
.score-box{font-size:18px;font-weight:900;color:#fff;background:var(--blue);border-radius:8px;padding:2px 12px;font-family:'Kanit',sans-serif;letter-spacing:2px}
.score-box.live{background:var(--red);animation:scorePulse 2s infinite}
@keyframes scorePulse{0%,100%{box-shadow:0 0 0 0 rgba(198,40,40,.4)}50%{box-shadow:0 0 0 6px rgba(198,40,40,0)}}
.match-time-txt{font-size:10px;color:var(--muted);font-weight:700}
.disabled-lbl{font-size:9px;background:#fee;color:var(--red);padding:1px 6px;border-radius:3px;font-weight:800}
.odds-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:8px 12px;border-bottom:1px solid #eef3fa;background:#fafcff}
.odds-grid-6{grid-template-columns:repeat(6,1fr)}

/* ── BETSLIP ── */
.bs-tabs{display:flex;border-bottom:1px solid var(--border);background:#fafcff}
.bs-tab{flex:1;padding:13px;text-align:center;cursor:pointer;font-size:13px;color:var(--text2);border-bottom:2px solid transparent;font-weight:600;background:none;border-top:none;border-left:none;border-right:none;font-family:'Sarabun',sans-serif;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}
.bs-tab.active{color:var(--blue);border-bottom-color:var(--blue);background:#fff;font-weight:800}
.bs-count{background:var(--blue);color:#fff;font-size:10px;font-weight:800;padding:1px 6px;border-radius:10px}
.bs-body{flex:1;padding:12px;overflow-y:auto}
.bs-empty{text-align:center;padding:44px 16px;color:var(--muted)}
.bs-item{background:#f7f9fc;border-radius:9px;padding:10px;margin-bottom:8px;border:1px solid var(--border);position:relative;transition:all .2s}
.bs-item:hover{border-color:var(--blue)}
.bs-rm{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px}
.bs-rm:hover{color:var(--red)}
.stake-inp{width:100%;background:#f0f4f8;border:1.5px solid var(--border);color:var(--text);font-family:'Sarabun',sans-serif;font-size:14px;padding:9px 12px;border-radius:7px;outline:none;transition:all .2s}
.stake-inp:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(21,101,192,.1)}
.preset{background:#eef3fa;border:1px solid var(--border);color:var(--text2);font-size:11px;padding:4px 9px;border-radius:5px;cursor:pointer;font-weight:700;transition:all .2s;font-family:'Sarabun',sans-serif}
.preset:hover{background:var(--blue);border-color:var(--blue);color:#fff}

/* ── TICKER ── */
.ticker-wrap{background:#eaf1fa;border-bottom:1px solid var(--border);overflow:hidden;height:32px;display:flex;align-items:center}
.ticker-lbl{background:var(--red);color:#fff;font-size:11px;font-weight:800;padding:0 14px;height:100%;display:flex;align-items:center;gap:6px;flex-shrink:0;white-space:nowrap}
.ticker-scroll{flex:1;overflow:hidden}
.ticker-inner{display:flex;gap:36px;animation:tick 35s linear infinite;white-space:nowrap;align-items:center}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.tick-item{font-size:11px;color:var(--text2);display:flex;align-items:center;gap:7px;font-weight:600}
.tick-up{color:var(--odds-up);font-weight:800}.tick-dn{color:var(--odds-dn);font-weight:800}

/* ── DATE NAV ── */
.date-nav{background:#fff;border-bottom:1px solid var(--border);padding:8px 12px;display:flex;gap:6px;overflow-x:auto;align-items:center}
.date-btn{background:#f4f7fb;border:1px solid var(--border);border-radius:8px;padding:6px 14px;font-size:12px;font-weight:700;color:var(--text2);cursor:pointer;transition:all .2s;white-space:nowrap;font-family:'Sarabun',sans-serif}
.date-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}
.date-btn:hover:not(.active){border-color:var(--blue);color:var(--blue)}

/* ── SEARCH BAR ── */
.search-bar{display:flex;align-items:center;gap:9px;padding:10px 12px;border-bottom:1px solid var(--border);background:#fafcff}
.search-inp{flex:1;background:#f0f4f8;border:1px solid var(--border);color:var(--text);font-family:'Sarabun',sans-serif;font-size:12px;padding:7px 12px;border-radius:7px;outline:none;transition:all .2s}
.search-inp:focus{border-color:var(--blue);background:#fff}
.search-inp::placeholder{color:var(--muted)}
.toggle-sw{width:37px;height:21px;background:#d8e3ee;border-radius:11px;position:relative;cursor:pointer;border:1px solid var(--border2);transition:background .2s;flex-shrink:0}
.toggle-sw.on{background:var(--blue);border-color:var(--blue)}
.toggle-knob{width:15px;height:15px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle-sw.on .toggle-knob{transform:translateX(16px)}

/* ── LEAGUE HEADER ── */
.league-hdr{display:flex;align-items:center;gap:9px;padding:9px 12px;background:#eef3fa;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s;user-select:none}
.league-hdr:hover{background:#e3ecfb}
.league-logo-img{width:24px;height:24px;object-fit:contain;flex-shrink:0}
.league-count{margin-left:auto;background:var(--blue);color:#fff;font-size:10px;font-weight:800;padding:1px 7px;border-radius:4px}

/* ── PROMO BANNER ── */
.promo-banner{margin:10px 12px;border-radius:14px;overflow:hidden;cursor:pointer;position:relative;background:linear-gradient(135deg,#1565c0,#0d47a1);height:86px;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 4px 18px rgba(21,101,192,.3)}
.promo-banner:hover{transform:scale(1.01)}
.promo-btn{position:absolute;right:16px;background:#ff8f00;color:#fff;border:none;font-family:'Sarabun',sans-serif;font-size:12px;font-weight:800;padding:8px 18px;border-radius:7px;cursor:pointer}

/* ── TOGGLE ── */
.toggle-wrap{display:flex;align-items:center;gap:8px}
.toggle-big{width:46px;height:26px;background:#d8e3ee;border-radius:13px;position:relative;cursor:pointer;border:1px solid var(--border2);transition:all .25s;flex-shrink:0}
.toggle-big.on{background:var(--green);border-color:var(--green)}
.toggle-big-k{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .25s;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.toggle-big.on .toggle-big-k{transform:translateX(20px)}

/* ── API STATUS ── */
.api-status{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);font-weight:700;padding:0 4px}
.api-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.api-dot.ok{background:var(--green)}.api-dot.loading{background:var(--orange);animation:pulse 1s infinite}.api-dot.err{background:var(--red)}

/* ── CACHE STATUS BAR ── */
.cache-bar{background:#e3ecfb;border-bottom:1px solid var(--border);padding:6px 14px;display:flex;align-items:center;gap:10px;font-size:11px;font-weight:700;color:var(--blue);flex-wrap:wrap}
.cache-tag{background:#fff;border:1px solid var(--border);border-radius:5px;padding:2px 8px;font-size:11px;font-weight:800;color:var(--text2);display:flex;align-items:center;gap:4px}
.cache-tag.live{border-color:var(--red);color:var(--red)}
.cache-tag.fresh{border-color:var(--green);color:var(--green)}
.cache-tag.old{border-color:var(--orange);color:var(--orange)}
.cache-tag.api{border-color:var(--blue);color:var(--blue)}

/* ── MODAL ── */
.overlay{position:fixed;inset:0;background:rgba(21,101,192,.12);z-index:200;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(7px);opacity:0;pointer-events:none;transition:opacity .25s}
.overlay.open{opacity:1;pointer-events:all}
.modal{background:#fff;border:1px solid var(--border);box-shadow:0 24px 70px rgba(21,101,192,.2);border-radius:16px;width:420px;max-width:92vw;transform:translateY(-20px);transition:transform .25s;overflow:hidden}
.overlay.open .modal{transform:translateY(0)}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:17px 22px;border-bottom:1px solid var(--border);background:#fafcff}
.modal-title{font-size:16px;font-weight:900;color:var(--text);font-family:'Kanit',sans-serif}
.modal-close{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;transition:color .2s}
.modal-close:hover{color:var(--red)}
.modal-body{padding:22px}
.modal-tabs{display:flex;margin-bottom:22px;border-radius:9px;overflow:hidden;background:#f0f4f8;border:1px solid var(--border)}
.modal-tab{flex:1;padding:10px;text-align:center;cursor:pointer;font-size:13px;font-weight:800;color:var(--text2);background:none;border:none;font-family:'Sarabun',sans-serif;transition:all .2s}
.modal-tab.active{background:var(--blue);color:#fff}
.form-grp{margin-bottom:14px}
.form-lbl{display:block;font-size:12px;color:var(--text2);margin-bottom:5px;font-weight:800}
.form-inp{width:100%;background:#f4f7fb;border:1.5px solid var(--border);color:var(--text);font-family:'Sarabun',sans-serif;font-size:14px;padding:11px 14px;border-radius:8px;outline:none;transition:all .2s}
.form-inp:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(21,101,192,.1)}
.modal-footer{padding:17px 22px;border-top:1px solid var(--border);background:#fafcff}

/* ── TOAST ── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(100px);background:#fff;border:1.5px solid var(--border);color:var(--text);font-size:13px;padding:12px 22px;border-radius:11px;z-index:400;transition:transform .3s;box-shadow:0 8px 32px rgba(21,101,192,.15);display:flex;align-items:center;gap:9px;font-weight:700;max-width:90vw;text-align:center}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.success{border-color:var(--green)}.toast.error{border-color:var(--red)}.toast.gold{border-color:var(--gold)}

/* ── LOADING / EMPTY ── */
.loading-wrap{padding:60px;text-align:center;color:var(--muted)}
.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{padding:60px;text-align:center;color:var(--muted)}
.empty-icon{opacity:.15;display:block;margin:0 auto 16px}

/* ── SB PROMO ── */
.sb-promo{margin:10px 8px;background:linear-gradient(135deg,#1565c0,#0d47a1);border-radius:12px;padding:14px;text-align:center;cursor:pointer;box-shadow:0 4px 16px rgba(21,101,192,.3);transition:all .2s}
.sb-promo:hover{transform:translateY(-2px)}

/* ── ADMIN TABLE ── */
.adm-table{width:100%;border-collapse:collapse;min-width:900px}
.adm-table th{background:#f4f7fb;border-bottom:2px solid var(--border);padding:10px 14px;font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;text-align:left;white-space:nowrap;position:sticky;top:0}
.adm-table td{padding:11px 14px;border-bottom:1px solid #f0f4f8;vertical-align:middle;font-size:13px}
.adm-table tr:hover td{background:#f4f8ff}
.adm-table tr.disabled td{opacity:.5;background:#fff8f8}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .sbl,.sbr{display:none}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .odds-grid{grid-template-columns:repeat(3,1fr)}
  .match-row{grid-template-columns:1fr auto 1fr}
  .hdr-nav .nav-btn span{display:none}
}
