/*
Theme Name:  XoSo 2026
Theme URI:   https://xoso2026.com
Description: Kết quả xổ số XSMB XSMN XSMT - Soi cầu - Thống kê lô đề
Version:     2.0.0
Author:      XoSo2026
Text Domain: xoso2026_com
*/
:root{
  --red:#e8192c;--gold:#f5c518;--green:#00d084;--blue:#3b9eff;
  --dark:#0d0d0d;--dark2:#141414;--dark3:#1c1c1c;--dark4:#242424;
  --border:#2e2e2e;--text:#e8e8e8;--muted:#888;
  --fd:'Saira Condensed',sans-serif;--fb:'Be Vietnam Pro',sans-serif;
  --r:8px;--t:.2s ease;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--dark);color:var(--text);font-family:var(--fb);font-size:14px;line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--dark2)}::-webkit-scrollbar-thumb{background:var(--red);border-radius:3px}

/* TOPBAR */
.topbar{background:var(--red);padding:5px 16px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;min-height:30px}
.topbar a{color:#ffe066;transition:opacity var(--t)}.topbar a:hover{opacity:.8}

/* HEADER */
header{background:var(--dark2);border-bottom:2px solid var(--red);position:sticky;top:0;z-index:100;box-shadow:0 2px 16px rgba(232,25,44,.2)}
.header-inner{max-width:1280px;margin:0 auto;padding:0 16px;display:flex;align-items:center;height:58px;gap:10px}
.logo{font-family:var(--fd);font-size:26px;font-weight:900;letter-spacing:-1px;flex-shrink:0}
.logo span{color:var(--gold)}.logo em{color:var(--red);font-style:normal}
nav{display:flex;gap:2px;flex:1;justify-content:center}
nav a{color:var(--muted);font-size:12px;font-weight:700;padding:6px 11px;border-radius:4px;transition:all var(--t);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}
nav a:hover,.nav-active{color:var(--gold)!important;background:rgba(245,197,24,.1)}
.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.live-badge{background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;letter-spacing:1px;animation:blink 1.5s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.5}}
.btn-register{background:var(--gold);color:#111;font-size:12px;font-weight:800;padding:7px 15px;border-radius:6px;cursor:pointer;transition:all var(--t);white-space:nowrap;text-transform:uppercase;letter-spacing:.5px;display:inline-block}
.btn-register:hover{background:#ffd700;transform:translateY(-1px)}

/* TICKER */
.ticker{background:var(--dark3);border-bottom:1px solid var(--border);padding:7px 0;overflow:hidden}
.ticker-wrap{display:flex;animation:tick 40s linear infinite;white-space:nowrap}
.ticker-wrap:hover{animation-play-state:paused}
@keyframes tick{from{transform:translateX(100vw)}to{transform:translateX(-100%)}}
.ticker-item{color:var(--muted);font-size:13px;margin-right:60px}
.ticker-item strong{color:var(--gold);margin-right:5px}.ticker-item .hi{color:var(--green)}

/* COUNTDOWN */
.countdown-bar{background:linear-gradient(135deg,#1a0a0a,var(--dark3));border-bottom:1px solid var(--border);padding:10px 0}
.countdown-inner{max-width:1280px;margin:0 auto;padding:0 16px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.cdt{display:flex;align-items:center;gap:8px;font-family:var(--fd)}
.tb{background:var(--dark4);border:1px solid var(--border);padding:4px 12px;border-radius:6px;text-align:center;min-width:50px}
.tb .num{color:var(--gold);display:block;font-size:24px;font-weight:900;line-height:1}
.tb .lbl{color:var(--muted);font-size:10px}
.time-sep{color:var(--red);font-size:20px;font-weight:900}

/* LAYOUT */
.main-wrap{max-width:1280px;margin:0 auto;padding:20px 16px;display:grid;grid-template-columns:1fr 320px;gap:20px;align-items:start}
@media(max-width:960px){.main-wrap{grid-template-columns:1fr}}
@media(max-width:640px){nav{display:none}}

/* CARDS */
.card{background:var(--dark2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:14px}
.card-hd{background:var(--dark3);padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px}
.card-title{font-family:var(--fd);font-size:15px;font-weight:800;text-transform:uppercase;letter-spacing:.8px}

/* SECTION HEADER */
.sec-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.sec-title{font-family:var(--fd);font-size:18px;font-weight:900;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.sec-title::before{content:'';width:4px;height:20px;background:var(--red);border-radius:2px;flex-shrink:0;display:block}
.sec-title .sub{color:var(--muted);font-size:12px;font-weight:400;text-transform:none;font-family:var(--fb)}
.see-all{font-size:12px;color:var(--gold);font-weight:600;padding:4px 10px;border:1px solid rgba(245,197,24,.3);border-radius:4px;transition:all var(--t)}
.see-all:hover{background:rgba(245,197,24,.1)}

/* TABS */
.tab-bar{display:flex;gap:6px;margin-bottom:14px}
.tab-btn{background:var(--dark3);border:1px solid var(--border);color:var(--muted);font-size:13px;font-weight:700;padding:7px 18px;border-radius:6px;cursor:pointer;transition:all var(--t);text-transform:uppercase}
.tab-btn.active,.tab-btn:hover{background:var(--red);border-color:var(--red);color:#fff}
.tab-pane{display:none}.tab-pane.active{display:block}

/* RESULT TABLE */
.rtbl{width:100%;border-collapse:collapse;font-size:13px}
.rtbl th{background:var(--dark3);color:var(--muted);padding:7px 10px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.rtbl td{padding:7px 10px;border-bottom:1px solid rgba(46,46,46,.5);vertical-align:middle}
.rtbl tr:last-child td{border:none}
.rtbl .row-db td{background:rgba(232,25,44,.07);font-weight:800}
.n-sp{font-family:var(--fd);font-size:22px;font-weight:900;color:var(--red);letter-spacing:2px}
.n-norm{font-family:var(--fd);font-weight:700;font-size:15px}
.nums{display:flex;flex-wrap:wrap;gap:5px}

/* STATUS */
.st{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}
.st-live{background:rgba(232,25,44,.15);color:var(--red);border:1px solid rgba(232,25,44,.3);animation:blink 1.5s infinite}
.st-done{background:rgba(0,208,132,.1);color:var(--green);border:1px solid rgba(0,208,132,.25)}
.st-wait{background:rgba(245,197,24,.1);color:var(--gold);border:1px solid rgba(245,197,24,.25)}
.upd-ts{font-size:11px;color:var(--muted);padding:7px 14px;border-top:1px solid var(--border);text-align:right}

/* SOI CAU */
.sc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px;margin-bottom:14px}
.sc-card{background:var(--dark3);border:1px solid var(--border);border-radius:var(--r);padding:14px;cursor:pointer;transition:all var(--t)}
.sc-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.sc-type{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:7px}
.sc-nums{font-family:var(--fd);font-size:30px;font-weight:900;color:var(--gold);letter-spacing:4px;margin-bottom:7px;line-height:1}
.sc-cf{display:flex;align-items:center;gap:8px}
.cf-bar{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.cf-fill{height:100%;border-radius:2px;transition:width 1s}
.cf-pct{font-size:11px;font-weight:700;white-space:nowrap}

/* HEATMAP */
.hm-tabs{display:flex;gap:6px;margin-bottom:10px}
.hm-tab{background:var(--dark3);border:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:700;padding:5px 13px;border-radius:4px;cursor:pointer;transition:all var(--t)}
.hm-tab.active{background:var(--red);border-color:var(--red);color:#fff}
.hm-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:3px}
.hm-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;transition:all var(--t);border:1px solid transparent;font-family:var(--fd);font-size:13px;font-weight:800}
.hm-cell:hover{transform:scale(1.12);z-index:2;border-color:#fff}
.hm-cell small{font-size:9px;font-family:var(--fb);font-weight:400;opacity:.7}
.h0{background:#1a1a1a;color:#444}.h1{background:#1f1510;color:#7a5533}.h2{background:#2d1e0f;color:#9c7240}
.h3{background:#3a2510;color:#bf9050}.h4{background:#4a2e08;color:var(--gold)}.h5{background:#5c3505;color:var(--gold)}
.h6{background:#7a3d00;color:#ffbe30}.h7{background:#a04500;color:#ffd050}.h8{background:#c84a00;color:#ffe070}
.h9{background:var(--red);color:#fff}.h10{background:#ff2a00;color:#fff;box-shadow:0 0 8px rgba(255,42,0,.5)}
.g0{background:#1a1a1a;color:#555}.g1{background:rgba(59,158,255,.08);color:var(--blue)}.g2{background:rgba(59,158,255,.15);color:#60b8ff}
.g3{background:rgba(245,197,24,.1);color:var(--gold)}.g4{background:rgba(245,197,24,.18);color:#ffd040}
.g5{background:rgba(232,25,44,.1);color:#ff6b6b}.g6{background:rgba(232,25,44,.2);color:var(--red)}
.g7{background:var(--red);color:#fff;box-shadow:0 0 10px rgba(232,25,44,.4)}

/* CHART */
.chart-wrap{padding:14px;position:relative}canvas{max-height:200px}

/* WIN RATE */
.wr-bar{display:flex;align-items:center;gap:10px;background:var(--dark3);border:1px solid var(--border);border-radius:var(--r);padding:9px 14px;margin-bottom:12px}
.wr-track{flex:1;height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.wr-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--green));border-radius:3px;transition:width 1s}
.wr-pct{font-size:12px;font-weight:800;color:var(--green);white-space:nowrap}

/* SIDEBAR */
.sidebar{display:flex;flex-direction:column;gap:12px}
.sw{background:var(--dark2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.sw-title{background:var(--dark3);padding:9px 14px;border-bottom:1px solid var(--border);font-family:var(--fd);font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.8px}
.sw-body{padding:12px}

.aff-banner{display:block;background:linear-gradient(135deg,#1a0000,#2d0000);border:1px solid rgba(232,25,44,.4);border-radius:var(--r);padding:14px;text-align:center;position:relative;overflow:hidden;transition:all var(--t)}
.aff-banner:hover{border-color:var(--red);transform:translateY(-2px)}
.aff-title{font-family:var(--fd);font-size:20px;font-weight:900;color:#fff}
.aff-sub{font-size:12px;color:var(--muted);margin:5px 0;line-height:1.6}
.aff-btn{background:var(--red);color:#fff;font-weight:800;font-size:13px;padding:8px 18px;border-radius:6px;display:inline-block;text-transform:uppercase;margin-top:4px}
.push-w{background:var(--dark3);border:1px solid var(--border);border-radius:var(--r);padding:11px 13px;display:flex;align-items:center;gap:10px}
.push-btn{background:var(--green);color:#000;font-size:12px;font-weight:800;padding:6px 13px;border-radius:5px;border:none;cursor:pointer;text-transform:uppercase;flex-shrink:0;transition:background var(--t)}
.push-btn:hover{background:#00f096}
.hist-tbl{width:100%;border-collapse:collapse;font-size:12px}
.hist-tbl th{color:var(--muted);padding:5px 8px;text-align:left;font-weight:600;border-bottom:1px solid var(--border)}
.hist-tbl td{padding:5px 8px;border-bottom:1px solid rgba(46,46,46,.5)}
.hist-tbl tr:last-child td{border:none}
.hist-tbl .hi{color:var(--gold);font-weight:800}
.trend-list{display:flex;flex-direction:column;gap:9px}
.trend-item{display:flex;align-items:center;gap:10px}
.trend-rank{font-family:var(--fd);font-size:18px;font-weight:900;color:var(--muted);width:22px;flex-shrink:0}
.rank-1{color:var(--gold)}.rank-2{color:#c0c0c0}.rank-3{color:#cd7f32}
.trend-title{flex:1;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-size:13px;transition:color var(--t)}
.trend-title:hover{color:var(--gold)}
.trend-views{font-size:11px;color:var(--muted);white-space:nowrap}

/* ARTICLES */
.article-list{display:flex;flex-direction:column;gap:9px}
.article-item{display:flex;gap:12px;background:var(--dark2);border:1px solid var(--border);border-radius:var(--r);padding:11px;transition:all var(--t)}
.article-item:hover{border-color:rgba(245,197,24,.3);transform:translateX(3px)}
.art-thumb{width:58px;height:58px;border-radius:6px;background:var(--dark3);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;overflow:hidden}
.art-thumb img{width:100%;height:100%;object-fit:cover}
.art-title{font-size:13px;font-weight:600;line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.art-meta{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.tag{background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:3px}
.art-meta span{font-size:11px;color:var(--muted)}

/* BREADCRUMB */
.breadcrumb{font-size:12px;color:var(--muted);margin-bottom:11px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--gold)}.breadcrumb .sep{opacity:.4}

/* UPDATE NOTICE */
.upd{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);padding:8px 12px;background:var(--dark3);border-radius:6px;border:1px solid var(--border);margin-bottom:14px}
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot-g{background:var(--green);box-shadow:0 0 6px var(--green)}.dot-y{background:var(--gold)}.dot-r{background:var(--red);animation:blink 1.5s infinite}

/* SKELETON */
.skel{background:linear-gradient(90deg,var(--dark3) 25%,var(--dark4) 50%,var(--dark3) 75%);background-size:200% 100%;animation:sk 1.5s infinite;border-radius:4px}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* MODAL */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:999;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
.modal-ov.open{display:flex}
.modal{background:var(--dark2);border:1px solid var(--border);border-radius:12px;width:100%;max-width:520px;max-height:80vh;overflow-y:auto;padding:20px;position:relative}
.modal-x{position:absolute;top:12px;right:12px;background:var(--dark3);border:1px solid var(--border);color:var(--text);width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center}
.modal-x:hover{background:var(--red);border-color:var(--red)}
.modal-title{font-family:var(--fd);font-size:18px;font-weight:800;margin-bottom:14px;padding-right:30px}

/* LO HISTORY */
.lo-hist-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin:12px 0}
.lh-cell{padding:5px 3px;text-align:center;border-radius:4px;font-size:11px}
.lh-cell.win{background:rgba(0,208,132,.15);color:var(--green);border:1px solid rgba(0,208,132,.3)}
.lh-cell.miss{background:var(--dark3);color:var(--muted);border:1px solid var(--border)}

/* FLOAT BTNS */
.float-btns{position:fixed;bottom:20px;right:20px;z-index:99;display:flex;flex-direction:column;gap:8px}
.fbtn{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:19px;cursor:pointer;box-shadow:0 3px 12px rgba(0,0,0,.4);transition:all var(--t);border:none;text-decoration:none}
.fbtn:hover{transform:scale(1.1)}
.fb-z{background:#0068ff}.fb-t{background:#0088cc}.fb-up{background:var(--dark3);border:1px solid var(--border);color:var(--text);font-size:14px}

/* FOOTER */
footer{background:var(--dark2);border-top:1px solid var(--border);padding:30px 0 0}
.footer-inner{max-width:1280px;margin:0 auto;padding:0 16px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:24px;padding-bottom:24px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h4{font-family:var(--fd);font-size:13px;font-weight:800;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.footer-grid ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.footer-grid ul a{font-size:13px;color:var(--muted);transition:color var(--t)}.footer-grid ul a:hover{color:var(--text)}
.footer-bottom{border-top:1px solid var(--border);padding:14px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--muted)}
.footer-ad{border-top:1px solid var(--border);padding:10px 16px;text-align:center}

/* NATIVE AD */
.native-ad{margin:12px 0;border-radius:var(--r);overflow:hidden}

/* DATE INPUT */
.date-input{background:var(--dark3);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:6px;font-size:13px;font-family:var(--fb)}
.date-input:focus{outline:none;border-color:var(--gold)}
.btn-search{background:var(--red);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:700;font-size:13px;cursor:pointer;transition:background var(--t)}
.btn-search:hover{background:#c8162a}

/* FADE IN */
.fade-in{animation:fi .35s ease}
@keyframes fi{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* EMPTY STATE */
.empty-s{padding:28px 20px;text-align:center}
.empty-s .ei{font-size:36px;margin-bottom:10px}
.empty-s p{color:var(--muted);font-size:13px}
