:root{
  --blue-950:#071628;
  --blue-900:#0c2340;
  --blue-800:#12335d;
  --blue-700:#17467d;
  --blue-600:#1e5aa3;
  --blue-500:#2f7ae5;
  --blue-300:#9bc5ff;
  --ink:#eaf2ff;
  --glass: rgba(255,255,255,.06);
  --ring: rgba(47,122,229,.35);
  --success:#24c16a;
  --danger:#e74d4d;
  --warning:#ffb020;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:linear-gradient(180deg,var(--blue-950),var(--blue-900));color:#eaf2ff;font:14px/1.6 system-ui,Segoe UI,Roboto,Arial}
a{color:#fff;text-decoration:none}
.container{max-width:1280px;margin:auto;padding:0 16px}

/* Topbar */
.topbar{
  background:linear-gradient(180deg, rgba(18,51,93,.90), rgba(12,35,64,.90)) !important;
  border-bottom:1px solid rgba(255,255,255,.08);
  font-size:13px;
}
.topbar .row{display:flex;gap:16px;align-items:center;justify-content:space-between;padding:8px 0}
.topbar .links{display:flex;gap:14px;flex-wrap:wrap}
.topbar .links a{opacity:.95}
.topbar .cta{
  background:#25D366;color:#06220f;padding:6px 12px;border-radius:999px;font-weight:700
}

/* Navbar */
.navbar{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(0deg, #1d7dd3, #084572, #1d72d3, #004271), linear-gradient(225deg, #1d3cd3 0%, #1d8ed3 60%);
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 6px 20px rgba(0,0,0,.25);
}
.navbar .row{display:flex;align-items:center;gap:18px;padding:12px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.5px}
.brand .logo{width:34px;height:34px;border-radius:8px;background:linear-gradient(180deg,#fff,#b9d7ff);box-shadow:0 2px 10px rgba(0,0,0,.25)}
.nav{display:flex;gap:18px;flex-wrap:wrap}
.nav a{opacity:.95;position:relative;padding:8px 6px;border-radius:8px}
.nav a.hot::after{
  content:'HOT!';position:absolute;top:-6px;right:-8px;font-size:10px;background:linear-gradient(180deg,#ff7a7a,#d63a3a);padding:2px 6px;border-radius:6px
}

/* Marquee (promo/welcome) */
.marquee{
  background:linear-gradient(180deg, rgba(18,51,93,.90), rgba(12,35,64,.90)) !important;
  border:1px solid rgba(255,255,255,.08);border-left:0;border-right:0;
}
.marquee .inner{padding:8px 0;white-space:nowrap;overflow:hidden}
.marquee .inner span{display:inline-block;padding-left:100%;animation:slide 22s linear infinite}
@keyframes slide{to{transform:translateX(-100%)}}
/* Marquee dengan ikon speaker di kiri */
.marquee .bar{
  display:flex; align-items:center; gap:10px;
}

/* Biar area teks mengisi sisa ruang dan tetap scroll */
.marquee .inner{
  flex:1;             /* <— penting */
  overflow:hidden;    /* menjaga teks agar tidak spill */
  padding:8px 0;
  white-space:nowrap;
}

/* Kotak ikon speaker */
.speaker{
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; border-radius:8px;
  background:linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,.08));
  border:1px solid rgba(255,255,255,.15);
  box-shadow:0 6px 14px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.2);
  font-size:16px; line-height:1;
}

/* (opsional) efek berdenyut halus di ikon */
@keyframes pulse {
  0%,100% { transform:scale(1); filter:brightness(1); }
  50%     { transform:scale(1.05); filter:brightness(1.15); }
}
.speaker{ animation:pulse 1.8s ease-in-out infinite; }
/* Hero */
.hero{padding:16px 0}
.hero-grid{
  display:grid;grid-template-columns: 2fr 1fr;gap:16px;
}
.banner{
  background:linear-gradient(180deg, rgba(30,90,163,.25), rgba(20,60,120,.25));
  border:1px solid rgba(255,255,255,.10);border-radius:16px;min-height:300px;
  box-shadow:0 10px 30px rgba(0,0,0,.35), inset 0 0 0 1px rgba(255,255,255,.03);
  position:relative;overflow:hidden;padding:16px;
}
.banner .title{font-size:28px;font-weight:900;margin:4px 0 6px}
.banner .subtitle{opacity:.9;margin-bottom:10px}
.banner .ribbon{position:absolute;inset:auto 12px 12px auto;background:rgba(0,0,0,.25);padding:6px 10px;border-radius:8px;font-weight:700}
.banner .glow{
  position:absolute;inset:-20%;background:radial-gradient(600px 200px at 10% 0%,rgba(47,122,229,.25),transparent 60%);
  pointer-events:none
}
.hero-right{display:grid;grid-template-rows:repeat(3, 1fr);gap:16px}
.promo{
  background:linear-gradient(180deg, rgba(30,90,163,.18), rgba(20,60,120,.18));
  border:1px solid rgba(255,255,255,.10);border-radius:16px;padding:14px 16px;
  position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.promo h4{margin:0;font-size:16px}
.promo .tag{font-weight:900;font-size:20px}
.promo .flare{position:absolute;inset:auto -30% -60% auto;width:60%;height:160%;background:radial-gradient(300px 300px at 100% 100%,rgba(155,197,255,.4),transparent 60%);pointer-events:none}

/* Action buttons */
.actions{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;
  background:linear-gradient(180deg,var(--blue-600),var(--blue-700));
  border:1px solid rgba(255,255,255,.10);box-shadow:0 6px 16px rgba(0,0,0,.35);font-weight:700
}
.btn.alt{background:linear-gradient(180deg,#1b2a44,#12263f)}
.btn.warn{background:linear-gradient(180deg,#ff7a7a,#d63a3a)}
.btn .dot{width:10px;height:10px;border-radius:999px;background:#9bc5ff}

/* Sections */
.section{padding:8px 0 18px}
.section h2{margin:6px 0 12px}
.grid{
  display:grid;gap:16px;grid-template-columns:repeat(4,1fr)
}
.card{
  background:linear-gradient(180deg, rgba(30,90,163,.16), rgba(20,60,120,.16));
  border:1px solid rgba(255,255,255,.10);border-radius:16px;padding:14px;
  box-shadow:0 8px 24px rgba(0,0,0,.32), inset 0 0 0 1px rgba(255,255,255,.03);
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-2px)}
.card h3{margin:0 0 8px;font-size:50px}
.kv{display:grid;grid-template-columns:88px 1fr;gap:4px;font-size:13px}
.kv b{color:#fff}
.hot-badge{
  position:absolute;top:8px;right:8px;background:linear-gradient(180deg,#ff7a7a,#d63a3a);
  color:#fff;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:700;box-shadow:0 0 18px rgba(255,90,90,.45)
}

/* Table (center on mobile) */
.table-wrap{overflow:auto;border-radius:14px;border:1px solid rgba(255,255,255,.08)}
table{width:100%;border-collapse:collapse;background:rgba(0,0,0,.15)}
th,td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.06);text-align:center}

/* Footer */
.footer{opacity:.85;text-align:center;padding:22px 0;margin-top:16px;border-top:1px solid rgba(255,255,255,.08)}

/* Responsive */
@media(max-width:1100px){.grid{grid-template-columns: repeat(3,1fr)}}
@media(max-width:900px){
  .hero-grid{grid-template-columns: 1fr}
  .hero-right{grid-template-columns: repeat(3,1fr);grid-template-rows:none}
}
@media(max-width:640px){
  .nav{overflow:auto}
  .grid{grid-template-columns: repeat(2,1fr)}
  .hero-right{grid-template-columns:1fr}
}
@media(max-width:420px){
  .grid{grid-template-columns:1fr}
}

/* === NAVBAR RIGHT + BUTTON LOOK === */
.navbar .row { display:flex; align-items:center; }
.nav {                 /* ratakan ke kanan */
  margin-left:auto; display:flex; gap:14px; flex-wrap:wrap; justify-content:flex-end;
}
.nav a{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px;
  font-weight:800; letter-spacing:.2px;
  border-radius:10px;
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.15);
  box-shadow:
    0 6px 14px rgba(0,0,0,.25),            /* shadow bawah (timbul) */
    inset 0 1px 0 rgba(255,255,255,.20);   /* highlight atas */
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  text-transform: uppercase;
}
.nav a:hover{
  transform: translateY(-1px);
  background:linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.06));
  border-color: rgba(255,255,255,.25);
  box-shadow: 0 10px 18px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.25);
}
.nav a:active{ transform: translateY(0); box-shadow: 0 4px 10px rgba(0,0,0,.25) }

/* badge HOT tetap bisa dipakai di atas link */
.nav a.hot::after{
  content:'HOT!'; position:absolute; top:-8px; right:-10px;
  font-size:10px; padding:2px 6px; border-radius:6px;
  background:linear-gradient(180deg,#ff7a7a,#d63a3a);
  color:#fff; box-shadow:0 2px 8px rgba(0,0,0,.25);
}

/* ikon kecil di kiri teks */
.nav a .ico{
  width:14px; height:14px; display:inline-flex; align-items:center; justify-content:center;
  opacity:.95;
}

/* responsif: biar bisa geser saat sempit */
@media (max-width: 640px){
  .nav{overflow:auto; padding-bottom:6px}
}

.nav a.active{
  background:linear-gradient(180deg, var(--blue-500), var(--blue-600));
  border-color:transparent;
  box-shadow:0 10px 18px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.2);
}
/* ===== Link reset biar gak ungu/bergaris ===== */
a, a:link, a:visited { color:#fff; text-decoration:none }
a:hover { text-decoration:none; opacity:.92 }

/* ===== Navbar: rata kanan + tombol timbul jelas ===== */
.navbar .row{ display:flex; align-items:center }
.nav{
  margin-left:auto; display:flex; gap:14px; flex-wrap:wrap; justify-content:flex-end;
}

/* gaya tombol lebih kuat + hilangkan underline visited di menu */
.nav a, .nav a:visited{
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 14px; border-radius:10px;
  font-weight:800; letter-spacing:.2px; text-transform:uppercase;
  background:linear-gradient(180deg, rgba(255,255,255,.22), rgba(255,255,255,.12));
  border:1px solid rgba(255,255,255,.25);
  box-shadow:0 8px 16px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.22);
}
.nav a:hover{
  transform:translateY(-1px);
  background:linear-gradient(180deg, rgba(255,255,255,.30), rgba(255,255,255,.16));
  border-color:rgba(255,255,255,.35);
  box-shadow:0 12px 20px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.25);
}

/* state aktif (halaman sekarang) */
.nav a.active{
  background:linear-gradient(180deg, var(--blue-500), var(--blue-600));
  border-color:transparent;
  box-shadow:0 10px 18px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.2);
}

/* ikon kecil di kiri label */
.nav a .ico{
  width:14px; height:14px; display:inline-flex; align-items:center; justify-content:center;
  line-height:1; opacity:.95;
}
/* Brand logo only */
.brand{
  display:flex; align-items:center; gap:10px;
  font-weight:900; letter-spacing:.5px;
}
.brand-logo{
  height:80px; /* sesuaikan 34–48 */
  width:auto; display:block;
  object-fit:contain;
  /* efek halus agar “nimbul” di background biru */
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.35));
}

/* Sembunyikan kotak gradient lama kalau masih ada .brand .logo */
.brand .logo{ display:none }

/* Optional (aksesibilitas, teks tersembunyi) */
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
/* Background global dgn overlay gradient biru */
html, body{
  /* urutan: overlay gradient di atas, foto di bawah */
  background:
    url('/assets/img/background.webp') center top / cover no-repeat fixed;
  color: var(--ink);
}

/* Safari/iOS kadang lag kalau fixed, ganti ke scroll di mobile */
@media (max-width: 768px){
  html, body{
    background-attachment: scroll;
    background-position: center;
  }
}
/* Panel semi-transparan tapi pekat + blur */
.banner,
.promo,
.cta-card,
.card,
.table-wrap {
  background: linear-gradient(180deg, rgba(18,51,93,.90), rgba(12,35,64,.90)) !important;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.10);
}
/* ===== Aksen per menu (pembeda) ===== */
.nav a{ --accent:#9bc5ff; position:relative; }
.nav a .ico{
  width:16px; height:16px; border-radius:6px;
  display:inline-flex; align-items:center; justify-content:center; line-height:1;
  background: radial-gradient(circle at 30% 30%, var(--accent), transparent 60%);
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.10);
}

/* set warna aksen tiap kategori */
.nav a.prediksi{ --accent:#a78bfa; } /* ungu */
.nav a.slot{     --accent:#f59e0b; } /* oranye */
.nav a.alat{     --accent:#94a3b8; } /* abu */
.nav a.data{     --accent:#22d3ee; } /* toska */
.nav a.bukti{    --accent:#fbbf24; } /* emas */
.nav a.home{     --accent:#60a5fa; } /* biru */

/* item aktif: lebih terang + ring + glow garis bawah */
.nav a.active{
  color:#fff;
  background: linear-gradient(180deg, rgba(255,255,255,.28), rgba(255,255,255,.14));
  border-color: rgba(255,255,255,.35);
  box-shadow:
    0 12px 22px rgba(0,0,0,.38),
    inset 0 0 0 1px rgba(255,255,255,.25),
    0 0 0 2px color-mix(in sRGB, var(--accent) 45%, transparent); /* aman kalau didukung */
}
@supports not (color: color-mix(in sRGB, #000 0%, #000 0%)) {
  .nav a.active{ box-shadow:0 12px 22px rgba(0,0,0,.38), inset 0 0 0 1px rgba(255,255,255,.25); }
}
/* glow garis bawah */
.nav a.active::after{
  content:""; position:absolute; left:12px; right:12px; bottom:-6px; height:3px; border-radius:999px;
  background: radial-gradient(12px 6px at 50% 50%, var(--accent), transparent 65%);
  opacity:.85;
}

/* hover ikut aksen */
.nav a:hover{
  transform:translateY(-1px);
  border-color: rgba(255,255,255,.40);
  box-shadow:0 14px 24px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.25);
}
/* ====== RESET YANG BIKIN PECAH DI MOBILE ====== */
html,body{overflow-x:hidden}
img{max-width:100%;height:auto}

/* ====== MOBILE < 768px ====== */
@media (max-width: 768px){
  .container{padding:0 12px}

  /* Topbar menumpuk rapi */
  .topbar .row{flex-direction:column;align-items:flex-start;gap:6px;padding:8px 0}
  .topbar .links{gap:10px;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .topbar .links::-webkit-scrollbar{display:none}

  /* Navbar: brand + bar menu scroll horizontal */
  .navbar .row{gap:10px;padding:8px 0}
  .brand-logo{height:30px}

  .nav{
    margin-left:0;                 /* jangan paksa ke kanan di mobile */
    justify-content:flex-start;
    gap:8px; padding:6px 0;
    overflow-x:auto; white-space:nowrap; /* jadi toolbar geser */
    -webkit-overflow-scrolling:touch; scroll-behavior:smooth;
    touch-action:pan-x;
  }
  .nav::-webkit-scrollbar{display:none}
  .nav a, .nav a:visited{
    font-size:12px; padding:8px 10px; border-radius:9px;
    white-space:nowrap;              /* jangan patah 2 baris */
  }
  .nav a .ico{width:14px;height:14px}
  .nav a.active::after{display:none} /* hilangkan glow garis bawah biar hemat ruang */

  /* Marquee + speaker lebih rapat */
  .marquee .bar{gap:6px}
  .speaker{width:24px;height:24px;font-size:14px}

  /* Hero jadi 1 kolom */
  .hero-grid{grid-template-columns:1fr}
  .banner .title{font-size:22px}
  .btn{padding:8px 12px;font-size:13px}

  /* Kartu/section 1 kolom */
  .grid{grid-template-columns:1fr}
  .cta-grid{grid-template-columns:1fr}
  .table-wrap{font-size:13px}
}

/* ====== MOBILE KECIL < 380px ====== */
@media (max-width: 380px){
  .brand-logo{height:26px}
  .nav a, .nav a:visited{font-size:11px;padding:7px 9px}
  .btn{padding:7px 10px;font-size:12px}
}
/* ==== MOBILE: perbesar logo & kasih jarak kiri/kanan ==== */
@media (max-width: 768px){
  /* tambah padding horizontal navbar */
  .navbar .row{
    padding-left: max(16px, env(safe-area-inset-left, 0px));
    padding-right: max(16px, env(safe-area-inset-right, 0px));
    gap: 10px;
  }

  /* logo lebih besar dan tidak ketarik mengecil */
  .brand{ flex: 0 0 auto; margin-right: 8px; }
  .brand-logo{
    height: 42px;          /* naikkan ukuran logo */
    width: auto;
  }

  /* toolbar menu tetap bisa digeser, tapi punya jarak kiri */
  .nav{
    margin-left: 0;
    padding-left: 6px;     /* biar tidak nempel ke logo */
    gap: 8px;
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
  }
}

@media (max-width: 420px){
  .navbar .row{
    padding-left: max(18px, env(safe-area-inset-left, 0px));
    padding-right: max(18px, env(safe-area-inset-right, 0px));
  }
  .brand-logo{ height: 46px; }  /* ekstra besar di layar kecil */
}
/* ==== MOBILE LAYOUT: logo center + nav 2 kolom ==== */
@media (max-width: 768px){
  /* Navbar jadi bertumpuk & center */
  .navbar .row{
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 10px 0;
  }

  /* Logo di tengah & lebih besar */
  .brand{ margin: 0 auto; }
  .brand-logo{ height: 56px; width: auto; }

  /* Menu jadi grid 2 kolom: 3 item kiri, 3 item kanan */
  .nav{
    margin-left: 0;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;   /* 2 kolom */
    gap: 10px 12px;                   /* row/column gap */
    justify-items: stretch;
    overflow: visible;                 /* hilangkan scroll horizontal */
    white-space: normal;
  }
  .nav a, .nav a:visited{
    width: 100%;
    justify-content: center;           /* label + ikon di tengah */
    min-height: 44px;                  /* target sentuh nyaman */
    font-size: 13px;
    border-radius: 12px;
  }
  .nav a .ico{ width:16px; height:16px }

  /* (opsional) rapikan underline/glow aktif di mobile */
  .nav a.active::after{ display:none; }
}

/* layar sangat kecil tetap 2 kolom, perkecil font/padding */
@media (max-width: 380px){
  .brand-logo{ height: 50px; }
  .nav{ gap: 8px 10px; }
  .nav a, .nav a:visited{ font-size:12px; padding:7px 9px; min-height:40px; }
}
.glowlink{
  --c1:#60a5fa; --c2:#22d3ee;
  position:relative; display:inline-flex; align-items:center; gap:8px;
  padding:7px 12px; border-radius:12px; font-weight:800;
  background:rgba(0,0,0,.12); color:#fff;
}
.glowlink::before{
  content:""; position:absolute; inset:0; border-radius:12px;
  padding:1px; background:linear-gradient(135deg,var(--c1),var(--c2));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
}
.glowlink:hover{ box-shadow:0 10px 22px rgba(0,0,0,.3) }
/* === Hero-right: dua tombol mewah === */
.hero-right{
  display:grid;
  grid-template-columns: 1fr;
  grid-template-rows: none;
  gap:16px;
}

.cta-btn{
  position:relative;
  display:flex; align-items:flex-start; gap:12px;
  padding:16px 18px; border-radius:16px;
  text-decoration:none; color:#fff;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(47,122,229,.20), rgba(18,51,93,.18));
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow:0 12px 28px rgba(0,0,0,.32), inset 0 0 0 1px rgba(255,255,255,.04);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.cta-btn .title{font-weight:900; font-size:18px; line-height:1.1}
.cta-btn .desc{opacity:.9; font-size:13px; margin-top:2px}
.cta-btn .ico{
  width:40px; height:40px; border-radius:12px;
  display:inline-grid; place-items:center; font-size:20px; line-height:1;
  background:linear-gradient(180deg, rgba(255,255,255,.26), rgba(255,255,255,.12));
  border:1px solid rgba(255,255,255,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 10px 18px rgba(0,0,0,.28);
}

/* varian warna */
.cta-btn.primary{
  background:linear-gradient(180deg, rgba(47,122,229,.35), rgba(18,51,93,.24));
  border-color: rgba(147,189,255,.35);
}
.cta-btn.dark{
  background:linear-gradient(180deg, rgba(18,34,56,.70), rgba(10,22,40,.60));
}

/* efek shine */
.cta-btn .shine{
  pointer-events:none;
  position:absolute; top:-60%; left:-30%;
  width:60%; height:220%;
  background:radial-gradient(220px 220px at 50% 50%, rgba(255,255,255,.22), transparent 60%);
  transform:rotate(25deg);
  opacity:0;
}
.cta-btn:hover{ transform:translateY(-2px); border-color:rgba(255,255,255,.28) }
.cta-btn:hover .shine{ animation:shineSlide 1.1s linear forwards }
@keyframes shineSlide{
  0%{ transform:translateX(0) rotate(25deg); opacity:.0 }
  10%{ opacity:.75 }
  100%{ transform:translateX(320%) rotate(25deg); opacity:0 }
}

/* responsif: di layar kecil tetap rapi; di >= 900px bisa dibuat 2 kolom kalau mau */
@media (min-width: 900px){
  .hero-right{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px){
  .cta-btn{ padding:14px 16px }
  .cta-btn .title{ font-size:17px }
  .cta-btn .ico{ width:38px; height:38px; font-size:18px }
}
/* ===== Layout dengan sidebar kiri ===== */
.layout{display:grid; grid-template-columns:280px 1fr; gap:16px}
.sidebar{position:sticky; top:72px; align-self:start}
.side-card{
  background:linear-gradient(180deg, rgba(18,51,93,.92), rgba(12,35,64,.90));
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px; padding:14px; box-shadow:0 12px 28px rgba(0,0,0,.32);
}
.side-welcome{display:flex; gap:10px; align-items:center; margin-bottom:10px}
.avatar{width:32px;height:32px;border-radius:999px;display:grid;place-items:center;
  background:linear-gradient(180deg, rgba(255,255,255,.25), rgba(255,255,255,.12));
  border:1px solid rgba(255,255,255,.18); font-size:16px}
.side-title{font-weight:900}
.side-sub{opacity:.85; font-size:12px}
.side-actions{display:flex; flex-direction:column; gap:10px}
.btn-small{
  display:block; width:100%; text-align:center; padding:10px 12px; border-radius:10px;
  font-weight:800; letter-spacing:.2px; text-decoration:none; color:#fff;
  border:1px solid rgba(255,255,255,.18);
}
.btn-green{background:linear-gradient(180deg,#34d399,#16a34a); box-shadow:0 10px 18px rgba(0,0,0,.28)}
.btn-ghost{background:transparent; color:#eaf2ff}
.btn-small:hover{transform:translateY(-1px)}

/* Browse section */
.side-section{background:rgba(203,255,138,.14); color:#eaf2ff; font-weight:900;
  padding:8px 10px; border-radius:10px; margin:-4px -4px 10px}
.side-list{display:flex; flex-direction:column; gap:8px}
.side-list a{color:#fff; opacity:.95; text-decoration:none; padding:6px 4px; border-radius:8px}
.side-list a:hover{background:rgba(255,255,255,.08)}

/* Dark mode row + switch */
.side-row{display:flex; align-items:center; justify-content:space-between}
.switch{position:relative; width:44px; height:24px}
.switch input{opacity:0; width:0; height:0}
.slider{
  position:absolute; inset:0; border-radius:999px;
  background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.18);
  transition:.2s;
}
.slider::before{
  content:""; position:absolute; width:18px; height:18px; left:3px; top:50%;
  transform:translateY(-50%); border-radius:50%; background:#fff; transition:.2s;
}
.switch input:checked + .slider{
  background:linear-gradient(180deg,#2f7ae5,#1e5aa3); border-color:transparent;
}
.switch input:checked + .slider::before{ left:23px }

/* Theme override saat dark mode aktif (pakai class di <body>) */
body.theme-dark{
  --blue-950:#020b16; --blue-900:#0a1424; --blue-800:#0f2340; --blue-700:#133256;
  --blue-600:#1a4e85; --blue-500:#2971c7; --ink:#eaf2ff;
}

/* Responsif: sidebar stack di atas konten */
@media (max-width: 1024px){ .layout{grid-template-columns:250px 1fr} }
@media (max-width: 900px){
  .layout{grid-template-columns:1fr}
  .sidebar{position:relative; top:auto; order:-1}
}
/* ===== Layout 3 kolom: Sidebar | Rail Gambar | Konten ===== */
.layout.has-rail{
  display:grid; gap:16px;
  grid-template-columns: 280px 260px 1fr; /* kiri 280, rail 260, konten sisanya */
}

/* Rail gambar (bukan overlay, mengikuti flow halaman) */
.side-rail{
  align-self:start;
  position:sticky; top:72px;            /* sesuaikan tinggi navbar kamu */
  display:flex; flex-direction:column; gap:12px;
}

/* Kartu gambar */
.rail-card{
  display:block; position:relative; overflow:hidden; border-radius:16px;
  background:linear-gradient(180deg, rgba(18,51,93,.88), rgba(12,35,64,.84));
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 12px 28px rgba(0,0,0,.32), inset 0 0 0 1px rgba(255,255,255,.04);
  transform: rotate(var(--rot, 0deg));   /* efek miring halus */
  transition:transform .18s ease, box-shadow .18s ease;
}
.rail-card img{display:block; width:100%; height:auto}
.rail-card:hover{transform:translateY(-2px) rotate(var(--rot,0deg));
  box-shadow:0 16px 34px rgba(0,0,0,.38)}

/* "Polaroid tilt" biar tidak monoton */
.side-rail .rail-card:nth-child(odd){  --rot:-1.2deg }
.side-rail .rail-card:nth-child(even){ --rot: .9deg }

/* Sembunyikan rail di layar sempit agar tidak menutup konten */
@media (max-width: 1100px){
  .layout.has-rail{ grid-template-columns: 1fr }
  .side-rail{ display:none }
}
/* rail di kanan sidebar (sudah ada) — pastikan 3 kolom aktif */
.layout.has-rail{ grid-template-columns:280px 260px 1fr !important; }
.side-rail{ align-self:start; position:sticky; top:72px; }

/* === Slider rail (bukan numpuk) === */
.rail-slider{
  width:100%; aspect-ratio: 4 / 5;     /* tinggi proporsional */
  position:relative; overflow:hidden; border-radius:16px;
  background:linear-gradient(180deg, rgba(18,51,93,.90), rgba(12,35,64,.88));
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 12px 28px rgba(0,0,0,.32), inset 0 0 0 1px rgba(255,255,255,.04);
}
.rail-slider .track{
  display:flex; height:100%; transform:translateX(0);
  transition: transform .45s cubic-bezier(.22,.61,.36,1);
}
.rail-slider .slide{ min-width:100%; height:100%; display:block; }
.rail-slider img{ width:100%; height:100%; object-fit:cover; display:block }

/* nav buttons */
.rail-slider .nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:34px; height:34px; border-radius:999px; border:1px solid rgba(255,255,255,.25);
  background:rgba(0,0,0,.25); color:#fff; font-size:20px; line-height:1;
  display:grid; place-items:center; cursor:pointer;
  box-shadow:0 6px 16px rgba(0,0,0,.35); backdrop-filter:blur(6px);
}
.rail-slider .prev{ left:8px } .rail-slider .next{ right:8px }
.rail-slider .nav:hover{ background:rgba(255,255,255,.18) }

/* dots */
.rail-slider .dots{
  position:absolute; left:0; right:0; bottom:8px; display:flex; gap:6px; justify-content:center;
}
.rail-slider .dot{
  width:8px; height:8px; border-radius:999px; border:0; cursor:pointer;
  background:rgba(255,255,255,.35); box-shadow:0 0 0 1px rgba(0,0,0,.25) inset;
}
.rail-slider .dot.active{ background:#fff }

/* sembunyikan di layar sempit jika perlu ruang */
@media (max-width:1100px){ .side-rail{ display:none } }
/* Rail 3 kolom tetap */
.layout.has-rail{ grid-template-columns:280px 260px 1fr !important; }
.side-rail{ align-self:start; position:sticky; top:72px; }

/* === Slider: auto-height & gambar ukuran asli === */
.rail-slider{
  width:100%;
  position:relative; overflow:hidden; border-radius:16px;
  background:linear-gradient(180deg, rgba(18,51,93,.90), rgba(12,35,64,.88));
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 12px 28px rgba(0,0,0,.32), inset 0 0 0 1px rgba(255,255,255,.04);
  height:auto;             /* kontainer akan kita set via JS */
}

/* jangan pakai aspect-ratio & jangan paksa height 100% di sini */
.rail-slider .track{
  display:flex; transform:translateX(0);
  transition: transform .45s cubic-bezier(.22,.61,.36,1);
}
.rail-slider .slide{
  min-width:100%;
  display:flex; justify-content:center; align-items:flex-start;
  padding:0;                  /* biar natural */
}

/* gambar mengikuti ukuran asli: tidak di-crop / tidak di-stretch */
.rail-slider img{
  max-width:100%;    /* downscale kalau lebih lebar dari rail */
  height:auto;       /* pertahankan rasio asli */
  display:block;
  object-fit:contain;
}

/* nav & dots (biarkan seperti sebelumnya, tidak berubah) */
.rail-slider .nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:34px;height:34px;border-radius:999px;border:1px solid rgba(255,255,255,.25);
  background:rgba(0,0,0,.25);color:#fff;display:grid;place-items:center;cursor:pointer;
  box-shadow:0 6px 16px rgba(0,0,0,.35);backdrop-filter:blur(6px)
}
.rail-slider .prev{left:8px}.rail-slider .next{right:8px}
.rail-slider .dots{position:absolute;left:0;right:0;bottom:8px;display:flex;gap:6px;justify-content:center}
.rail-slider .dot{width:8px;height:8px;border-radius:999px;border:0;background:rgba(255,255,255,.35)}
.rail-slider .dot.active{background:#fff}
/* Auto-height halus + animasi */
.rail-slider{ transition: height .35s ease; }
.rail-slider .track{
  transition: transform .6s cubic-bezier(.22,.61,.36,1);
}
.rail-slider .slide img{
  max-width:100%; height:auto; display:block; object-fit:contain;
  will-change: transform, opacity;
}

/* Ken-Burns: aktif hanya pada slide yang sedang tampil */
.rail-slider .slide.live img{
  animation: kbA 4.2s ease-in-out forwards;
}
.rail-slider .slide.live.kbB img{
  animation-name: kbB;            /* arah lain supaya variatif */
}

/* arah A: zoom + pan atas */
@keyframes kbA{
  0%{   transform: scale(1) translate(0,0) }
  100%{ transform: scale(1.06) translateY(-2%) }
}
/* arah B: zoom + pan kanan sedikit */
@keyframes kbB{
  0%{   transform: scale(1) translate(0,0) }
  100%{ transform: scale(1.06) translateX(1.5%) }
}

/* (opsional) sembunyikan tombol prev/next kalau pure auto */
@media (hover:none){
  .rail-slider .nav{ display:none }
}
/* === MOBILE: tampilkan rail di bawah sidebar, full width === */
@media (max-width:1100px){
  .layout.has-rail{ grid-template-columns: 1fr; }

  .side-rail{
    display:flex !important;      /* tampilkan lagi */
    position:relative;            /* non-sticky di mobile */
    top:auto;
    width:auto;
    order:2;                      /* urutan: sidebar -> rail -> main (sesuai HTML) */
    gap:12px;
  }

  .rail-slider{ width:100%; }     /* slider melebar penuh */
  .rail-slider .nav{ width:32px; height:32px; }  /* tombol sedikit lebih kecil */
}
/* ==== Sidebar: samakan lebar semua blok ==== */
.sidebar{
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.sidebar, .side-card, .side-card * { box-sizing: border-box; }

.side-card{
  width: 100%;
  margin: 0;                   /* hilangkan selisih */
  padding: 14px;
  border-radius: 16px;
}

/* Header "Browse" biar tidak melebar/menyempit sendiri */
.side-section{
  display: block;
  width: 100%;
  margin: 5 5 10px;            /* ganti margin negatif sebelumnya */
  padding: 20px 15px;
  border-radius: 12px;
}

/* Pastikan elemen di dalamnya juga full width */
.side-actions{ width: 100%; }
.side-actions .btn-small{ width: 100%; }
.side-list{ width: 100%; }
.side-row{ width: 100%; }
/* di style.css */
html,body{
  background:
    /* … */
    url('/assets/img/background.webp?v=20250823') center top / cover no-repeat fixed;
}
/* wrap hijau gelap */
.lr-wrap{background:#061806;border-radius:10px;padding:16px;margin:16px 0;
  border:1px solid rgba(120,255,120,.06)}
.lr-title{margin:0 4px 12px;color:#b7ffb7;font-weight:900;letter-spacing:.2px}

/* grid kartu */
.lr-card{background:rgba(0,0,0,.2);border:1px solid rgba(80,255,120,.12);border-radius:12px;
  padding:14px;position:relative;box-shadow:inset 0 8px 18px rgba(0,0,0,.3)}
.lr-card::after{content:"";position:absolute;right:10px;top:10px;width:10px;height:6px;border-radius:12px;background:rgba(120,255,120,.15)}
.lr-headline{color:#caffca;font-weight:900;text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}
.lr-num{font-weight:900;font-size:28px;color:blue;text-shadow:0 0 10px rgba(90,255,90,.25);line-height:1.1;margin-bottom:6px}
.lr-date{font-size:11px;color:rgba(200,255,200,.75)}
/* Warna tema yang kamu minta */
:root{
  --teal-100:#1e9fbe;   /* warna dasar kartu + grid bg */
  --teal-ink:#07343a;   /* teks utama di atas warna itu */
  --teal-ring:rgba(7,52,58,.18);
}

/* jika halaman pakai layout grid 3 kolom, pastikan section ini lebar penuh */
.latest-wrap{ grid-column: 1 / -1; }

/* judul */
.latest-title{
    font-size:30px;
    text-align:center;
  margin:0 0 10px; font-weight:900; letter-spacing:.2px;
  color:var(--teal-ink);
  background:var(--teal-100);
  padding:10px 14px; border-radius:12px;
  border:1px solid var(--teal-ring);
}

/* GRID MENYAMPING */
.latest-results{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
  gap:14px;
}

/* Kartu */
.lr-card{
  background:var(--teal-100);
  color:var(--teal-ink);
  border:1px solid var(--teal-ring);
  border-radius:14px;
  padding:12px 14px;
  box-shadow:0 8px 18px rgba(0,0,0,.15);
}
.lr-head{font-size:20px; text-align: center; font-weight:800; opacity:.85; letter-spacing:.3px}
.lr-num{font-size:32px; text-align: center; font-weight:900; line-height:1.1; margin:6px 0 2px}
.lr-date{font-size:15px; text-align: center; font-weight:700; opacity:.8}

/* responsif */
@media (max-width:640px){
  .latest-results{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width:420px){
  .latest-results{ grid-template-columns: 1fr; }
}
/* Tagline full-width di baris baru */
.tagline{
  text-align:center;
  padding:12px 16px;
  border-radius:14px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.5px;

  /* efek “neon” biru + glass */
  color:#eaf2ff;
  text-shadow:0 0 10px rgba(155,197,255,.45), 0 2px 0 rgba(0,0,0,.45);
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 10px 24px rgba(0,0,0,.32), inset 0 0 0 1px rgba(255,255,255,.03);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);

  /* ukuran responsif */
  font-size: clamp(14px, 2.1vw, 28px);
  line-height:1.25;
}

/* Mobile: tetap full-width, jarak rapat */
@media (max-width: 900px){
  .layout.has-rail{ grid-template-columns:1fr; }   /* layout jadi 1 kolom */
  .tagline{ margin-top:8px; font-size: clamp(13px, 4.2vw, 18px); }
}
/* ===== Spacing Hasil Togel & Tagline ===== */

/* jarak atas–bawah blok "Hasil Togel Terbaru" */
.latest-wrap{
  margin-top: 14px;
  margin-bottom: 24px;   /* <<< jarak ke tagline di bawah */
}

/* jarak antara kartu-kartu result */
.latest-results{
  display: grid;
  grid-template-columns: repeat(5, minmax(220px, 1fr)); /* sesuaikan */
  gap: 16px;                 /* <<< renggang horizontal + vertikal */
  padding: 8px 0 6px;        /* sedikit napas di dalam */
}

/* jika masih terasa rapat, bisa tambah jarak di kartu */
.lr-card{ margin-bottom: 8px; }

/* jarak ekstra di tagline biar tidak mepet grid */
.tagline{ margin-top: 18px; }

/* versi mobile: jarak sedikit lebih kecil */
@media (max-width: 900px){
  .latest-results{ grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .latest-wrap{ margin-bottom: 18px; }
  .tagline{ margin-top: 14px; }
}
/* ===== Footer badges strip ===== */
.footer{
  background: linear-gradient(180deg, rgba(18,51,93,.90), rgba(12,35,64,.90));
  border-top: 1px solid rgba(255,255,255,.10);
  padding: 18px 0 22px;               /* beri ruang buat badges + copyright */
}

.footer-badges{
  display: flex;
  justify-content: center;            /* sejajar tengah seperti header */
  align-items: center;
  margin: 6px 0 14px;
}

.footer-badges img{
  max-width: 100%;
  height: auto;
  image-rendering: -webkit-optimize-contrast;
  filter: drop-shadow(0 6px 16px rgba(0,0,0,.30));
}

/* copyright tetap rapi di tengah */
.footer .copyright{
  text-align: center;
  opacity: .85;
  font-size: 13px;
}

/* Mobile: beri sedikit padding agar tidak mentok */
@media (max-width: 768px){
  .footer{ padding: 14px 0 18px; }
  .footer-badges{ margin: 4px 0 12px; }
}
/* --- Paksa footer keluar dari grid dan melebar penuh --- */
.footer{
  grid-column: 1 / -1 !important;   /* kalau footer berada di dalam .layout grid */
  width: 100%;
  align-self: stretch;
}

/* Container footer tetap center seperti header */
.footer .container{
  max-width: 1280px;           /* samakan dengan header */
  margin: 0 auto;
  padding: 0 16px;
}

/* Badges & copyright benar-benar center */
.footer-badges{
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 8px 0 12px;
}
.footer-badges img{
  display: block;
  height: auto;
  max-width: 100%;
}
.footer .copyright{
  text-align: center;
}
/* Layout 2 kolom */
.admin-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.admin-top-right{display:flex;gap:8px;align-items:center}
.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);color:#fff}
.pill-ok{background:linear-gradient(180deg,#1ec98d,#129b6b);border-color:transparent}

.admin-layout{
  display:grid; gap:16px;
  grid-template-columns: 220px 1fr;
  margin-top:12px;
}
.admin-side{align-self:start; position:sticky; top:72px}
.tabs{display:flex; flex-direction:column; gap:10px}
.tablink{
  display:block; padding:10px 12px; border-radius:12px; font-weight:800; color:#fff;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.14);
}
.tablink:hover{transform:translateX(2px)}
.tablink.active{
  background:linear-gradient(180deg, var(--blue-500), var(--blue-600));
  border-color:transparent; box-shadow:0 10px 18px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.2);
}

.admin-content{min-height:300px}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* tombol hapus */
.btn-danger{
  background:#b63f3f !important; border-color:transparent !important; color:#fff !important;
}

/* responsif */
@media (max-width: 900px){
  .admin-layout{ grid-template-columns:1fr }
  .admin-side{ position:relative; top:auto }
  .tabs{ flex-direction:row; overflow:auto; padding-bottom:6px }
  .tablink{ white-space:nowrap }
}

.post-content img{max-width:100%;height:auto}
.post-content .alignleft{float:left;margin:0 1em 1em 0}
.post-content .alignright{float:right;margin:0 0 1em 1em}
.post-content .aligncenter{display:block;margin-left:auto;margin-right:auto}
.post-content figure.image img{display:block;margin:0 auto}
