/* ====================== ROOT TOKENS ====================== */
:root{
  --navy:#001633;--navy2:#031f46;--navy3:#0b2f63;--deep:#020814;
  --panel:#0d244a;--panel2:#183869;
  --sky:#09d8ff;--sky2:#0095df;--gold:#f4d787;--gold2:#b98122;
  --white:#fff;--muted:#9aa9c5;--green:#27d65e;--red:#ff4141;
  --line:#294b7d;--max:1320px;--bottom:78px;
  --shadow:0 18px 50px rgba(0,0,0,.45);
  --side-w:96px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;min-height:100%;font-family:'Noto Sans Thai',system-ui,-apple-system,Segoe UI,sans-serif;background:#020814;color:var(--white);scroll-behavior:smooth}
body.no-scroll{overflow:hidden}
.hidden{display:none!important}
button,input,select,textarea{font-family:inherit}
button{cursor:pointer;color:inherit}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
input,select,textarea{outline:none}

/* ====================== INPUT SYSTEM ====================== */
.input{
  display:block;
  width:100%;
  padding:13px 16px;
  background:rgba(0,10,30,.75);
  border:1.5px solid rgba(0,190,255,.22);
  border-radius:14px;
  color:#dceeff;
  font-size:15px;
  font-family:inherit;
  line-height:1.4;
  transition:border-color .18s,box-shadow .18s,background .18s;
  -webkit-appearance:none;
  appearance:none;
}
.input::placeholder{color:rgba(145,165,196,.55);font-size:14px}
.input:hover:not(:disabled){border-color:rgba(0,210,255,.38)}
.input:focus{
  border-color:rgba(0,231,255,.7);
  background:rgba(0,16,46,.85);
  box-shadow:0 0 0 3px rgba(0,231,255,.1),inset 0 1px 3px rgba(0,0,0,.25);
}
.input:disabled{
  opacity:.45;
  cursor:not-allowed;
  background:rgba(0,8,22,.5);
  border-color:rgba(0,190,255,.1);
}
.input.is-error{
  border-color:rgba(255,65,65,.7)!important;
  box-shadow:0 0 0 3px rgba(255,65,65,.1)!important;
}
/* select arrow */
select.input{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='8' viewBox='0 0 14 8'%3E%3Cpath d='M1 1l6 6 6-6' stroke='%2340e0ff' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:38px;
  cursor:pointer;
}
select.input option{background:#041230;color:#dceeff}

/* textarea */
textarea.input{resize:vertical;min-height:90px;line-height:1.6}

/* number — hide spinners */
input[type=number].input::-webkit-inner-spin-button,
input[type=number].input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type=number].input{-moz-appearance:textfield}

/* ---------- input-wrap (password eye toggle) ---------- */
.input-wrap{position:relative}
.input-wrap .input{padding-right:46px}
.input-eye{
  position:absolute;
  right:4px;top:50%;transform:translateY(-50%);
  width:38px;height:38px;
  border:0;background:transparent;
  color:#5a7aa8;font-size:16px;
  display:grid;place-items:center;
  border-radius:10px;
  transition:color .15s;
  padding:0;
}
.input-eye:hover{color:#40e0ff}

/* ---------- form label ---------- */
label:not(.deposit-upload):not(.toggle-row):not([class]){
  display:block;
  font-size:12px;
  font-weight:700;
  color:#7a9cc6;
  margin:0 0 6px 2px;
  letter-spacing:.02em;
}

/* ---------- phone validation indicator ---------- */
.input.phone-ok{border-color:rgba(39,214,94,.6)!important}
.input.phone-ok:focus{box-shadow:0 0 0 3px rgba(39,214,94,.1)!important}
.input.phone-err{border-color:rgba(255,65,65,.6)!important}
.input.phone-err:focus{box-shadow:0 0 0 3px rgba(255,65,65,.1)!important}

/* ====================== BACKGROUND ====================== */
body:before{content:"";position:fixed;inset:0;z-index:-3;background:linear-gradient(180deg,#000817 0%,#001a3c 24%,#020918 80%,#001a3c 100%)}
body:after{content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(circle at 8% 22%,rgba(0,219,255,.16),transparent 22%),
    radial-gradient(circle at 92% 8%,rgba(244,215,135,.14),transparent 25%),
    linear-gradient(90deg,rgba(0,216,255,.03) 1px,transparent 1px),
    linear-gradient(rgba(0,216,255,.025) 1px,transparent 1px);
  background-size:auto,auto,42px 42px,42px 42px;pointer-events:none}

/* ====================== APP INSTALL BAR ====================== */
.app-install{position:sticky;top:0;z-index:95;height:60px;background:linear-gradient(180deg,#2a2a2a,#1a1a1a);display:flex;align-items:center;gap:10px;padding:6px 14px;border-bottom:1px solid rgba(255,255,255,.08)}
.app-install .install-close{border:0;background:transparent;color:#ddd;font-size:22px;width:32px;height:32px;display:grid;place-items:center}
.mini-logo{height:42px;min-width:96px;display:flex;align-items:center;justify-content:center}
.brand-logo{position:relative;display:inline-flex;align-items:center;justify-content:center;height:42px;min-width:120px;padding:0 18px;border-radius:50px;color:#ffe99f;font-family:Georgia,serif;font-weight:900;font-size:24px;letter-spacing:-1px;
  text-shadow:0 2px #432306,0 0 10px rgba(255,221,99,.8);
  background:linear-gradient(180deg,#3b290f,#0c0710 50%,#2b103d);
  border:2px solid #a87b27;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.08),0 0 13px rgba(132,67,255,.35)}
.brand-logo:before,.brand-logo:after{content:"";position:absolute;top:50%;width:18px;height:14px;transform:translateY(-50%) rotate(45deg);border:2px solid #b98a31;background:#08070d}
.brand-logo:before{left:-8px}
.brand-logo:after{right:-8px}
.brand-logo.brand-logo-image{min-width:0;padding:4px 12px;background:rgba(3,12,30,.72);overflow:hidden}
.brand-logo.brand-logo-image:before,.brand-logo.brand-logo-image:after{display:none}
.brand-logo.brand-logo-image img{display:block;height:100%;max-width:180px;object-fit:contain}
.install-text{min-width:0;flex:1;line-height:1.18}
.install-text b{display:block;font-weight:900;font-size:14px}
.install-text span{display:block;color:#c9c9c9;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.install-btn{height:36px;border:0;border-radius:8px;padding:0 18px;background:linear-gradient(180deg,#10e8ff,#008fdc);color:#fff;font-weight:900;font-size:13px;box-shadow:0 4px 12px rgba(0,195,255,.35);white-space:nowrap}

/* ====================== TOP BAR ====================== */
.topbar{position:sticky;top:60px;z-index:90;background:linear-gradient(180deg,#001936,#001229);border-bottom:1px solid rgba(40,82,140,.45)}
.topbar-inner{max-width:var(--max);margin:0 auto;height:74px;padding:0 18px;display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center}
.icon-btn{width:48px;height:48px;border:0;border-radius:14px;background:linear-gradient(180deg,#0b65b1,#082856);color:#21caff;font-size:22px;display:grid;place-items:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 8px 20px rgba(0,0,0,.28)}
.topbar .logo{justify-self:center;display:flex;align-items:center;gap:14px;min-width:0}
.topbar .logo .brand-logo{height:46px;min-width:128px;font-size:22px}
.topbar .logo .brand-logo.brand-logo-image{min-width:0;width:auto;max-width:210px}
.flag-btn{width:42px;height:42px;border-radius:50%;border:2px solid rgba(255,255,255,.25);overflow:hidden;background:linear-gradient(#ee1c25 0 33%,#fff 33% 67%,#0a0a8c 67%);box-shadow:0 6px 16px rgba(0,0,0,.25);display:grid;place-items:center;color:transparent;cursor:pointer}
.flag-btn.us{background:linear-gradient(#b22234 0 14%,#fff 14% 28%,#b22234 28% 42%,#fff 42% 56%,#b22234 56% 70%,#fff 70% 84%,#b22234 84%)}

/* desktop top nav */
.desktop-promo-btn{display:none;align-items:center;gap:8px;height:44px;padding:0 18px;border-radius:14px;border:1px solid rgba(244,215,135,.4);background:linear-gradient(180deg,#163b6f,#0a1d40);color:#fff;font-weight:900;font-size:14px}
.desktop-promo-btn .gicon{width:30px;height:30px;border-radius:9px;background:linear-gradient(180deg,#ffd45c,#aa7720);display:grid;place-items:center;color:#3a2300;font-size:16px}
.desktop-search-btn{display:none;width:42px;height:42px;border:1px solid rgba(255,255,255,.18);border-radius:50%;background:transparent;color:#cfe5ff;font-size:16px}
.site-nav-primary{display:none;flex-wrap:nowrap;align-items:center;justify-content:center;gap:6px;margin:0;padding:0;min-width:0}
.site-nav-primary .sn-link{display:inline-flex;align-items:center;gap:8px;border:1px solid transparent;background:transparent;color:#cfe0ff;font-weight:800;font-size:13px;padding:10px 12px;border-radius:12px;white-space:nowrap;cursor:pointer;transition:.18s;color:#cdd9f5}
.site-nav-primary .sn-link i{color:#f4d787;font-size:15px}
.site-nav-primary .sn-link:hover{border-color:rgba(98,169,255,.35);background:rgba(0,40,90,.38);color:#fff}
.site-nav-primary .sn-link.sn-active{border-color:rgba(19,234,255,.45);background:linear-gradient(180deg,rgba(19,234,255,.12),rgba(6,34,74,.52));color:#fff;box-shadow:0 0 18px rgba(19,234,255,.08)}

.desktop-auth{display:none;align-items:center;gap:12px}
.desktop-auth .btn-login,.desktop-auth .btn-register{height:48px;border-radius:12px;padding:0 28px;font-weight:900;font-size:15px;border:1.5px solid #c9b87c}
.desktop-auth .btn-login{background:linear-gradient(180deg,#ffe28b,#bd8120);color:#1c1100;border:0}
.desktop-auth .btn-register{background:#0b1d3b;color:#f6d98a}

/* ====================== HORIZONTAL CATEGORY TAB (DESKTOP) ====================== */
.cat-tabs{display:none;background:linear-gradient(180deg,#001226,#000915);border-bottom:1px solid rgba(40,82,140,.4)}
.cat-tabs-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:8px;padding:8px 18px;overflow:auto;scrollbar-width:none}
.cat-tabs-inner::-webkit-scrollbar{display:none}
.cat-tab{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;background:transparent;border:0;color:#bccfee;font-weight:900;font-size:15px;white-space:nowrap;border-bottom:3px solid transparent;height:54px}
.cat-tab i{font-size:20px;color:#f4d787}
.cat-tab.active{color:#fff;border-bottom-color:#13eaff}
.cat-tab.active i{color:#13eaff}
.cat-tab .live-dot{width:8px;height:8px;border-radius:50%;background:#ff4141;box-shadow:0 0 8px #ff4141;animation:pulse 1.4s infinite;display:inline-block}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ====================== APP / SHELL LAYOUT ====================== */
.app{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:var(--side-w) minmax(0,1fr);gap:14px;padding:14px 16px 24px}
.desktop-side{position:sticky;top:140px;align-self:start}
.side-card{display:flex;flex-direction:column;gap:8px}

/* mobile-only side rail (left vertical icons) */
.side-rail{display:flex;flex-direction:column;gap:8px}
.rail-link{position:relative;height:74px;border-radius:14px;background:linear-gradient(180deg,#0e2b58,#061838);border:1px solid rgba(74,142,225,.34);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#fff;font-weight:900;font-size:11px;text-align:center;padding:6px 4px;box-shadow:0 6px 16px rgba(0,0,0,.28)}
.rail-link .ricon{width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.06);display:grid;place-items:center;color:#f4d787;font-size:16px}
.rail-link.active{background:linear-gradient(180deg,#fff,#dde7f7);color:#071b36}
.rail-link.active .ricon{background:rgba(0,34,72,.08);color:#0d4380}

/* main column */
.main{min-width:0}
.notice{height:42px;border-radius:8px;border:1px solid rgba(255,255,255,.18);background:#020b1a;display:flex;align-items:center;gap:10px;padding:0 14px;margin-bottom:10px;color:#dce8ff;font-size:14px;overflow:hidden}
.notice i{color:#5dc7ff;font-size:18px}
.notice marquee{flex:1;min-width:0}

/* ====================== HERO SLIDER ====================== */
.hero-slider{position:relative;border-radius:14px;overflow:hidden;background:linear-gradient(135deg,#031026,#0a2a5c);border:1px solid rgba(76,138,220,.35);box-shadow:var(--shadow);aspect-ratio:21/9;min-height:200px}
.hero-track{position:absolute;inset:0;display:flex;transition:transform .55s cubic-bezier(.22,.71,.27,1)}
.hero-slide{flex:0 0 100%;position:relative;height:100%;display:grid;place-items:center;background:#031026;cursor:pointer}
.hero-slide img{width:100%;height:100%;object-fit:cover}
.hero-slide .blur-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:blur(24px);transform:scale(1.15);opacity:.65;z-index:0}
.hero-slide picture{position:relative;z-index:1;width:100%;height:100%;display:grid;place-items:center}
.hero-slide picture img{width:auto;max-width:100%;max-height:100%;object-fit:contain}
.hero-fallback{position:relative;z-index:1;width:100%;height:100%;padding:34px 30px;display:flex;flex-direction:column;justify-content:center;color:#fff;background:
  linear-gradient(100deg,#081124 0%,rgba(12,27,58,.82) 40%,rgba(0,0,0,.2)),
  radial-gradient(circle at 72% 44%,rgba(254,213,98,.38),transparent 30%),
  linear-gradient(135deg,#051126,#173563)}
.hero-fallback h1{margin:0;font-size:34px;line-height:1.06;font-weight:1000;color:#ffe18b;text-shadow:0 0 18px rgba(255,220,70,.3)}
.hero-fallback h1 .pct{display:block;font-size:1.95em;line-height:1}
.hero-fallback p{font-size:16px;color:#fff;margin:14px 0 22px;max-width:520px}
.hero-fallback .hero-actions{display:flex;gap:10px;flex-wrap:wrap}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:42px;height:42px;border-radius:50%;border:0;background:rgba(0,0,0,.45);color:#fff;font-size:18px;display:grid;place-items:center;backdrop-filter:blur(6px);transition:.2s}
.hero-arrow:hover{background:rgba(0,150,220,.7)}
.hero-arrow.prev{left:10px}
.hero-arrow.next{right:10px}
.hero-dots{position:absolute;left:0;right:0;bottom:10px;display:flex;justify-content:center;gap:6px;z-index:5}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.36);cursor:pointer;transition:.2s;border:0;padding:0}
.hero-dot.active{background:#13eaff;width:22px;border-radius:5px;box-shadow:0 0 8px rgba(19,234,255,.6)}

/* ====================== WELCOME / LOBBY ====================== */
.welcome-hero-panel{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin:14px 0 16px;padding:18px 20px;border-radius:16px;border:1px solid rgba(119,174,255,.45);background:linear-gradient(120deg,rgba(6,32,74,.94),rgba(4,22,54,.92),rgba(12,62,118,.72));box-shadow:0 18px 40px rgba(0,0,0,.28)}
.welcome-copy{flex:1;min-width:220px}
.welcome-copy h2{margin:0 0 10px;font-size:20px;font-weight:900;color:#fff;text-shadow:0 0 12px rgba(19,234,255,.28)}
.welcome-copy h2 i{color:#ffd66b;margin-right:8px}
.welcome-copy p{margin:0;color:#cdd9ef;font-size:14px;line-height:1.5}
.welcome-actions{display:flex;flex-wrap:wrap;gap:10px}
.welcome-actions .btn-register,.welcome-actions .btn-login{padding:11px 18px;border-radius:12px;font-weight:900;font-size:14px}
.welcome-actions .ghost-welcome{background:transparent;border:2px solid rgba(19,234,255,.55);color:#c9efff;font-weight:900}
.welcome-actions .ghost-welcome:hover{background:rgba(19,234,255,.1)}
.welcome-member-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;margin:12px 0 14px;padding:14px 18px;border-radius:14px;border:1px solid rgba(244,215,135,.42);background:linear-gradient(100deg,rgba(28,54,112,.92),rgba(8,26,62,.94))}
.welcome-member-strip div{display:flex;flex-direction:column;gap:4px;font-size:14px;color:#dae6ff;line-height:1.35}
.welcome-member-strip b{font-size:16px;color:#ffe7a8}
.referral-home-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin:0 0 14px;padding:12px 16px;border-radius:12px;border:1px solid rgba(71,227,157,.42);background:rgba(10,54,42,.52);font-size:14px;color:#d4fae8}
.referral-home-strip b{color:#8fffc4}
.game-lobby-hero{margin:-4px 0 14px;padding:18px 16px;border-radius:16px;border:1px solid rgba(93,157,245,.42);background:linear-gradient(180deg,rgba(8,42,93,.92),rgba(4,14,38,.94))}
.game-lobby-title{margin:0 0 10px;font-size:clamp(22px,3vw,28px);font-weight:1000;color:#fff}
.game-lobby-title i{color:#13eaff;margin-right:10px;font-size:.92em}
.game-lobby-sub{margin:0;font-size:14px;color:#a9c6eb;line-height:1.55}

/* ====================== AUTH ROW + NOTICE ====================== */
.btn-main{border:0;border-radius:12px;padding:13px 22px;background:linear-gradient(180deg,#10edff,#0084d6);color:#fff;font-weight:1000;font-size:15px;box-shadow:0 0 16px rgba(0,205,255,.32),inset 0 1px 0 rgba(255,255,255,.35)}
.btn-dark{border:1px solid rgba(89,143,224,.46);border-radius:12px;padding:12px 18px;color:#fff;background:#07152d;font-weight:900;font-size:14px}
.btn-gold{border:0;border-radius:12px;padding:13px 22px;background:linear-gradient(180deg,#ffe28b,#bd8120);color:#1c1100;font-weight:1000;font-size:15px;box-shadow:0 6px 18px rgba(255,200,80,.25)}
.auth-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:14px 0 12px}
.auth-row button{height:60px;border-radius:14px;font-size:20px;font-weight:1000;border:2px solid #c9b87c}
.auth-row .register{background:#0b1d3b;color:#f6d98a}
.auth-row .login{background:linear-gradient(180deg,#fff1a9,#ca8e25);color:#000;border:0}

/* ====================== TAB PILLS ====================== */
.tab-row{display:flex;gap:10px;margin:12px 0;overflow:auto;scrollbar-width:none}
.tab-row::-webkit-scrollbar{display:none}
.tab-pill{flex:1 1 0;min-width:140px;height:54px;border-radius:12px;border:0;background:transparent;color:#16a6ff;font-size:16px;font-weight:1000;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}
.tab-pill.active{background:linear-gradient(180deg,#13eaff,#008bdd);color:#fff;box-shadow:0 0 18px rgba(0,210,255,.4)}
.tab-pill i{font-size:18px}

/* ====================== BAR TITLE ====================== */
.bar-title{height:44px;display:flex;align-items:center;gap:10px;background:linear-gradient(90deg,#0b4078,#071329);border-radius:8px;padding:0 16px;font-size:17px;font-weight:1000;margin:14px 0 12px;border:1px solid rgba(74,142,225,.28)}
.bar-title i{color:#64d8ff;font-size:18px}
.bar-title .extra{margin-left:auto;color:#8db5e9;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px}

/* ====================== PANEL ====================== */
.panel{border:1px solid rgba(70,117,190,.46);background:linear-gradient(180deg,#0d244a,#051326);border-radius:14px;padding:14px;box-shadow:var(--shadow)}

/* ====================== GAME GRID ====================== */
.game-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.game-card{position:relative;border-radius:14px;overflow:hidden;background:#07152d;border:1px solid rgba(75,137,224,.32);box-shadow:0 12px 28px rgba(0,0,0,.35);cursor:pointer;transition:transform .25s}
.game-card:hover{transform:translateY(-3px)}
.game-thumb{position:relative;aspect-ratio:3/4;background:#020815;overflow:hidden}
.game-thumb img{width:100%;height:100%;display:block;object-fit:cover}
.game-thumb i{position:absolute;inset:0;display:grid;place-items:center;font-size:46px;color:#f4d787}
.game-info{padding:9px 10px}
.game-info b{display:block;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.game-info span{display:block;color:#9aa9c5;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.game-info button{width:100%;height:34px;border:0;border-radius:8px;margin-top:6px;background:linear-gradient(180deg,#10edff,#0084d6);color:#fff;font-weight:900;font-size:12px}
.game-badge{position:absolute;top:7px;right:7px;z-index:3;border-radius:7px;padding:3px 8px;font-size:10px;font-weight:1000;background:linear-gradient(180deg,#ff4d81,#ff1e5f);color:#fff;box-shadow:0 4px 12px rgba(255,28,90,.3)}
.game-badge.hot{background:linear-gradient(180deg,#ff8a3d,#e23a13)}
.game-badge.new{background:linear-gradient(180deg,#27d65e,#0e8c34)}

/* ====================== PROVIDER GRID ====================== */
.provider-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.provider-card{position:relative;min-height:160px;border:1px solid rgba(72,139,220,.38);background:linear-gradient(180deg,#0f2e60,#061225);border-radius:16px;padding:14px;color:#fff;box-shadow:0 12px 26px rgba(0,0,0,.34);overflow:hidden;cursor:pointer}
.provider-card:after{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;background:rgba(0,216,255,.1)}
.provider-badge{position:absolute;top:8px;right:8px;z-index:3;border-radius:8px;padding:4px 9px;font-size:11px;font-weight:1000;background:linear-gradient(180deg,#ff4d81,#ff1e5f);color:#fff;box-shadow:0 4px 12px rgba(255,28,90,.3)}
.provider-logo{height:80px;display:flex;align-items:center;justify-content:center;margin-top:10px}
.provider-logo img{max-height:72px;max-width:140px;object-fit:contain}
.provider-logo i{font-size:42px;color:#f4d787}
.provider-meta{text-align:center;margin-top:8px}
.provider-meta b{display:block;font-size:15px}
.provider-meta span{color:#b6c4df;font-size:11px}

/* ====================== ONLINE-NOW BOXES (provider counts) ====================== */
.online-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}
.online-box{position:relative;border:1px solid rgba(72,139,220,.38);background:linear-gradient(180deg,#0d2954,#040d20);border-radius:14px;padding:10px;text-align:center;overflow:hidden}
.online-img{aspect-ratio:1/1;display:grid;place-items:center;border-radius:10px;background:linear-gradient(135deg,#152a52,#040d20);overflow:hidden;margin-bottom:6px}
.online-img img{max-width:78%;max-height:78%;object-fit:contain;filter:drop-shadow(0 6px 8px rgba(0,0,0,.5))}
.online-box .count{display:flex;align-items:center;justify-content:center;gap:6px;background:linear-gradient(180deg,#0f2c5c,#06152e);border:1px solid rgba(74,142,225,.4);border-radius:10px;padding:6px 8px;font-weight:1000;font-size:13px;color:#fff}
.online-box .count i{color:#13eaff;font-size:11px}

/* ====================== LIVE NOW (sports) ====================== */
.live-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:10px}
.live-card{border:1px solid rgba(74,142,225,.4);background:linear-gradient(180deg,#0a2c66,#03132d);border-radius:14px;padding:14px;color:#fff;box-shadow:0 8px 22px rgba(0,0,0,.28)}
.live-card .lc-top{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#9fb3d6;margin-bottom:10px}
.live-card .lc-top .lcn-name{display:flex;align-items:center;gap:6px;color:#dceaff}
.live-card .lc-live{background:#ff4141;color:#fff;font-size:10px;font-weight:1000;padding:2px 8px;border-radius:5px;letter-spacing:.5px}
.live-card .lc-teams{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;margin:6px 0}
.live-card .lc-team{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.live-card .lc-team .lc-logo{width:46px;height:46px;border-radius:50%;background:#fff;display:grid;place-items:center;color:#001633;font-weight:1000;font-size:13px;overflow:hidden}
.live-card .lc-team .lc-logo img{width:100%;height:100%;object-fit:contain}
.live-card .lc-team b{font-size:13px;font-weight:900}
.live-card .lc-vs{font-size:18px;font-weight:1000;color:#9fb3d6}
.live-card .lc-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.live-card .lc-actions button{height:38px;border:0;border-radius:9px;font-weight:1000;font-size:13px;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.lc-actions .lc-watch{background:linear-gradient(180deg,#ff5060,#c81a2b);color:#fff}
.lc-actions .lc-bet{background:linear-gradient(180deg,#10edff,#0084d6);color:#fff}

/* ====================== LEADERBOARD ====================== */
.lb-table{width:100%;border-collapse:separate;border-spacing:0 6px;margin-top:8px}
.lb-table th{text-align:left;color:#9fb3d6;font-size:12px;font-weight:600;padding:0 10px}
.lb-table td{background:linear-gradient(180deg,#0e2c5d,#04122a);border-top:1px solid rgba(74,142,225,.3);border-bottom:1px solid rgba(74,142,225,.3);padding:10px;font-size:13px;color:#fff}
.lb-table td:first-child{border-left:1px solid rgba(74,142,225,.3);border-radius:10px 0 0 10px}
.lb-table td:last-child{border-right:1px solid rgba(74,142,225,.3);border-radius:0 10px 10px 0;font-weight:1000;color:#f4d787;text-align:right}
.lb-rank{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:9px}
.lb-rank.r1{background:linear-gradient(180deg,#ffd45c,#a36d10);color:#3a2300}
.lb-rank.r2{background:linear-gradient(180deg,#dde2ed,#8a92a3);color:#1d2030}
.lb-rank.r3{background:linear-gradient(180deg,#dc8453,#6b3413);color:#fff}
.lb-rank.rN{background:#0a1d40;color:#9fb3d6}
.lb-game{display:inline-flex;align-items:center;gap:8px}
.lb-game-icon{width:32px;height:32px;border-radius:7px;background:#fff2;overflow:hidden;display:grid;place-items:center;flex:0 0 auto}
.lb-game-icon img{width:100%;height:100%;object-fit:cover}
.lb-game-icon i{color:#f4d787;font-size:14px}
.lb-game-meta b{display:block;font-size:13px}
.lb-game-meta span{display:block;color:#9fb3d6;font-size:10px}

/* ====================== GUIDE COLLAPSIBLES ====================== */
.guide-list{display:grid;gap:10px;margin-top:8px}
.guide-row{border:1px solid rgba(74,142,225,.38);background:linear-gradient(180deg,#0d2952,#06183a);border-radius:11px;overflow:hidden}
.guide-row summary{list-style:none;display:flex;align-items:center;gap:10px;padding:14px 16px;cursor:pointer;font-weight:1000;font-size:15px}
.guide-row summary::-webkit-details-marker{display:none}
.guide-row summary .gr-icon{margin-left:auto;transition:.2s;color:#13eaff}
.guide-row[open] summary .gr-icon{transform:rotate(180deg)}
.guide-row p{margin:0;padding:0 16px 14px;color:#b6c4df;font-size:14px;line-height:1.5}

/* ====================== INSTALL / SHORTCUT CARD ====================== */
.shortcut-card{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;padding:16px 18px;border-radius:14px;background:
  radial-gradient(circle at 80% 50%,rgba(244,215,135,.18),transparent 50%),
  linear-gradient(180deg,#0e3268,#03152e);border:1px solid rgba(74,142,225,.4);box-shadow:var(--shadow);margin-top:12px}
.shortcut-left h3{margin:0 0 4px;font-size:18px}
.shortcut-left p{margin:0 0 12px;color:#b6c4df;font-size:13px}
.shortcut-os{display:flex;gap:10px;flex-wrap:wrap}
.shortcut-os button{height:42px;padding:0 20px;border:1px solid rgba(255,255,255,.18);border-radius:10px;background:rgba(0,0,0,.38);color:#fff;font-weight:900;display:inline-flex;align-items:center;gap:8px;font-size:13px}
.shortcut-os button.active{background:#000;border-color:#13eaff;color:#13eaff}
.shortcut-os button i{font-size:18px}
.shortcut-right .brand-logo{transform:scale(1.25)}

/* ====================== PAYMENT METHODS / FOOTER ====================== */
.payments-section{margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,.1)}
.payments-section h3{text-align:center;margin:0 0 14px;font-size:18px;font-weight:600;color:#dce8ff}
.bank-logos{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;max-width:880px;margin:0 auto}
.bank-logo{width:46px;height:46px;border-radius:50%;background:#fff;padding:5px;box-shadow:0 0 0 2px rgba(255,255,255,.18),0 8px 18px rgba(0,0,0,.24);overflow:hidden}
.bank-logo img{width:100%;height:100%;object-fit:contain;border-radius:50%}

/* footer */
.footer{background:linear-gradient(180deg,#001936,#000915);border-top:1px solid rgba(74,142,225,.28);padding:24px 16px 28px;margin-top:24px}
.footer-inner{max-width:var(--max);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:24px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-grid h4{margin:0 0 12px;font-size:15px;color:#dce8ff}
.footer-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.footer-grid ul a{color:#9fb3d6;font-size:13px}
.footer-grid ul a:hover{color:#13eaff}
.footer-cert{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.footer-cert .cert{height:46px;min-width:46px;border-radius:9px;background:#06122a;border:1px solid rgba(255,255,255,.14);padding:0 10px;display:grid;place-items:center;color:#fff;font-weight:900;font-size:12px}
.footer-contact{display:flex;gap:10px;flex-wrap:wrap}
.footer-contact a{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:#06122a;border:1px solid rgba(255,255,255,.14);font-size:20px}
.footer-contact a.line{color:#06c755;background:#fff}
.footer-contact a.tg{color:#fff;background:linear-gradient(180deg,#34aade,#0683b6)}
.footer-contact a.live{color:#fff;background:linear-gradient(180deg,#1eaf5b,#073f1e)}
.partners{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.partner-pill{height:36px;min-width:96px;padding:0 14px;border-radius:8px;border:1px solid rgba(255,255,255,.14);background:#06122a;color:#9fb3d6;font-weight:900;font-size:11px;display:inline-flex;align-items:center;justify-content:center;letter-spacing:.5px}
.copyright{text-align:center;color:#7d8aa6;font-size:12px;margin-top:18px;display:flex;align-items:center;justify-content:center;gap:10px}

/* ====================== JACKPOT / LEADERBOARD SIDEBAR ====================== */
.jackpot-card,.lb-card,.minigame-card{border:1px solid rgba(74,142,225,.4);background:linear-gradient(180deg,#0e2c5d,#03102a);border-radius:14px;padding:14px;box-shadow:var(--shadow);margin-bottom:14px}
.jackpot-card .jp-title,.lb-card .lb-title,.minigame-card .mg-title{display:flex;align-items:center;gap:8px;font-weight:1000;font-size:15px;margin-bottom:8px}
.jackpot-card .jp-title i{color:#f4d787}
.lb-card .lb-title i{color:#f4d787}
.jp-img{aspect-ratio:16/9;border-radius:10px;background:radial-gradient(circle at 50% 60%,#5e3712,#1c0c00);position:relative;overflow:hidden;display:grid;place-items:center;text-align:center}
.jp-img b{font-family:Georgia,serif;font-size:32px;color:#fff;text-shadow:0 0 10px rgba(255,200,80,.6),0 2px 0 #5e3712;font-weight:1000;letter-spacing:1px}
.jp-img small{display:block;color:#ffd58a;font-size:11px;font-style:italic;margin-top:2px}
.jp-img:before{content:"JACKPOTS";position:absolute;top:10px;left:0;right:0;text-align:center;font-family:Georgia,serif;color:#ffe28b;font-size:14px;font-weight:1000;letter-spacing:3px;text-shadow:0 0 8px rgba(255,200,80,.6)}
.minigame-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
.minigame-btn{position:relative;height:64px;border:0;border-radius:12px;background:linear-gradient(180deg,#10edff,#0084d6);color:#fff;font-weight:1000;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 0 16px rgba(0,205,255,.32)}
.minigame-btn.gold{background:linear-gradient(180deg,#ffe28b,#bd8120);color:#1c1100}
.minigame-btn i{font-size:20px}

/* floating CS */
.cs-float{position:fixed;right:14px;bottom:calc(var(--bottom) + 16px);z-index:140;width:60px;height:60px;border-radius:50%;border:0;background:radial-gradient(circle at 50% 30%,#3fdfff,#0066b3);color:#fff;font-size:26px;display:grid;place-items:center;box-shadow:0 0 0 8px rgba(0,150,220,.18),0 14px 32px rgba(0,80,140,.5);cursor:pointer}


/* ===== Referral Page ===== */
.ref-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:#9fb3d6;font-size:15px}
.ref-wrap{max-width:680px;margin:0 auto;padding:0 0 40px}
.ref-hero{display:flex;align-items:center;gap:16px;padding:20px 22px;margin-bottom:20px;border-radius:18px;background:linear-gradient(135deg,rgba(0,90,60,.55),rgba(0,40,30,.7));border:1px solid rgba(0,230,130,.22)}
.ref-hero-icon{width:52px;height:52px;min-width:52px;border-radius:14px;background:linear-gradient(135deg,#00e682,#0097a7);display:grid;place-items:center;font-size:24px;color:#fff;box-shadow:0 8px 20px rgba(0,200,100,.25)}
.ref-hero-text h3{margin:0 0 4px;font-size:16px;font-weight:900;color:#b6ffdb}
.ref-hero-text p{margin:0;font-size:13px;color:#7ec9a8}
.ref-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.ref-stat-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:16px;background:rgba(5,20,50,.7);border:1px solid rgba(0,180,255,.22)}
.ref-stat-card.gold{border-color:rgba(255,210,80,.28);background:rgba(30,18,0,.7)}
.ref-stat-icon{width:44px;height:44px;min-width:44px;border-radius:12px;background:rgba(0,180,255,.12);display:grid;place-items:center;font-size:20px;color:#40e0ff}
.ref-stat-card.gold .ref-stat-icon{background:rgba(255,200,60,.1);color:#ffd04a}
.ref-stat-num{display:block;font-size:22px;font-weight:900;color:#fff;line-height:1.1}
.ref-stat-card small{display:block;font-size:11px;color:#9fb3d6;margin-top:3px}
.ref-stat-card.gold .ref-stat-num{color:#ffe082}
.ref-code-box,.ref-link-box{padding:16px 18px;border-radius:16px;background:rgba(5,20,50,.7);border:1px solid rgba(0,180,255,.18);margin-bottom:14px}
.ref-code-box label,.ref-link-box label{display:block;font-size:12px;color:#9fb3d6;margin-bottom:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.ref-code-row,.ref-link-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ref-code{flex:1;min-width:0;font-size:26px;font-weight:900;letter-spacing:4px;color:#40e0ff;font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ref-link-text{flex:1;min-width:0;font-size:12px;color:#9fb3d6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ref-copy-btn{height:40px;padding:0 16px;border-radius:10px;border:0;background:linear-gradient(180deg,#21e8ff,#008bd8);color:#fff;font-size:13px;font-weight:900;display:inline-flex;align-items:center;gap:6px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:.15s}
.ref-copy-btn.cyan{background:linear-gradient(180deg,#1affb2,#0097a7)}
.ref-copy-btn:hover{filter:brightness(1.1)}
.ref-share-row{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.ref-share-btn{height:38px;padding:0 16px;border-radius:10px;border:0;font-size:13px;font-weight:900;display:inline-flex;align-items:center;gap:7px;cursor:pointer;transition:.15s}
.ref-share-btn.line{background:#06c755;color:#fff}
.ref-share-btn.copy{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:#dceeff}
.ref-share-btn:hover{filter:brightness(1.1)}
.ref-history-box{padding:16px 18px;border-radius:16px;background:rgba(5,20,50,.7);border:1px solid rgba(0,180,255,.18)}
.ref-history-box h4{margin:0 0 12px;font-size:14px;color:#9fb3d6;display:flex;align-items:center;gap:8px}
.ref-history-box h4 i{color:#40e0ff}
.ref-table-wrap{overflow-x:auto}
.ref-table{width:100%;border-collapse:collapse;font-size:13px}
.ref-table th{text-align:left;padding:8px 10px;color:#7a9cc6;font-weight:700;border-bottom:1px solid rgba(255,255,255,.08)}
.ref-table td{padding:10px 10px;border-bottom:1px solid rgba(255,255,255,.05);color:#cdd9f5}
.ref-table tr:last-child td{border-bottom:0}
.ref-amt{color:#4dffb0!important;font-weight:900}
.ref-date{color:#7a9cc6!important;font-size:12px}
@media (max-width:768px){
  .game-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
}
@media (max-width:480px){
  .game-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
  .ref-stats{grid-template-columns:1fr}
  .ref-stat-num{font-size:18px}
  .ref-code{font-size:20px;letter-spacing:2px}
}

/* ---- Rail bank card ---- */
.rail-bank-card{display:flex;align-items:center;gap:9px;background:rgba(0,7,22,.55);border:1px solid rgba(0,231,255,.18);border-radius:14px;padding:9px 12px;margin:8px 0}
.rail-bank-logo{width:34px;height:34px;object-fit:contain;border-radius:8px;background:#fff;padding:2px;flex-shrink:0}
.rail-bank-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.rail-bank-name{font-size:12px;color:#9fb3d6;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rail-bank-acc{font-size:13px;color:#dceeff;font-weight:900;letter-spacing:.5px}
.rail-bank-holder{font-size:11px;color:#7a9cc6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---- Withdraw modal bank card ---- */
.withdraw-balance-row{display:flex;justify-content:space-between;align-items:center;background:rgba(0,7,22,.55);border:1px solid rgba(0,231,255,.18);border-radius:16px;padding:12px 16px;margin-bottom:14px}
.withdraw-balance-row span{font-size:13px;color:#9fb3d6;display:flex;align-items:center;gap:7px}
.withdraw-balance-row span i{color:#f5d57a}
.withdraw-balance-row b{font-size:22px;color:#f5d57a;font-weight:900}
.withdraw-balance-row small{font-size:13px;margin-left:3px}
.withdraw-section-label{font-size:12px;color:#7a9cc6;font-weight:700;display:flex;align-items:center;gap:6px;margin-bottom:8px}
.withdraw-section-label i{color:#40e0ff}
.withdraw-bank-card{display:flex;align-items:center;gap:14px;background:rgba(0,7,22,.6);border:1px solid rgba(0,231,255,.22);border-radius:18px;padding:14px 18px}
.wb-logo{width:48px;height:48px;object-fit:contain;border-radius:12px;background:#fff;padding:4px;flex-shrink:0}
.wb-logo-fallback{font-size:28px;color:#40e0ff;width:48px;text-align:center}
.wb-info{display:flex;flex-direction:column;gap:4px;min-width:0}
.wb-bank-name{font-size:13px;color:#9fb3d6;font-weight:700}
.wb-acc-no{font-size:20px;color:#dceeff;font-weight:900;letter-spacing:1px}
.wb-acc-name{font-size:12px;color:#7a9cc6}

/* ---- Drawer profile card (mobile) ---- */
.drawer-profile{padding:4px 0 10px;margin-bottom:4px;border-bottom:1px solid rgba(0,231,255,.14)}
.drawer-profile-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.drawer-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(180deg,#38f2ff,#0a6dff);display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;flex-shrink:0;box-shadow:0 0 16px rgba(0,231,255,.3)}
.drawer-profile-info{display:flex;flex-direction:column;gap:2px}
.drawer-profile-info b{font-size:15px;color:#dceeff;font-weight:900}
.drawer-profile-info small{font-size:12px;color:#7a9cc6}
.drawer-bank-card{display:flex;align-items:center;gap:10px;background:rgba(0,7,22,.55);border:1px solid rgba(0,231,255,.18);border-radius:14px;padding:10px 13px;margin-bottom:10px}
.drawer-bank-logo{width:36px;height:36px;object-fit:contain;border-radius:8px;background:#fff;padding:2px;flex-shrink:0}
.drawer-bank-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.drawer-balance-row{display:flex;justify-content:space-between;align-items:center;background:rgba(0,7,22,.5);border:1px solid rgba(0,231,255,.15);border-radius:12px;padding:9px 13px;margin-bottom:10px}
.drawer-balance-row span{font-size:12px;color:#9fb3d6;display:flex;align-items:center;gap:6px}
.drawer-balance-row span i{color:#f5d57a}
.drawer-balance-row b{font-size:16px;color:#f5d57a;font-weight:900}
.drawer-quick{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.drawer-quick button{height:40px;border-radius:12px;border:0;font-size:13px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px}
.drawer-quick button:first-child{background:linear-gradient(180deg,#40f4ff,#0487ff);color:#fff}
.drawer-quick button:last-child{background:linear-gradient(180deg,#ffe07b,#ffb331);color:#160b00}

/* Admin payment toggle rows */
.toggle-row{display:flex;align-items:center;padding:6px 0}
.toggle-row label{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer}
.toggle-row input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#40e0ff}
