/* ============================================================
   AKADEMI TOTOVIP — Shared Stylesheet
   Dark luxe theme: gold/ruby accent on charcoal base
   ============================================================ */

:root{
  --tv-bg:#0a0a0e;
  --tv-surface:#13131a;
  --tv-surface-2:#1c1c26;
  --tv-surface-3:#252530;
  --tv-text:#e8e8ed;
  --tv-text-mute:#8a8a95;
  --tv-text-faint:#5a5a65;
  --tv-gold:#d4af37;
  --tv-gold-bright:#f4d03f;
  --tv-gold-dark:#8b7028;
  --tv-ruby:#c0392b;
  --tv-ruby-dark:#8b1f15;
  --tv-emerald:#27ae60;
  --tv-azure:#3498db;
  --tv-border:rgba(212,175,55,0.18);
  --tv-border-strong:rgba(212,175,55,0.35);
  --tv-radius:10px;
  --tv-radius-lg:14px;
  --tv-shadow:0 4px 24px rgba(0,0,0,0.4);
  --tv-shadow-gold:0 4px 16px rgba(212,175,55,0.25);
  --tv-font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --tv-mono:'JetBrains Mono','Consolas',Monaco,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}

body{
  font-family:var(--tv-font);
  background:var(--tv-bg);
  color:var(--tv-text);
  line-height:1.7;
  font-size:16px;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

/* ============= HEADER ============= */
.tv-header{
  position:sticky;top:0;z-index:100;
  background:rgba(10,10,14,0.95);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--tv-border);
}
.tv-header-inner{
  max-width:1200px;margin:0 auto;padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.tv-logo{display:flex;align-items:center;gap:8px;flex-shrink:0;text-decoration:none}
.tv-logo-img{height:42px;width:auto;object-fit:contain;display:block}
.tv-logo-tag{font-size:11px;color:var(--tv-gold);font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:3px 7px;border:1px solid var(--tv-gold);border-radius:4px;line-height:1;background:rgba(212,175,55,0.08)}
.tv-logo img{height:42px;width:auto;object-fit:contain}
.tv-logo-text{font-weight:800;font-size:18px;letter-spacing:-0.5px}
.tv-logo-text .tv-suffix{color:var(--tv-gold);font-weight:600}

.tv-nav{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tv-nav a{
  color:var(--tv-text);font-size:14px;font-weight:500;
  padding:8px 14px;border-radius:6px;transition:all .2s;
}
.tv-nav a:hover{color:var(--tv-gold-bright);background:rgba(212,175,55,0.08)}
.tv-nav a.active{color:var(--tv-gold)}
.tv-nav a.tv-nav-cta{
  background:linear-gradient(135deg,var(--tv-gold) 0%,var(--tv-gold-bright) 100%);
  color:#1a1a1f;font-weight:700;padding:8px 18px;margin-left:6px;
}
.tv-nav a.tv-nav-cta:hover{background:linear-gradient(135deg,var(--tv-gold-bright) 0%,#fff 100%);color:#000;transform:translateY(-1px)}
.tv-nav a.tv-nav-cta-ghost{border:1px solid var(--tv-gold);color:var(--tv-gold-bright);padding:7px 16px}

/* ============= BREADCRUMB ============= */
.tv-breadcrumb{
  max-width:880px;margin:14px auto 0;padding:0 20px;
  font-size:13px;color:var(--tv-text-mute);
}
.tv-breadcrumb a{color:var(--tv-gold);transition:color .2s}
.tv-breadcrumb a:hover{color:var(--tv-gold-bright)}
.tv-breadcrumb span.sep{margin:0 8px;color:var(--tv-text-faint)}

/* ============= HERO ============= */
.tv-hero{max-width:1200px;margin:24px auto 0;padding:0 20px}
.tv-hero-banner{
  position:relative;width:100%;aspect-ratio:16/9;
  border-radius:14px;overflow:hidden;
  background:linear-gradient(135deg,#1c1c26 0%,#2a1a1a 100%);
  border:1px solid var(--tv-border);
  box-shadow:0 8px 40px rgba(0,0,0,0.5);
}
.tv-hero-banner img{width:100%;height:100%;object-fit:cover}
.tv-hero-banner::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(10,10,14,0.6) 100%);
  pointer-events:none;
}

/* ============= RESULT WIDGET (homepage hero strip) ============= */
.tv-result-widget{
  max-width:1200px;margin:20px auto 0;padding:0 20px;
}
.tv-result-bar{
  background:linear-gradient(135deg,var(--tv-surface) 0%,rgba(212,175,55,0.08) 100%);
  border:1px solid var(--tv-border-strong);
  border-radius:var(--tv-radius-lg);
  padding:18px 20px;
}
.tv-result-head{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:10px;margin-bottom:14px;
  padding-bottom:12px;border-bottom:1px solid var(--tv-border);
}
.tv-result-title{
  font-size:15px;font-weight:700;color:var(--tv-gold-bright);
  display:flex;align-items:center;gap:8px;
}
.tv-result-status{
  display:flex;align-items:center;gap:6px;
  font-size:12px;color:var(--tv-emerald);
}
.tv-result-status .dot{
  width:8px;height:8px;background:var(--tv-emerald);border-radius:50%;
  box-shadow:0 0 10px var(--tv-emerald);animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.6;transform:scale(0.85)}}

.tv-result-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
}
.tv-result-card{
  background:var(--tv-surface-2);
  border:1px solid var(--tv-border);
  border-radius:var(--tv-radius);
  padding:14px;text-align:center;
  transition:transform .25s,border-color .25s;
  position:relative;overflow:hidden;
}
.tv-result-card:hover{
  transform:translateY(-3px);
  border-color:var(--tv-gold);
  box-shadow:var(--tv-shadow-gold);
}
.tv-result-card .pasaran-name{
  font-size:13px;font-weight:700;color:var(--tv-gold);
  letter-spacing:0.5px;margin-bottom:4px;
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.tv-result-card .pasaran-flag{font-size:14px}
.tv-result-card .pasaran-date{
  font-size:11px;color:var(--tv-text-mute);margin-bottom:8px;
}
.tv-result-card .pasaran-number{
  font-family:var(--tv-mono);font-size:26px;font-weight:700;
  color:var(--tv-gold-bright);letter-spacing:6px;
  padding:8px 0;
}
.tv-result-card .pasaran-cta{
  font-size:11px;color:var(--tv-azure);
  margin-top:6px;text-decoration:none;
}
.tv-result-card .pasaran-cta:hover{color:var(--tv-gold-bright)}

.tv-result-foot{
  margin-top:12px;padding-top:12px;
  border-top:1px solid var(--tv-border);
  font-size:12px;color:var(--tv-text-mute);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
}
.tv-result-foot a{color:var(--tv-gold);font-weight:600}

/* ============= STATUS BAR ============= */
.tv-status-bar{max-width:880px;margin:20px auto 0;padding:0 20px}
.tv-status-inner{
  background:linear-gradient(135deg,rgba(46,204,113,0.12) 0%,rgba(46,204,113,0.04) 100%);
  border:1px solid rgba(46,204,113,0.35);
  border-radius:10px;padding:14px 18px;
  display:flex;align-items:center;gap:12px;font-size:14px;
}
.tv-status-dot{
  width:10px;height:10px;background:#2ecc71;border-radius:50%;
  box-shadow:0 0 12px rgba(46,204,113,0.6);animation:pulse 2s infinite;flex-shrink:0;
}
.tv-status-inner strong{color:#5dd599}

/* ============= MAIN ARTICLE ============= */
.tv-main{max-width:880px;margin:24px auto;padding:0 20px;flex:1}
.tv-article{
  background:var(--tv-surface);padding:36px 32px;
  border-radius:var(--tv-radius);
  border:1px solid var(--tv-border);
  box-shadow:var(--tv-shadow);
}

h1{
  font-size:clamp(22px,4vw,32px);font-weight:800;
  background:linear-gradient(135deg,var(--tv-gold) 0%,var(--tv-gold-bright) 60%,var(--tv-gold) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  text-align:center;line-height:1.3;margin-bottom:24px;
  padding-bottom:20px;border-bottom:2px solid var(--tv-border);
}
h2{
  font-size:clamp(18px,2.4vw,22px);font-weight:700;color:var(--tv-gold-bright);
  margin:32px 0 14px;padding:10px 14px;
  background:linear-gradient(90deg,rgba(212,175,55,0.14) 0%,transparent 100%);
  border-left:3px solid var(--tv-gold);border-radius:4px;
}
h3{font-size:17px;font-weight:600;color:var(--tv-gold);margin:18px 0 8px}
h4{font-size:15px;font-weight:600;color:var(--tv-gold);margin:14px 0 6px}

.tv-article p{color:var(--tv-text);margin-bottom:14px;text-align:justify}
.tv-article a{
  color:var(--tv-gold-bright);font-weight:600;
  border-bottom:1px dashed rgba(244,208,63,0.4);
  transition:all .2s ease;
}
.tv-article a:hover{color:#fff;border-bottom-color:var(--tv-gold-bright)}
strong{color:var(--tv-gold-bright);font-weight:700}

.tv-article ul,.tv-article ol{margin:12px 0 18px 0;padding-left:22px}
.tv-article li{margin-bottom:8px;color:var(--tv-text)}
.tv-article ul li::marker{color:var(--tv-gold)}
.tv-article ol li::marker{color:var(--tv-gold);font-weight:700}

/* ============= E-E-A-T STRIP ============= */
.tv-eeat-strip{
  display:flex;align-items:center;flex-wrap:wrap;gap:14px;
  font-size:13px;color:var(--tv-text-mute);
  padding:14px 16px;margin:-8px 0 24px;
  background:var(--tv-surface-2);
  border:1px solid var(--tv-border);
  border-radius:8px;
}
.tv-eeat-strip span.dot{color:var(--tv-text-faint)}
.tv-eeat-author{color:var(--tv-gold)}
.tv-eeat-author a{color:var(--tv-gold);border-bottom:none;font-weight:600}
.tv-eeat-author a:hover{color:var(--tv-gold-bright)}

/* ============= INFO TABLE ============= */
.tv-info-table{
  width:100%;border-collapse:collapse;
  margin:18px 0 22px;
  background:var(--tv-surface-2);
  border:1px solid var(--tv-border);
  border-radius:10px;overflow:hidden;
}
.tv-info-table td{
  padding:11px 16px;
  border-bottom:1px solid rgba(212,175,55,0.1);
  font-size:14px;
}
.tv-info-table tr:last-child td{border-bottom:none}
.tv-info-table td:first-child{color:var(--tv-gold);font-weight:600;width:40%}
.tv-info-table td:last-child{color:var(--tv-text)}

/* ============= CARDS GRID (silo hub) ============= */
.tv-cards-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:16px;margin:24px 0;
}
.tv-card{
  background:var(--tv-surface-2);
  border:1px solid var(--tv-border);
  border-radius:var(--tv-radius);
  padding:22px;
  transition:transform .25s,border-color .25s,box-shadow .25s;
  display:flex;flex-direction:column;
  text-decoration:none;border-bottom:0 !important;
}
.tv-card:hover{
  transform:translateY(-4px);
  border-color:var(--tv-gold);
  box-shadow:var(--tv-shadow-gold);
}
.tv-card-tag{
  display:inline-block;background:rgba(212,175,55,0.12);
  border:1px solid rgba(212,175,55,0.3);color:var(--tv-gold);
  padding:3px 10px;border-radius:12px;
  font-size:11px;font-weight:600;margin-bottom:12px;width:fit-content;
}
.tv-card-icon{font-size:32px;margin-bottom:10px;opacity:0.9}
.tv-card-title{
  color:var(--tv-gold-bright);font-size:18px;font-weight:700;
  margin-bottom:8px;
}
.tv-card-desc{
  color:var(--tv-text);font-size:14px;line-height:1.65;
  margin-bottom:12px;flex:1;
}
.tv-card-cta{
  color:var(--tv-azure);font-size:13px;font-weight:600;
  margin-top:auto;
}
.tv-card-cta::after{content:" →";transition:transform .2s}
.tv-card:hover .tv-card-cta::after{transform:translateX(4px)}

/* ============= PASARAN PREDIKSI CARDS ============= */
.tv-pasaran-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:16px;margin:20px 0 28px;
}
.tv-pasaran-card{
  background:linear-gradient(135deg,var(--tv-surface-2) 0%,rgba(212,175,55,0.06) 100%);
  border:1px solid var(--tv-border);
  border-radius:10px;padding:18px;
  transition:transform .25s,border-color .25s;
}
.tv-pasaran-card:hover{transform:translateY(-3px);border-color:var(--tv-gold)}
.tv-pasaran-card h4{
  color:var(--tv-gold-bright);font-size:17px;font-weight:700;
  margin-bottom:10px;display:flex;align-items:center;gap:8px;
}
.tv-flag{font-size:20px;filter:drop-shadow(0 0 4px rgba(212,175,55,0.4))}
.tv-pasaran-meta{
  font-size:12px;color:var(--tv-text-mute);
  margin-bottom:10px;display:flex;flex-wrap:wrap;gap:8px;
}
.tv-pasaran-meta span{
  background:rgba(212,175,55,0.1);
  padding:2px 8px;border-radius:10px;color:var(--tv-gold);
}
.tv-pred-numbers{
  font-family:var(--tv-mono);font-size:22px;font-weight:700;
  color:var(--tv-gold-bright);letter-spacing:6px;text-align:center;
  padding:10px 0;
  background:rgba(10,10,14,0.5);border-radius:6px;
  margin:8px 0;border:1px dashed rgba(212,175,55,0.3);
}
.tv-pred-shio{
  text-align:center;font-size:13px;color:var(--tv-text-mute);margin-top:6px;
}
.tv-pred-shio strong{color:var(--tv-gold)}

/* ============= CTA BOX ============= */
.tv-cta-box{
  background:linear-gradient(135deg,var(--tv-surface-2) 0%,rgba(192,57,43,0.15) 100%);
  border:1px solid var(--tv-gold);
  border-radius:var(--tv-radius);
  padding:24px 20px;margin:24px 0;text-align:center;
}
.tv-cta-box p{text-align:center;margin-bottom:16px}
.tv-btn{
  display:inline-block;
  background:linear-gradient(135deg,var(--tv-gold) 0%,var(--tv-gold-bright) 100%);
  color:#1a1a1f !important;padding:12px 32px;border-radius:8px;
  font-weight:800;font-size:15px;letter-spacing:0.3px;
  text-transform:uppercase;border-bottom:none !important;
  box-shadow:0 4px 14px rgba(212,175,55,0.35);
  transition:transform .2s ease;
}
.tv-btn:hover{transform:translateY(-2px);color:#000 !important}
.tv-btn-ghost{
  display:inline-block;background:transparent;
  color:var(--tv-gold-bright) !important;
  padding:11px 28px;border-radius:8px;font-weight:700;font-size:14px;
  border:1px solid var(--tv-gold);
  border-bottom:1px solid var(--tv-gold) !important;
  margin-left:8px;transition:all .2s ease;
}
.tv-btn-ghost:hover{background:rgba(212,175,55,0.1)}

/* ============= PAITO TABLE ============= */
.tv-paito-wrap{margin:24px 0;overflow-x:auto}
.tv-paito-controls{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  margin-bottom:14px;padding:12px;
  background:var(--tv-surface-2);border:1px solid var(--tv-border);border-radius:8px;
}
.tv-paito-controls label{font-size:13px;color:var(--tv-text-mute);margin-right:6px}
.tv-tabs{display:flex;gap:4px;flex-wrap:wrap}
.tv-tab{
  background:transparent;border:1px solid var(--tv-border);
  color:var(--tv-text);padding:6px 12px;border-radius:6px;
  font-size:13px;font-weight:600;cursor:pointer;
  transition:all .2s;
}
.tv-tab:hover{border-color:var(--tv-gold);color:var(--tv-gold-bright)}
.tv-tab.active{background:var(--tv-gold);color:#1a1a1f;border-color:var(--tv-gold)}

.tv-rowcount{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap}
.tv-rowcount-btn{
  background:transparent;border:1px solid var(--tv-border);
  color:var(--tv-text-mute);padding:4px 10px;border-radius:4px;
  font-size:12px;cursor:pointer;font-family:var(--tv-mono);
}
.tv-rowcount-btn:hover{border-color:var(--tv-gold);color:var(--tv-gold)}
.tv-rowcount-btn.active{background:rgba(212,175,55,0.15);color:var(--tv-gold-bright);border-color:var(--tv-gold)}

.tv-paito-table{
  width:100%;border-collapse:collapse;
  background:var(--tv-surface);
  border:1px solid var(--tv-border);
  border-radius:8px;overflow:hidden;
  font-family:var(--tv-mono);font-size:13px;
}
.tv-paito-table th{
  background:var(--tv-surface-2);
  color:var(--tv-gold);font-weight:700;
  padding:10px 8px;text-align:center;
  border-bottom:1px solid var(--tv-border);
  font-family:var(--tv-font);font-size:12px;
}
.tv-paito-table td{
  padding:6px;text-align:center;
  border-bottom:1px solid rgba(212,175,55,0.05);
  color:var(--tv-text);
}
.tv-paito-table tr:hover td{background:rgba(212,175,55,0.04)}
.tv-paito-table .digit{
  display:inline-block;width:24px;height:24px;line-height:24px;
  margin:0 1px;border-radius:3px;font-weight:700;
  color:#fff;font-size:13px;
}
/* Paito 10-color scheme (digit value → color) */
.tv-paito-table .d0{background:#1a1a1a;border:1px solid #444}
.tv-paito-table .d1{background:#c0392b}
.tv-paito-table .d2{background:#27ae60}
.tv-paito-table .d3{background:#d4af37;color:#000}
.tv-paito-table .d4{background:#2980b9}
.tv-paito-table .d5{background:#e67e22}
.tv-paito-table .d6{background:#e91e63}
.tv-paito-table .d7{background:#8e44ad}
.tv-paito-table .d8{background:#795548}
.tv-paito-table .d9{background:#607d8b}

/* ============= BACA JUGA / RELATED ============= */
.tv-related{
  margin:36px 0 0;padding:24px 20px;
  background:var(--tv-surface-2);
  border:1px solid var(--tv-border);border-radius:var(--tv-radius);
}
.tv-related h3{color:var(--tv-gold-bright);margin-bottom:14px}
.tv-related-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;
}
.tv-related-item{
  background:var(--tv-surface);border:1px solid var(--tv-border);
  border-radius:8px;padding:14px;text-decoration:none;
  border-bottom:0 !important;transition:all .2s;
}
.tv-related-item:hover{border-color:var(--tv-gold);transform:translateY(-2px)}
.tv-related-item-tag{
  font-size:10px;color:var(--tv-gold);text-transform:uppercase;
  letter-spacing:1px;margin-bottom:6px;font-weight:700;
}
.tv-related-item-title{
  color:var(--tv-text);font-size:14px;font-weight:600;line-height:1.4;
}

/* ============= AUTHOR BIO ============= */
.tv-author-bio{
  margin-top:32px;padding:20px;
  background:var(--tv-surface-2);
  border-left:3px solid var(--tv-gold);
  border-radius:6px;
}
.tv-author-bio h4{
  color:var(--tv-gold-bright);margin-bottom:8px;
  font-size:14px;text-transform:uppercase;letter-spacing:0.5px;
}
.tv-author-bio p{font-size:14px;color:var(--tv-text-mute);margin:0}

/* ============= TOC (Table of Contents) ============= */
.tv-toc{
  background:rgba(10,6,16,0.5);
  border:1px solid rgba(212,175,55,0.2);
  border-radius:8px;padding:14px 18px;margin:14px 0 22px;
}
.tv-toc-title{
  font-size:13px;font-weight:700;color:var(--tv-gold);
  text-transform:uppercase;letter-spacing:0.5px;margin-bottom:10px;
}
.tv-toc ol{margin:0 0 0 22px;padding:0}
.tv-toc a{
  color:var(--tv-gold-bright);font-weight:500;
  border-bottom:none;padding:3px 0;display:inline-block;
  transition:all .2s;
}
.tv-toc a:hover{color:#fff;padding-left:6px}

/* ============= FOOTER ============= */
.tv-footer{
  background:#070709;border-top:1px solid var(--tv-border);
  margin-top:60px;padding:48px 20px 0;
}
.tv-footer-inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:36px;padding-bottom:36px;
}
.tv-footer h4{
  color:var(--tv-gold-bright);font-size:14px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.5px;margin-bottom:14px;
}
.tv-footer-about p{color:var(--tv-text-mute);font-size:13px;line-height:1.7;margin-top:12px}
.tv-footer ul{list-style:none;padding:0;margin:0}
.tv-footer ul li{margin-bottom:8px;font-size:13px}
.tv-footer ul li a{color:var(--tv-text-mute);transition:color .2s}
.tv-footer ul li a:hover{color:var(--tv-gold-bright)}
.tv-footer-bottom{
  border-top:1px solid var(--tv-border);padding:20px 0;text-align:center;
  color:var(--tv-text-mute);font-size:12px;
  max-width:1200px;margin:0 auto;
}
.tv-footer-bottom .tv-warn{
  display:inline-block;margin-top:8px;padding:6px 14px;
  background:rgba(192,57,43,0.15);border:1px solid rgba(192,57,43,0.4);
  border-radius:20px;color:#e88b80;font-size:11px;
}

/* ============= MOBILE ============= */
@media(max-width:768px){
  .tv-header-inner{padding:12px 14px;gap:10px;flex-wrap:wrap}
  .tv-logo img,.tv-logo-img{height:32px}
  .tv-logo-tag{font-size:9px;padding:2px 5px;letter-spacing:1px}
  .tv-nav{gap:2px;width:100%;justify-content:flex-start;overflow-x:auto;padding-top:8px;border-top:1px solid var(--tv-border)}
  .tv-nav a{padding:6px 10px;font-size:13px;white-space:nowrap}
  .tv-nav a.tv-nav-cta,.tv-nav a.tv-nav-cta-ghost{padding:6px 12px}
  .tv-hero{margin:16px auto 0;padding:0 14px}
  .tv-result-widget,.tv-status-bar{padding:0 14px}
  .tv-main{padding:0 14px;margin:20px auto}
  .tv-article{padding:22px 18px}
  h2{padding:8px 12px;font-size:18px}
  .tv-article p,.tv-article li{font-size:15px}
  .tv-result-grid{grid-template-columns:repeat(2,1fr)}
  .tv-result-card .pasaran-number{font-size:22px;letter-spacing:4px}
  .tv-cards-grid{grid-template-columns:1fr}
  .tv-pasaran-grid{grid-template-columns:1fr}
  .tv-footer{padding:32px 16px 0}
  .tv-footer-inner{grid-template-columns:1fr 1fr;gap:24px}
  .tv-footer-about{grid-column:1/-1}
  .tv-info-table td{padding:9px 12px;font-size:13px}
  .tv-info-table td:first-child{width:45%}
  .tv-btn-ghost{margin-left:0;margin-top:8px}
  .tv-paito-table{font-size:11px}
  .tv-paito-table .digit{width:20px;height:20px;line-height:20px;font-size:11px}
}
@media(max-width:480px){.tv-footer-inner{grid-template-columns:1fr}}

/* ============= PRINT (E-E-A-T signal) ============= */
@media print{
  .tv-header,.tv-footer,.tv-status-bar,.tv-cta-box,.tv-nav-cta,.tv-nav-cta-ghost{display:none}
  body{background:#fff;color:#000}
  .tv-article{box-shadow:none;border:1px solid #ccc}
}

/* ===================== TVT ENGINE BLOCKS + tv-spec (Jalur A) ===================== */
.tvt-keluaran,.tvt-prediksi{margin:28px 0}
.tvt-keluaran h2,.tvt-prediksi h2{
  font-size:22px;color:var(--tv-gold-bright);margin:0 0 14px;
  padding-bottom:10px;border-bottom:1px solid var(--tv-border)}
.tvt-prediksi h3{font-size:16px;color:var(--tv-gold);margin:22px 0 10px}
.tvt-latest{
  background:var(--tv-surface-2);border:1px solid var(--tv-border);
  border-left:3px solid var(--tv-gold);border-radius:var(--tv-radius);
  padding:12px 16px;margin:0 0 16px;font-size:14px;line-height:1.6}
.tvt-latest strong{color:var(--tv-gold-bright);font-family:var(--tv-mono);letter-spacing:1px}

/* history + frequency tables */
.tvt-table,.tvt-freq{
  width:100%;border-collapse:collapse;margin:0 0 8px;background:var(--tv-surface);
  border:1px solid var(--tv-border);border-radius:var(--tv-radius);overflow:hidden;font-size:14px}
.tvt-table th,.tvt-freq th{
  background:var(--tv-surface-3);color:var(--tv-gold);text-align:left;padding:10px 14px;
  font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.tvt-table td,.tvt-freq td{padding:9px 14px;border-top:1px solid var(--tv-border);color:var(--tv-text)}
.tvt-table tr:hover td,.tvt-freq tr:hover td{background:rgba(212,175,55,0.04)}
.tvt-num{font-family:var(--tv-mono);color:var(--tv-gold-bright);font-weight:600;letter-spacing:2px}

/* full-history disclosure (crawlable, not JS-gated) */
.tvt-more{margin:6px 0 0;border:1px solid var(--tv-border);border-radius:var(--tv-radius);background:var(--tv-surface)}
.tvt-more>summary{cursor:pointer;padding:11px 16px;color:var(--tv-gold);font-size:13px;font-weight:600;list-style:none;user-select:none}
.tvt-more>summary::-webkit-details-marker{display:none}
.tvt-more>summary::before{content:"\25B8 ";color:var(--tv-text-mute)}
.tvt-more[open]>summary::before{content:"\25BE "}
.tvt-more .tvt-table{border:none;border-radius:0;margin:0}

/* prediction set cards */
.tvt-sets{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin:0 0 8px}
.tvt-set{
  background:var(--tv-surface-2);border:1px solid var(--tv-border);border-radius:var(--tv-radius);
  padding:14px;display:flex;flex-direction:column;gap:6px;transition:border-color .2s,transform .2s}
.tvt-set:hover{border-color:var(--tv-border-strong);transform:translateY(-2px)}
.tvt-set-num{font-family:var(--tv-mono);font-size:26px;font-weight:700;color:var(--tv-gold-bright);letter-spacing:4px;line-height:1}
.tvt-set-label{font-size:13px;font-weight:600;color:var(--tv-text)}
.tvt-set-desc{font-size:12px;color:var(--tv-text-mute);line-height:1.5}

/* frequency bar */
.tvt-freq td:first-child{font-family:var(--tv-mono);color:var(--tv-gold);font-weight:600}
.tvt-bar{display:inline-block;height:10px;min-width:2px;border-radius:5px;vertical-align:middle;
  background:linear-gradient(90deg,var(--tv-gold-dark),var(--tv-gold-bright))}

/* spec table (page-intro complement; facts also live in prose above it) */
.tv-spec{
  width:100%;border-collapse:collapse;margin:16px 0 24px;background:var(--tv-surface);
  border:1px solid var(--tv-border);border-radius:var(--tv-radius);overflow:hidden;font-size:14px}
.tv-spec th{
  text-align:left;width:38%;padding:10px 16px;color:var(--tv-gold);font-weight:600;
  background:var(--tv-surface-2);border-top:1px solid var(--tv-border);vertical-align:top;font-size:13px}
.tv-spec td{padding:10px 16px;border-top:1px solid var(--tv-border);color:var(--tv-text)}
.tv-spec tr:first-child th,.tv-spec tr:first-child td{border-top:none}

@media(max-width:560px){
  .tvt-sets{grid-template-columns:1fr 1fr}
  .tvt-set-num{font-size:22px}
  .tv-spec th{width:42%}
}
/* ============================================================
   TVT — blok prediksi/keluaran + hero + tv-spec + Lab interaktif
   Tempel di paling bawah style.css. Jangan hapus style lain.
   ============================================================ */

/* --- judul blok --- */
.tvt-prediksi h2,.tvt-keluaran h2{font-size:22px;color:var(--tv-gold-bright);margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--tv-border)}
.tvt-prediksi h3,.tvt-keluaran h3{font-size:16px;color:var(--tv-gold);margin:22px 0 10px}

/* --- HERO: jawaban di atas --- */
.tvt-hero{margin:0 0 20px;padding:20px 22px;border-radius:var(--tv-radius-lg);background:linear-gradient(135deg,var(--tv-surface-2),rgba(212,175,55,.10));border:1px solid var(--tv-gold)}
.tvt-hero-label{display:block;font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--tv-gold);font-weight:700;margin-bottom:6px}
.tvt-hero-main{font-family:var(--tv-mono);font-size:clamp(40px,11vw,64px);font-weight:800;color:var(--tv-gold-bright);letter-spacing:8px;line-height:1.05;margin:2px 0 12px;text-shadow:0 2px 20px rgba(212,175,55,.3)}
.tvt-hero-row{display:flex;justify-content:space-between;gap:12px;padding:7px 0;border-top:1px solid var(--tv-border);font-size:14px}
.tvt-hero-row span{color:var(--tv-text-mute)}
.tvt-hero-row strong{font-family:var(--tv-mono);color:var(--tv-text);letter-spacing:2px}
.tvt-hero-note{margin:12px 0 0;font-size:12px;color:var(--tv-text-faint)}

/* --- kartu set prediksi --- */
.tvt-sets{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin:0 0 8px}
.tvt-set{background:var(--tv-surface-2);border:1px solid var(--tv-border);border-radius:var(--tv-radius);padding:14px;display:flex;flex-direction:column;gap:6px}
.tvt-set-num{font-family:var(--tv-mono);font-size:26px;font-weight:700;color:var(--tv-gold-bright);letter-spacing:4px;line-height:1}
.tvt-set-label{font-size:13px;font-weight:600;color:var(--tv-text)}
.tvt-set-desc{font-size:12px;color:var(--tv-text-mute);line-height:1.5}

/* --- tabel keluaran & frekuensi --- */
.tvt-table,.tvt-freq{width:100%;border-collapse:collapse;margin:0 0 8px;background:var(--tv-surface);border:1px solid var(--tv-border);border-radius:var(--tv-radius);overflow:hidden;font-size:14px}
.tvt-table th,.tvt-freq th{background:var(--tv-surface-3);color:var(--tv-gold);text-align:left;padding:10px 14px;font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.tvt-table td,.tvt-freq td{padding:9px 14px;border-top:1px solid var(--tv-border);color:var(--tv-text)}
.tvt-table tr:hover td,.tvt-freq tr:hover td{background:rgba(212,175,55,0.04)}
.tvt-num{font-family:var(--tv-mono);color:var(--tv-gold-bright);font-weight:600;letter-spacing:2px}
.tvt-freq td:first-child{font-family:var(--tv-mono);color:var(--tv-gold);font-weight:600}
.tvt-bar{display:inline-block;height:10px;min-width:2px;border-radius:5px;vertical-align:middle;background:linear-gradient(90deg,var(--tv-gold-dark),var(--tv-gold-bright))}

/* --- collapse (riwayat penuh + analisa) --- */
.tvt-more,.tvt-analisa{margin:8px 0 0;border:1px solid var(--tv-border);border-radius:var(--tv-radius);background:var(--tv-surface)}
.tvt-more>summary,.tvt-analisa>summary{cursor:pointer;padding:12px 16px;color:var(--tv-gold);font-weight:600;font-size:14px;list-style:none;user-select:none}
.tvt-more>summary::-webkit-details-marker,.tvt-analisa>summary::-webkit-details-marker{display:none}
.tvt-more>summary::before,.tvt-analisa>summary::before{content:"\25B8 ";color:var(--tv-text-mute)}
.tvt-more[open]>summary::before,.tvt-analisa[open]>summary::before{content:"\25BE "}
.tvt-more .tvt-table{border:none;border-radius:0;margin:0}
.tvt-analisa-body{padding:0 16px 14px}

/* --- tabel spesifikasi pasaran --- */
.tv-spec{width:100%;border-collapse:collapse;margin:16px 0 24px;background:var(--tv-surface);border:1px solid var(--tv-border);border-radius:var(--tv-radius);overflow:hidden;font-size:14px}
.tv-spec th{text-align:left;width:38%;padding:10px 16px;color:var(--tv-gold);font-weight:600;background:var(--tv-surface-2);border-top:1px solid var(--tv-border);vertical-align:top;font-size:13px}
.tv-spec td{padding:10px 16px;border-top:1px solid var(--tv-border);color:var(--tv-text)}
.tv-spec tr:first-child th,.tv-spec tr:first-child td{border-top:none}

/* --- Lab Analisa Interaktif --- */
.tvt-lab{margin:28px 0;padding:20px;background:var(--tv-surface);border:1px solid var(--tv-border-strong);border-radius:var(--tv-radius-lg)}
.tvt-lab>h2{font-size:20px;color:var(--tv-gold-bright);margin:0 0 6px}
.tvt-lab-sub{font-size:13px;color:var(--tv-text-mute);margin:0 0 16px;line-height:1.6}
.tvt-lab-controls{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}
.tvt-lab-btn{padding:7px 16px;border-radius:999px;border:1px solid var(--tv-border);background:var(--tv-surface-2);color:var(--tv-text-mute);font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.tvt-lab-btn:hover{border-color:var(--tv-border-strong);color:var(--tv-text)}
.tvt-lab-btn.is-active{background:var(--tv-gold);border-color:var(--tv-gold);color:#1a1408}
.tvt-lab-note{font-size:13px;color:var(--tv-text-mute);margin:0 0 10px}
.tvt-lab-block{margin-top:18px;padding-top:16px;border-top:1px solid var(--tv-border)}
.tvt-lab-label{display:block;font-size:13px;font-weight:600;color:var(--tv-gold);margin:0 0 8px}
.tvt-lab-gen{padding:10px 20px;border:none;border-radius:var(--tv-radius);background:linear-gradient(135deg,var(--tv-gold),var(--tv-gold-dark));color:#1a1408;font:inherit;font-weight:700;font-size:14px;cursor:pointer}
.tvt-lab-gen:hover{filter:brightness(1.08)}
.tvt-bbfs-row{display:flex;gap:8px;flex-wrap:wrap}
.tvt-bbfs-row input{flex:1;min-width:160px;padding:9px 14px;border-radius:var(--tv-radius);border:1px solid var(--tv-border);background:var(--tv-bg);color:var(--tv-text);font:inherit}
.tvt-bbfs-out{margin-top:10px;font-family:var(--tv-mono);font-size:13px;color:var(--tv-gold-bright);line-height:1.8;word-break:break-word;max-height:220px;overflow:auto}
.tvt-copy{margin-top:4px;align-self:flex-start;padding:3px 10px;border-radius:6px;border:1px solid var(--tv-border);background:transparent;color:var(--tv-text-mute);font:inherit;font-size:11px;cursor:pointer}
.tvt-copy:hover{border-color:var(--tv-gold);color:var(--tv-gold)}
.tvt-lab-cta{margin-top:14px;font-size:14px}
.tvt-lab-cta a{color:var(--tv-gold-bright);font-weight:700}
#tvt-gen-out{margin-top:14px}

@media(max-width:560px){.tvt-sets{grid-template-columns:1fr 1fr}.tvt-set-num{font-size:22px}.tv-spec th{width:42%}}
/* B1: widget result number — clean token "4048", visual spacing via letter-spacing */
.pasaran-number{letter-spacing:.42em;padding-left:.42em;font-variant-numeric:tabular-nums;}

/* ======================= B2: PAITO WARNA (interactive grid) ======================= */
.tv-paito-wrap{max-height:560px;overflow:auto;border:1px solid var(--tv-border);border-radius:8px;margin:14px 0}
.tv-paito-wrap .tv-paito-table{border:0;border-radius:0;margin:0}
.tv-paito-grid thead th{position:sticky;top:0;z-index:2}
.tv-paito-grid td.pno{color:var(--tv-text-mute);font-size:11px}
.tv-paito-grid td.ptgl{white-space:nowrap;font-size:12px;color:var(--tv-text-mute)}
.tv-paito-grid td.p4d{font-weight:700;color:var(--tv-gold);letter-spacing:1px}
.tv-paito-grid td.pc{font-weight:700;color:#fff}

.tv-paito-ctrl{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:16px 0 4px}
.tv-paito-ctrl-label{font-size:13px;color:var(--tv-text-mute);font-weight:600}
.tv-paito-ctrl button{font-family:var(--tv-font);font-size:12px;font-weight:600;cursor:pointer;
  padding:6px 12px;border-radius:6px;border:1px solid var(--tv-border);
  background:var(--tv-surface-2);color:var(--tv-text);transition:.15s}
.tv-paito-ctrl button:hover{border-color:var(--tv-gold)}
.tv-paito-ctrl button.active{background:var(--tv-gold);color:#000;border-color:var(--tv-gold)}

/* scheme: per-digit palette (rainbow by design) */
.tv-paito-grid[data-scheme="palette"] td.pc[data-d="0"]{background:#2c2c2c}
.tv-paito-grid[data-scheme="palette"] td.pc[data-d="1"]{background:#c0392b}
.tv-paito-grid[data-scheme="palette"] td.pc[data-d="2"]{background:#27ae60}
.tv-paito-grid[data-scheme="palette"] td.pc[data-d="3"]{background:#d4af37;color:#000}
.tv-paito-grid[data-scheme="palette"] td.pc[data-d="4"]{background:#2980b9}
.tv-paito-grid[data-scheme="palette"] td.pc[data-d="5"]{background:#e67e22}
.tv-paito-grid[data-scheme="palette"] td.pc[data-d="6"]{background:#e91e63}
.tv-paito-grid[data-scheme="palette"] td.pc[data-d="7"]{background:#8e44ad}
.tv-paito-grid[data-scheme="palette"] td.pc[data-d="8"]{background:#795548}
.tv-paito-grid[data-scheme="palette"] td.pc[data-d="9"]{background:#607d8b}

/* scheme: besar/kecil — kecil 0-4 azure, besar 5-9 ruby */
.tv-paito-grid[data-scheme="bk"] td.pc[data-d="0"],
.tv-paito-grid[data-scheme="bk"] td.pc[data-d="1"],
.tv-paito-grid[data-scheme="bk"] td.pc[data-d="2"],
.tv-paito-grid[data-scheme="bk"] td.pc[data-d="3"],
.tv-paito-grid[data-scheme="bk"] td.pc[data-d="4"]{background:#2980b9}
.tv-paito-grid[data-scheme="bk"] td.pc[data-d="5"],
.tv-paito-grid[data-scheme="bk"] td.pc[data-d="6"],
.tv-paito-grid[data-scheme="bk"] td.pc[data-d="7"],
.tv-paito-grid[data-scheme="bk"] td.pc[data-d="8"],
.tv-paito-grid[data-scheme="bk"] td.pc[data-d="9"]{background:#c0392b}

/* scheme: ganjil/genap — genap emerald, ganjil ungu */
.tv-paito-grid[data-scheme="gg"] td.pc[data-d="0"],
.tv-paito-grid[data-scheme="gg"] td.pc[data-d="2"],
.tv-paito-grid[data-scheme="gg"] td.pc[data-d="4"],
.tv-paito-grid[data-scheme="gg"] td.pc[data-d="6"],
.tv-paito-grid[data-scheme="gg"] td.pc[data-d="8"]{background:#16a085}
.tv-paito-grid[data-scheme="gg"] td.pc[data-d="1"],
.tv-paito-grid[data-scheme="gg"] td.pc[data-d="3"],
.tv-paito-grid[data-scheme="gg"] td.pc[data-d="5"],
.tv-paito-grid[data-scheme="gg"] td.pc[data-d="7"],
.tv-paito-grid[data-scheme="gg"] td.pc[data-d="9"]{background:#8e44ad}

/* scheme: tepi/tengah — tepi 0,1,2,7,8,9 gold; tengah 3,4,5,6 slate */
.tv-paito-grid[data-scheme="tt"] td.pc[data-d="0"],
.tv-paito-grid[data-scheme="tt"] td.pc[data-d="1"],
.tv-paito-grid[data-scheme="tt"] td.pc[data-d="2"],
.tv-paito-grid[data-scheme="tt"] td.pc[data-d="7"],
.tv-paito-grid[data-scheme="tt"] td.pc[data-d="8"],
.tv-paito-grid[data-scheme="tt"] td.pc[data-d="9"]{background:#d4af37;color:#000}
.tv-paito-grid[data-scheme="tt"] td.pc[data-d="3"],
.tv-paito-grid[data-scheme="tt"] td.pc[data-d="4"],
.tv-paito-grid[data-scheme="tt"] td.pc[data-d="5"],
.tv-paito-grid[data-scheme="tt"] td.pc[data-d="6"]{background:#34495e}

.tv-paito-legend{display:flex;flex-wrap:wrap;gap:12px;margin:10px 0 0;font-size:12px;color:var(--tv-text-mute)}
.tv-paito-legend span{display:inline-flex;align-items:center;gap:5px}
.tv-paito-legend i{width:14px;height:14px;border-radius:3px;display:inline-block}
@media(max-width:600px){.tv-paito-grid td.ptgl{font-size:11px}.tv-paito-wrap{max-height:460px}}
.tv-paito-rowsel select{font-family:var(--tv-font);font-size:12px;padding:5px 8px;border-radius:6px;border:1px solid var(--tv-border);background:var(--tv-surface-2);color:var(--tv-text);cursor:pointer}

/* ======================= B3: BUKU MIMPI (search/filter/racik) ======================= */
.bm-tool{margin:18px 0}
.bm-search{width:100%;box-sizing:border-box;font-family:var(--tv-font);font-size:15px;padding:12px 14px;border-radius:10px;border:1px solid var(--tv-border);background:var(--tv-surface-2);color:var(--tv-text)}
.bm-search:focus{outline:none;border-color:var(--tv-gold)}
.bm-chips{display:flex;flex-wrap:wrap;gap:7px;margin:12px 0 6px}
.bm-chip{font-family:var(--tv-font);font-size:12px;font-weight:600;cursor:pointer;padding:6px 12px;border-radius:20px;border:1px solid var(--tv-border);background:var(--tv-surface-2);color:var(--tv-text);transition:.15s}
.bm-chip:hover{border-color:var(--tv-gold)}
.bm-chip.active{background:var(--tv-gold);color:#000;border-color:var(--tv-gold)}
.bm-meta{font-size:12px;color:var(--tv-text-mute);margin:4px 0}
.bm-racik{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:10px 0;padding:12px;border:1px dashed var(--tv-gold-dark);border-radius:10px;background:var(--tv-surface)}
.bm-racik-label{font-size:13px;font-weight:600;color:var(--tv-gold)}
.bm-racik-items{display:flex;flex-wrap:wrap;gap:6px}
.bm-racik-chip{font-family:var(--tv-mono);font-size:13px;background:var(--tv-surface-3);border:1px solid var(--tv-border);border-radius:6px;padding:3px 8px;cursor:pointer}
.bm-racik-chip:hover{border-color:var(--tv-ruby)}
.bm-racik-copy,.bm-racik-clear{font-family:var(--tv-font);font-size:12px;font-weight:600;cursor:pointer;padding:5px 11px;border-radius:6px;border:1px solid var(--tv-border);background:var(--tv-surface-2);color:var(--tv-text)}
.bm-racik-copy{background:var(--tv-gold);color:#000;border-color:var(--tv-gold)}
.bm-table-wrap{max-height:620px;overflow:auto;border:1px solid var(--tv-border);border-radius:10px;margin:10px 0}
.bm-table{width:100%;border-collapse:collapse;font-size:14px}
.bm-table thead th{position:sticky;top:0;z-index:2;background:var(--tv-surface-2);color:var(--tv-gold);font-weight:700;padding:10px 8px;text-align:center;border-bottom:1px solid var(--tv-border);font-size:12px}
.bm-table td{padding:8px;text-align:center;border-bottom:1px solid rgba(212,175,55,0.06);color:var(--tv-text)}
.bm-table tbody tr:hover td{background:rgba(212,175,55,0.05)}
.bm-no{color:var(--tv-text-mute);font-size:11px}
.bm-kw{text-align:left;font-weight:600}
.bm-cat{font-size:11px;color:var(--tv-text-mute)}
.bm-num{font-family:var(--tv-mono);font-weight:700;cursor:pointer;letter-spacing:.5px}
.bm-num:hover{color:var(--tv-gold)}
.bm-4d{color:var(--tv-gold)}
.bm-num.copied{color:var(--tv-emerald)}
.bm-add-btn{width:26px;height:26px;border-radius:6px;border:1px solid var(--tv-border);background:var(--tv-surface-2);color:var(--tv-gold);font-weight:700;cursor:pointer;line-height:1}
.bm-add-btn:hover{background:var(--tv-gold);color:#000}
.bm-empty{text-align:center;padding:24px;color:var(--tv-text-mute)}
@media(max-width:600px){.bm-table{font-size:13px}.bm-cat,.bm-table thead th:nth-child(3){display:none}}
