:root{--bg:#0b1020;--card:#121a33;--muted:#aab3d0;--text:#eef2ff;--accent:#6ee7ff;--accent2:#a78bfa;--danger:#ff6b6b;}
*{box-sizing:border-box} body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu; background:radial-gradient(1200px 600px at 20% 0%, #17204a 0%, var(--bg) 55%); color:var(--text);}
a{color:inherit;text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:16px}
.topbar{position:sticky;top:0;z-index:10;background:rgba(11,16,32,.75);backdrop-filter: blur(10px);border-bottom:1px solid rgba(255,255,255,.06)}
.nav{display:flex;align-items:center;gap:12px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.5px}
.brand-badge{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent2));}
.spacer{flex:1}
.pill{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:var(--muted)}
.btn{cursor:pointer;border:0;border-radius:12px;padding:10px 14px;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#0b1020}
.btn.secondary{background:rgba(255,255,255,.08);color:var(--text);border:1px solid rgba(255,255,255,.14)}
.grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
@media(max-width:1024px){.grid{grid-template-columns:repeat(4,1fr)}}
/* mobile: 3 kolom (3-3) sesuai request */
@media(max-width:640px){.grid{grid-template-columns:repeat(3,1fr)}}
/* extra small: fallback biar tidak terlalu kecil */
@media(max-width:380px){.grid{grid-template-columns:repeat(2,1fr)}}
.card{background:rgba(18,26,51,.92);border:1px solid rgba(255,255,255,.08);border-radius:18px;overflow:hidden}
.card .thumb{
  width: 100%;
  height: 132px;
  object-fit: cover;
  background: rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.card .meta{padding:10px 10px 12px}
.card .title{font-size:13px;font-weight:800;line-height:1.2}
.card .sub{margin-top:6px;font-size:12px;color:var(--muted)}

/* ===== RTP badge (always green >= 80%) ===== */
.rtpbox{margin-top:8px}
.rtphead{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--muted)}
.rtphead b{color:var(--text);font-weight:900}
.rtpbar{margin-top:6px;height:7px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10)}
.rtpbar i{display:block;height:100%;width:0%;background:linear-gradient(90deg,#22c55e,#86efac)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
select,input{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:var(--text);border-radius:12px;padding:10px 12px}
input::placeholder{color:#9aa5c7}
.section-title{display:flex;align-items:center;justify-content:space-between;margin:14px 0 10px}
.h1{font-size:20px;font-weight:900}
.small{font-size:12px;color:var(--muted)}
.alert{padding:12px;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.06)}
.footer{opacity:.8;margin:28px 0 18px;font-size:12px;color:var(--muted)}

.provbar{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0 6px}
.provbtn{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:14px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:var(--text);
  cursor:pointer;font-weight:800;font-size:12px;letter-spacing:.3px; text-transform:uppercase}
.provbtn:hover{border-color:rgba(255,255,255,.22)}
.provbtn.active{background:linear-gradient(135deg,rgba(110,231,255,.25),rgba(167,139,250,.25));
  border-color:rgba(110,231,255,.5)}
.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;font-size:11px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:var(--muted)}
.kpi{display:flex;gap:12px;flex-wrap:wrap;margin:12px 0}
.kpi .box{flex:1;min-width:220px;padding:14px;border-radius:18px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10)}
.kpi .box .t{font-weight:900}
.kpi .box .v{margin-top:6px;font-size:20px;font-weight:900}
.form{max-width:520px}
.form .rowcol{display:flex;flex-direction:column;gap:10px}

/* ===== v6 UI polish (petir/ong style inspired) ===== */
.topbar{background:rgba(7,10,20,.72);backdrop-filter: blur(14px);}
.nav{gap:10px;flex-wrap:nowrap}
.brand{gap:10px}
.brand span{font-size:16px}
.brand-badge{width:36px;height:36px;border-radius:12px}
.header-main{display:flex;align-items:center;gap:12px;padding:10px 0}
.header-tabs{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none;padding:8px 0 12px}
.header-tabs::-webkit-scrollbar{display:none}
.tab{white-space:nowrap;display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);color:var(--text);font-weight:800}
.tab.active{background:linear-gradient(135deg,rgba(110,231,255,.25),rgba(167,139,250,.22));border-color:rgba(110,231,255,.35)}
.pill{padding:8px 10px;border-radius:999px;font-size:12px}
.btn{border-radius:14px}
.container{padding:14px}
.section-title{margin:10px 0 10px}
.h1{font-size:18px}
.kpi{margin:10px 0}
.kpi .box{min-width:0}
@media(max-width:640px){
  .header-main{padding:10px 0 6px}
  .brand span{font-size:14px}
  .pill{padding:7px 9px}
  .grid{gap:10px}
  .card{border-radius:16px}
  .card .meta{padding:10px}
  .card .thumb{height:112px}
  .card .title{font-size:12px}
  .card .sub{font-size:11px}
  .kpi{flex-direction:column}
  .kpi .box{width:100%}
}

@media(max-width:420px){
  .card .thumb{height:98px}
  .card .meta{padding:9px}
  .card .title{font-size:11px}
}
.hero{border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04)}
.hero .inner{padding:14px}
.hero-title{font-size:18px;font-weight:900}
.hero-sub{margin-top:6px;color:var(--muted);font-size:12px;line-height:1.45}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.catgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:12px}
@media(max-width:640px){.catgrid{grid-template-columns:repeat(2,1fr)}}
.cat{display:flex;align-items:center;gap:10px;padding:12px;border-radius:16px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10)}
.cat .ico{width:36px;height:36px;border-radius:14px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center}
.cat .txt{font-weight:900}
.cat .sub{font-size:12px;color:var(--muted);margin-top:3px}
.cat .col{display:flex;flex-direction:column}
/* provider bar more like chips */
.provbar{overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;padding-bottom:6px}
.provbar::-webkit-scrollbar{display:none}
.provbtn{flex:0 0 auto;border-radius:999px;padding:10px 14px}
/* ===== MOBILE FIX (v6.1) ===== */
@media (max-width: 480px) {
  .container { padding: 12px !important; }

  /* header */
  .header-main { padding: 8px 0 6px !important; }
  .brand span { font-size: 13px !important; }
  .brand-badge { width: 32px !important; height: 32px !important; border-radius: 10px !important; }

  /* tabs: biar rapi, tidak turun jadi 2 baris */
  .header-tabs {
    gap: 8px !important;
    padding: 6px 0 10px !important;
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
  }
  .tab {
    padding: 8px 12px !important;
    font-size: 12px !important;
    border-radius: 999px !important;
    flex: 0 0 auto !important;
  }

  /* hero */
  .hero-title { font-size: 16px !important; }
  .hero-sub {
    font-size: 12px !important;
    line-height: 1.4 !important;
  }
  .actions {
    gap: 8px !important;
  }
  .btn, .btn.secondary {
    padding: 10px 12px !important;
    font-size: 13px !important;
    border-radius: 12px !important;
  }

  /* kategori grid biar rapih */
  .catgrid {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
  }
  .cat {
    padding: 12px !important;
    border-radius: 16px !important;
  }
  .cat .ico {
    width: 34px !important;
    height: 34px !important;
    border-radius: 12px !important;
  }
  .cat .txt { font-size: 13px !important; }
  .cat .sub { font-size: 11px !important; }

  /* footer */
  .footer { margin: 18px 0 14px !important; }
}
/* ===== Bottom Nav (Mobile) ===== */
.bottom-nav {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 50;
  background: rgba(7,10,20,.86);
  backdrop-filter: blur(14px);
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 10px 10px calc(10px + env(safe-area-inset-bottom));
  display: none;
}
.bottom-nav .wrap {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.bottom-nav a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 8px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--text);
  font-weight: 800;
  font-size: 11px;
}
.bottom-nav a .ico { font-size: 18px; line-height: 1; }
.bottom-nav a.active {
  background: linear-gradient(135deg, rgba(110,231,255,.25), rgba(167,139,250,.22));
  border-color: rgba(110,231,255,.35);
}

/* hanya tampil di mobile */
@media (max-width: 720px) {
  .bottom-nav { display: block; }
  /* kasih ruang biar konten tidak ketutup bottom nav */
  body { padding-bottom: 90px; }
}

/* ===== Banner Slider ===== */
.slider {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
}
.slider .slides {
  display: flex;
  transition: transform .45s ease;
  will-change: transform;
}
.slide {
  min-width: 100%;
  aspect-ratio: 16 / 7;
  background: rgba(255,255,255,.04);
}
.slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.slider .dots {
  position: absolute;
  left: 0; right: 0; bottom: 10px;
  display: flex;
  justify-content: center;
  gap: 8px;
}
.slider .dot {
  width: 8px; height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.35);
  border: 1px solid rgba(0,0,0,.2);
}
.slider .dot.active { background: rgba(110,231,255,.95); }

/* ===== iGaming UI Pack (petir/ong style) ===== */

/* Banner / Slider */
.slider { position: relative; border-radius: 18px; overflow: hidden; border: 1px solid rgba(255,255,255,.08); }
.slider .slides { display:flex; transition: transform .45s ease; will-change: transform; }
.slide { min-width:100%; aspect-ratio: 16/7; background: rgba(255,255,255,.04); }
.slide a, .slide img { display:block; width:100%; height:100%; }
.slide img { object-fit: cover; }
.slider .dots { position:absolute; left:0; right:0; bottom:10px; display:flex; justify-content:center; gap:8px; }
.slider .dot { width: 16px; height: 6px; border-radius: 999px; background: rgba(255,255,255,.25); border:1px solid rgba(0,0,0,.2); }
.slider .dot.active { background: rgba(110,231,255,.95); }

/* Marquee */
.marquee {
  margin-top: 10px;
  display:flex; align-items:center; gap:10px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}
.marquee .tag {
  flex: 0 0 auto;
  font-weight: 900;
  padding: 6px 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(110,231,255,.25), rgba(167,139,250,.22));
  border: 1px solid rgba(110,231,255,.35);
}
.marquee .track { overflow:hidden; position:relative; width:100%; }
.marquee .text {
  white-space: nowrap;
  display:inline-block;
  animation: marquee 16s linear infinite;
  color: var(--text);
  font-weight: 700;
  font-size: 12px;
}
@keyframes marquee { 0%{ transform: translateX(100%);} 100%{ transform: translateX(-110%);} }

/* Provider strip */
.provider-strip{
  margin-top: 12px;
  display:flex;
  gap:10px;
  overflow-x:auto;
  scrollbar-width:none;
  padding-bottom: 6px;
}
.provider-strip::-webkit-scrollbar{ display:none; }
.pchip{
  flex:0 0 auto;
  display:flex; align-items:center; gap:10px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  font-weight: 900;
  white-space: nowrap;
}
.pchip img{ width:28px; height:28px; border-radius: 10px; background: rgba(255,255,255,.06); }

/* Quick action cards */
.quick-grid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
@media(max-width:640px){
  .quick-grid{ grid-template-columns: repeat(2, 1fr); }
}
.qcard{
  border-radius: 18px;
  padding: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}
.qcard .t{ font-weight: 900; }
.qcard .s{ margin-top:6px; font-size:12px; color: var(--muted); }
.qcard .go{ margin-top:10px; display:inline-flex; }

/* Bottom nav 5 items */
.bottom-nav{
  position: fixed; left:0; right:0; bottom:0; z-index: 99;
  background: rgba(7,10,20,.86);
  backdrop-filter: blur(14px);
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 10px 10px calc(10px + env(safe-area-inset-bottom));
  display:none;
}
.bottom-nav .wrap{
  max-width: 1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns: repeat(5,1fr);
  gap: 8px;
}
.bottom-nav a{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap: 5px;
  padding: 10px 8px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--text);
  font-weight: 900;
  font-size: 10.5px;
}
.bottom-nav a .ico{ font-size: 18px; line-height:1; }
.bottom-nav a.active{
  background: linear-gradient(135deg, rgba(110,231,255,.25), rgba(167,139,250,.22));
  border-color: rgba(110,231,255,.35);
}

/* Mobile-only bottom nav + avoid overlap */
@media(max-width:720px){
  .bottom-nav{ display:block; }
  body{ padding-bottom: 98px; }
}

/* Fix header stack on small screens */
@media(max-width:480px){
  .header-main{ padding: 8px 0 6px !important; }
  .brand span{ font-size: 13px !important; }
  .header-tabs{ overflow-x:auto; flex-wrap:nowrap; gap:8px; padding:6px 0 10px; }
  .tab{ flex: 0 0 auto; padding: 8px 12px; font-size:12px; }
}

.gname{
    font-size:14px;
}
/* ===== TOP GAME BADGE ===== */
.top-game {
  border: 1px solid rgba(255,215,0);
  box-shadow: 0 0 0 1px rgba(255,215,0) inset;
}

.thumb-wrap {
  position: relative;
  background: rgba(0,0,0,.25);
}

.badge-top {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 3;
  padding: 4px 8px;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .5px;
  border-radius: 999px;
  color: #000;
  background: linear-gradient(135deg, #FFD700, #FFA500);
}

/* pastikan image FIT, bukan crop */
.thumb {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover !important;
  background: rgba(0,0,0,.25);
}

/* ===== Layout (ONG-like: sidebar + main) ===== */
.layout{display:flex;min-height:100vh}
.sidebar{
  width:260px;flex:0 0 260px;
  position:sticky;top:0;height:100vh;
  background:rgba(8,12,24,.86);
  backdrop-filter: blur(14px);
  border-right:1px solid rgba(255,255,255,.06);
}
.side-inner{display:flex;flex-direction:column;height:100%;padding:16px}
.side-brand{display:flex;align-items:center;gap:10px;padding:10px 10px;border-radius:16px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.side-search{margin-top:14px;position:relative}
.side-search input{
  width:100%;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color:var(--text);
  border-radius:14px;
  padding:10px 12px;
  font-weight:700;
}
.side-search-result{
  position:absolute;left:0;right:0;top:44px;
  background:rgba(10,14,28,.96);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  overflow:hidden;
  max-height:360px;
  overflow-y:auto;
  z-index:50;
}
.side-s-item{display:flex;gap:10px;align-items:center;padding:10px 12px;cursor:pointer}
.side-s-item:hover{background:rgba(255,255,255,.06)}
.side-s-item img{width:42px;height:32px;object-fit:contain;background:rgba(255,255,255,.06);border-radius:10px}
.side-menu{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.side-link{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  font-weight:800;
}
.side-link span{opacity:.95}
.side-link:hover{border-color:rgba(255,255,255,.18)}
.side-link.active{
  background:linear-gradient(135deg,rgba(110,231,255,.18),rgba(167,139,250,.14));
  border-color:rgba(110,231,255,.35);
}
.side-sep{height:1px;background:rgba(255,255,255,.08);margin:8px 0}
.side-foot{margin-top:auto;padding-top:12px}
.main{flex:1;min-width:0}

/* ===== Home sections ===== */
.hscroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none;}
/* ===== HOME: bikin card di hscroll jadi lebih lebar ===== */
.hscroll .gcard,
.hscroll .mini-card{
  flex: 0 0 210px;   /* ubah angka ini: 180 / 200 / 220 / 240 */
  width: 210px;
}

/* biar gambar ikut proporsi yang enak */
.hscroll .gcard .thumb,
.hscroll .mini-card .thumb{
  height: 130px;     /* boleh 120-150 */
}

/* Mobile: tetap enak dilihat */
@media (max-width: 640px){
  .hscroll .gcard,
  .hscroll .mini-card{
    flex-basis: 170px;
    width: 170px;
  }
  .hscroll .gcard .thumb,
  .hscroll .mini-card .thumb{
    height: 112px;
  }
}

.hscroll::-webkit-scrollbar{display:none}
.mini-card{
  width:160px;flex:0 0 160px;
  background:rgba(18,26,51,.92);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  overflow:hidden;
}
.mini-card .thumb{height:110px;width:100%;display:block;object-fit:cover;background:rgba(0,0,0,.25)}
.mini-card .meta{padding:10px}
.mini-card .title{font-size:12px;font-weight:900}
.mini-card .sub{font-size:11px;color:var(--muted);margin-top:6px}

/* Provider bar as horizontal scroller (ONG-like) */
.provbar{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;padding-bottom:6px}
.provbar::-webkit-scrollbar{display:none}
.provbtn{white-space:nowrap}


/* Mobile Offcanvas Sidebar */
.iconbtn{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:14px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:var(--text);
  cursor:pointer;
}
.iconbtn:active{transform:translateY(1px)}
.nav-toggle{display:none}
.nav-overlay{display:none}
.side-brand-row{display:flex;align-items:center;gap:10px}
.side-close{display:none;margin-left:auto}

@media(max-width:720px){
  .layout{display:block}
  .sidebar{
    position:fixed;left:0;top:0;height:100vh;width:280px;
    transform:translateX(-105%);
    transition:transform .25s ease;
    z-index:1001;
  }
  .sidebar.open{transform:translateX(0)}
  .nav-overlay{
    display:block;position:fixed;inset:0;
    background:rgba(0,0,0,.55);
    backdrop-filter: blur(2px);
    opacity:0;pointer-events:none;
    transition:opacity .2s ease;
    z-index:1000;
  }
  .nav-overlay.show{opacity:1;pointer-events:auto}
  .nav-toggle{display:inline-flex}
  .side-close{display:inline-flex}
  body.nav-open{overflow:hidden}
  .main{min-height:100vh}
  .container{padding:14px}
  .topbar .container{padding:12px 14px}
}
@media(min-width:721px){
  .nav-overlay{display:none !important}
}
/* ===== ONG188-like Sidebar ===== */
.sidebar{
  background: radial-gradient(120% 140% at 40% 0%, rgb(40 183 255 / 16%), rgba(0, 0, 0, .0) 55%), linear-gradient(180deg, rgb(10 19 28 / 92%), rgba(10, 6, 8, .92));
  border-right: 1px solid rgba(255,255,255,.08);
}
.side-inner{ padding: 16px 14px; }

.side-top-tabs{
  display:flex; gap:10px;
  margin: 12px 0 12px;
}
.side-tabbtn{
  flex:1;
  text-align: center;
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(315deg, #43cea2 0%, #185a9d 75%);
  color: rgba(255,255,255,.92);
  padding: 10px 12px;
  border-radius: 12px;
  font-weight: 800;
  cursor:pointer;
}

.side-tabpanel{ display:none; }
.side-tabpanel.show{ display:block; }

.side-cardlink{
  display:block;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.92);
  text-decoration:none;
  font-weight: 700;
}

.side-sep{
  height:1px;
  background: rgba(255,255,255,.08);
  margin: 14px 0;
}

.side-item{
  display:flex; align-items:center; gap:10px;
  padding: 12px 12px;
  border-radius: 14px;
  background: rgba(0,0,0,.16);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.93);
  text-decoration:none;
  font-weight: 750;
  margin-bottom: 10px;
}
.side-item span{ opacity: .98; }
.side-item:hover{ background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.14); }
.side-item.active{ border-color: rgba(255,171,64,.45); background: rgba(255,171,64,.12); }

.side-contact{ margin-top: 2px; }
.side-contact-row{
  display:flex; align-items:center; gap:10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px dashed rgba(255,255,255,.14);
  background: rgba(0,0,0,.14);
  color: rgba(255,255,255,.9);
  text-decoration:none;
  margin-bottom: 10px;
}
/* sidebar scrollable */
.sidebar { 
  height: 100vh;
}

.side-inner{
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 18px;
}
body.nav-open { overflow: hidden; }

/* optional: scroll bar lebih rapi */
.side-inner::-webkit-scrollbar { width: 8px; }
.side-inner::-webkit-scrollbar-thumb { background: rgba(255,255,255,.18); border-radius: 999px; }
.side-inner::-webkit-scrollbar-track { background: transparent; }

/* ===== Login Modal ===== */
.modal{
  position: fixed;
  inset: 0;
  z-index: 9999;           /* harus lebih tinggi dari topbar/sidebar */
  display: none;           /* JS akan ubah jadi block */
}

.modal-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
}

.modal-card{
  position: relative;
  width: min(420px, calc(100% - 28px));
  margin: 10vh auto 0;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(18,26,51,.98);
  box-shadow: 0 24px 80px rgba(0,0,0,.55);
  overflow: hidden;
}

.modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding: 14px 14px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.modal-body{
  padding: 14px;
}

.modal .label{
  display:block;
  font-size: 12px;
  color: rgba(255,255,255,.75);
  margin-bottom: 6px;
}

.modal .input{
  width: 100%;
}

.modal .alert{
  margin: 12px 14px 0;
  border-color: rgba(239,68,68,.35);
  background: rgba(239,68,68,.08);
}

/* optional anim */
.modal[aria-hidden="false"] .modal-card{
  animation: modalIn .14s ease-out;
}
@keyframes modalIn{
  from{ transform: translateY(10px); opacity: .7; }
  to{ transform: translateY(0); opacity: 1; }
}

/* === PROMO LIST (mobile premium) === */
.promo-list{display:flex;flex-direction:column;gap:12px}
.promo-card{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
  border-radius:16px;
  overflow:hidden;
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
}
.promo-head{
  width:100%;
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px;
  border:0;
  cursor:pointer;
  background:transparent;
  color:inherit;
  text-align:left;
}
.promo-thumb{
  width:120px;
  height:56px;
  border-radius:12px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  flex:0 0 auto;
}
.promo-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.promo-thumb-empty{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;letter-spacing:.6px;
  opacity:.85;
}
.promo-meta{flex:1;min-width:0}
.promo-title{font-weight:900;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.promo-sub{font-size:12px;opacity:.8;margin-top:2px}
.promo-cta{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(59,130,246,.95);
  color:#fff;
  font-weight:900;
  font-size:12px;
  flex:0 0 auto;
}
.promo-body{
  display:none;
  padding:12px;
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
}
.promo-card.open .promo-body{display:block}
.promo-desc{font-size:13px;line-height:1.55;color:rgba(255,255,255,.92)}



/* RTP colors */
.rtpbox.rtp-green .rtpbar i{background: linear-gradient(90deg, rgba(34,197,94,.95), rgba(16,185,129,.95));}
.rtpbox.rtp-yellow .rtpbar i{background: linear-gradient(90deg, rgba(245,158,11,.95), rgba(250,204,21,.95));}
.rtpbox.rtp-red .rtpbar i{background: linear-gradient(90deg, rgba(239,68,68,.95), rgba(244,63,94,.95));}

/* ===== FIX: gambar harus masuk ke card (home & slot) ===== */

/* card selalu nge-clip isi */
.card, .mini-card { overflow: hidden; }

/* thumb wrapper jadi frame yang punya tinggi pasti */
.card .thumb,
.mini-card .thumb{
  position: relative;
  overflow: hidden;
}

/* pastikan tinggi thumb sesuai design */
.card .thumb{ height: 132px; }
@media(max-width:640px){ .card .thumb{ height:112px; } }
@media(max-width:420px){ .card .thumb{ height:98px; } }

.mini-card .thumb{ height:110px; }

/* INI KUNCI UTAMA: IMG di dalam thumb harus ikut frame */
.card .thumb img,
.mini-card .thumb img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

/* kalau ada img langsung di card (tanpa wrapper) */
.card > img{
  width: 100%;
  height: 132px;
  display: block;
  object-fit: cover;
  object-position: center;
}
/* ===== FIX untuk card .gcard (gambar masuk ke card, tidak overflow) ===== */
.gcard{
  display:block;
  color:inherit;
  text-decoration:none;
  background: rgba(18,26,51,.92);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  overflow: hidden;            /* kunci: clip isi card */
}

/* frame gambar */
.gcard .thumb{
  position: relative;
  width: 100%;
  height: 132px;               /* sesuaikan ukuran kamu */
  overflow: hidden;            /* kunci: clip gambar */
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.06);
}

/* gambar harus ikut frame */
.gcard .thumb img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: fill;           /* cover biar pas */
  object-position: center;
}

/* mobile: biar lebih kecil */
@media(max-width:640px){
  .gcard{ border-radius: 16px; }
  .gcard .thumb{ height: 112px; }
}
@media(max-width:420px){
  .gcard .thumb{ height: 98px; }
}

/* ===== RTP bar: kamu pakai span.rtpfill, bukan i ===== */
.rtpbar{
  height: 7px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.10);
}
.rtpbar .rtpfill{
  display: block;
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg,#22c55e,#86efac);
}

