/* ============ Tema (light & dark) ============ */
:root{
  --maxw:1320px;
  --radius:14px;
  --gap:18px;
  --accent:#ff5a5f;
  --accent2:#7c5cff;
  --shadow:0 6px 24px rgba(0,0,0,.12);
  --speed:.25s;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
/* Terang */
html[data-theme="light"]{
  --bg:#f5f6f8; --bg2:#ffffff; --card:#ffffff; --header:#ffffffd9;
  --text:#1a1d24; --muted:#697586; --line:#e6e9ef; --skeleton:#e9ecf1;
  --chip:#eef0f4;
}
/* Gelap */
html[data-theme="dark"]{
  --bg:#0f1115; --bg2:#171a21; --card:#181b22; --header:#12141ad9;
  --text:#e9ebef; --muted:#9aa3b2; --line:#262a33; --skeleton:#23272f;
  --chip:#21252e; --shadow:0 6px 24px rgba(0,0,0,.4);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);font-family:var(--font);
  font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;
  transition:background var(--speed),color var(--speed);
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3{line-height:1.25;margin:0}
.container{max-width:var(--maxw);margin:0 auto;padding:0 16px;width:100%}
.muted{color:var(--muted);font-weight:400}

/* ============ Header ============ */
.site-header{
  position:sticky;top:0;z-index:30;background:var(--header);
  backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;gap:16px;height:62px}
.logo{display:flex;align-items:center;gap:8px;font-weight:800;font-size:19px;flex-shrink:0}
.logo-mark{
  display:grid;place-items:center;width:30px;height:30px;border-radius:9px;color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent2));font-size:13px;
  box-shadow:0 3px 10px rgba(124,92,255,.4);animation:pop .5s ease both;
}
.logo-text{background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent}
.main-nav{display:flex;gap:4px;flex:1;overflow-x:auto;scrollbar-width:none}
.main-nav::-webkit-scrollbar{display:none}
.main-nav a{
  padding:8px 13px;border-radius:999px;color:var(--muted);font-weight:600;white-space:nowrap;
  transition:color var(--speed),background var(--speed),transform var(--speed);
}
.main-nav a:hover{color:var(--text);background:var(--chip);transform:translateY(-1px)}
.main-nav a.active{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2))}
.search-box{display:flex;align-items:center;background:var(--chip);border-radius:999px;padding:2px 4px 2px 14px;border:1px solid transparent;transition:border var(--speed)}
.search-box:focus-within{border-color:var(--accent2)}
.search-box input{border:0;background:transparent;color:var(--text);padding:8px 4px;outline:none;width:160px;font-size:14px}
.search-box button{border:0;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center;padding:6px;border-radius:50%}
.search-box button:hover{color:var(--accent)}
.theme-toggle,.nav-toggle{border:0;background:var(--chip);color:var(--text);width:38px;height:38px;border-radius:50%;cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:transform var(--speed),background var(--speed)}
.theme-toggle:hover,.nav-toggle:hover{transform:rotate(18deg) scale(1.08)}
.theme-toggle .ic-sun{display:none}.theme-toggle .ic-moon{display:block}
html[data-theme="dark"] .theme-toggle .ic-sun{display:block}
html[data-theme="dark"] .theme-toggle .ic-moon{display:none}
.nav-toggle{display:none}

/* ============ Banner ============ */
.banner-zone{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);margin:18px 0}
.banner-col{display:flex;flex-direction:column;gap:12px}
.banner{display:block;border-radius:10px;overflow:hidden;border:1px solid var(--line)}
.banner img{width:100%;height:auto;aspect-ratio:728/120;object-fit:cover}
.banner-empty{aspect-ratio:728/120;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg2);color:var(--muted);gap:2px;border-style:dashed}
.banner-empty span{font-weight:700;font-size:14px}.banner-empty small{font-size:11px;opacity:.7}

/* ============ Page head / breadcrumb ============ */
.page-head{margin:22px 0 16px}
.page-head h1{font-size:22px;font-weight:800}
.breadcrumb{display:flex;gap:8px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:13px;margin:16px 0}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .current{color:var(--text);font-weight:600}

/* ============ Grid video ============ */
.video-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--gap)}
.vcard{display:flex;flex-direction:column;border-radius:var(--radius);overflow:hidden;background:var(--card);border:1px solid var(--line);transition:transform var(--speed),box-shadow var(--speed)}
.vcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.vthumb{position:relative;aspect-ratio:16/9;background:var(--skeleton);overflow:hidden}
.vthumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease,opacity var(--speed);opacity:1}
.vcard:hover .vthumb img{transform:scale(1.07)}
.vplay{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:opacity var(--speed)}
.vplay svg{width:46px;height:46px;transform:scale(.7);transition:transform var(--speed)}
.vplay svg circle{fill:rgba(0,0,0,.5)}.vplay svg path{fill:#fff}
.vcard:hover .vplay{opacity:1}
.vcard:hover .vplay svg{transform:scale(1);animation:bounce .5s}
.vmeta{padding:11px 12px 13px}
.vtitle{font-size:14px;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.5em}
.vsub{margin-top:6px;color:var(--muted);font-size:12.5px;display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.vsub .dot{opacity:.6}

/* ============ Skeleton shimmer ============ */
.skeleton{position:relative;overflow:hidden}
.skeleton::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);transform:translateX(-100%);animation:shimmer 1.3s infinite}
.skeleton img{opacity:0}

/* ============ Reveal saat scroll ============ */
.reveal{opacity:0;transform:translateY(16px)}
.reveal.in{opacity:1;transform:none;transition:opacity .5s ease,transform .5s ease}

/* ============ Halaman tonton ============ */
.watch{display:grid;grid-template-columns:1fr 340px;gap:26px;margin:18px 0 40px}
.player-wrap{border-radius:var(--radius);overflow:hidden;background:#000;box-shadow:var(--shadow);aspect-ratio:16/9}
.player-wrap video{width:100%;height:100%}
.watch-title{font-size:20px;font-weight:800;margin:16px 0 8px}
.watch-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:13.5px}
.chip{background:var(--chip);padding:4px 11px;border-radius:999px;font-weight:600;color:var(--text);transition:transform var(--speed)}
.chip:hover{transform:translateY(-1px);color:var(--accent)}
.watch-desc{margin-top:16px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;color:var(--text);white-space:pre-line}
.side-title,.side-title{font-size:16px;font-weight:700;margin-bottom:12px}
.side-list{display:flex;flex-direction:column;gap:12px}
.side-card{display:grid;grid-template-columns:168px 1fr;gap:10px;border-radius:10px;overflow:hidden;transition:background var(--speed)}
.side-card:hover{background:var(--card)}
.side-thumb{aspect-ratio:16/9;border-radius:8px;overflow:hidden;background:var(--skeleton)}
.side-thumb img{width:100%;height:100%;object-fit:cover}
.side-info h3{font-size:13.5px;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.side-info span{color:var(--muted);font-size:12px;display:block;margin-top:5px}

/* ============ Pagination ============ */
.pagination{display:flex;gap:7px;justify-content:center;flex-wrap:wrap;margin:34px 0 10px}
.pg{min-width:40px;height:40px;padding:0 12px;display:grid;place-items:center;border-radius:10px;background:var(--card);border:1px solid var(--line);color:var(--text);font-weight:600;transition:transform var(--speed),background var(--speed),color var(--speed)}
a.pg:hover{transform:translateY(-2px);border-color:var(--accent2)}
.pg.active{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-color:transparent}
.pg.dots{background:transparent;border:0}

/* ============ Halaman statis / empty ============ */
.static-page{max-width:820px;margin:10px auto 50px}
.static-page h1{font-size:26px;font-weight:800;margin-bottom:16px}
.prose{color:var(--text)}
.prose p{margin:0 0 14px}.prose h2{margin:24px 0 10px;font-size:20px}.prose a{color:var(--accent2)}
.empty-state{text-align:center;padding:70px 16px;color:var(--muted)}
.result-count{margin:0 0 14px}
.notfound .nf-emoji{font-size:60px;animation:bounce 1.2s infinite}
.notfound h1{font-size:54px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent;margin:6px 0}
.btn{display:inline-block;margin-top:14px;padding:11px 22px;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-weight:700;transition:transform var(--speed)}
.btn:hover{transform:translateY(-2px) scale(1.03)}

/* ============ Footer ============ */
.site-footer{background:var(--bg2);border-top:1px solid var(--line);margin-top:40px}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:26px;padding:34px 16px 26px}
.footer-tag{color:var(--muted);margin-top:8px;font-size:13.5px}
.footer-links h4{font-size:14px;margin-bottom:12px}
.footer-links a{display:block;color:var(--muted);padding:5px 0;font-size:13.5px;transition:color var(--speed),transform var(--speed)}
.footer-links a:hover{color:var(--accent);transform:translateX(3px)}
.footer-bottom{border-top:1px solid var(--line);padding:16px;text-align:center;color:var(--muted);font-size:13px}

/* ============ Animasi keyframes ============ */
@keyframes shimmer{100%{transform:translateX(100%)}}
@keyframes pop{0%{transform:scale(0) rotate(-30deg)}70%{transform:scale(1.15)}100%{transform:scale(1)}}
@keyframes bounce{0%,100%{transform:translateY(0)}30%{transform:translateY(-7px)}60%{transform:translateY(-3px)}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ============ Responsif ============ */
@media (max-width:1100px){
  .video-grid{grid-template-columns:repeat(4,1fr)}
  .watch{grid-template-columns:1fr}
}
@media (max-width:820px){            /* tablet */
  .video-grid{grid-template-columns:repeat(3,1fr)}
  .banner-zone{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){            /* mobile */
  .video-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .header-inner{height:56px;gap:10px}
  .search-box{display:none}
  .nav-toggle{display:grid}
  .main-nav{position:fixed;top:56px;left:0;right:0;background:var(--bg2);flex-direction:column;padding:10px;border-bottom:1px solid var(--line);transform:translateY(-120%);transition:transform var(--speed);max-height:70vh;overflow:auto}
  body.nav-open .main-nav{transform:none}
  .footer-inner{grid-template-columns:1fr;gap:18px}
  .page-head h1{font-size:19px}
}
