/* ============ DORAMA — Streaming Platform ============ */
:root{
  --bg:#050507; --panel:#131418; --panel-2:#1c1e24; --panel-hover:#22242c;
  --muted:#9aa3b2; --text:#e6eef8; --accent:#ff4757; --accent-2:#ff6b81;
  --green:#2ed573; --amber:#ffa502; --blue:#5352ed;
  --glass:rgba(255,255,255,.05); --border:rgba(255,255,255,.07);
  --maxw:1200px; --radius:12px;
  font-family:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
.icon{display:inline-block;vertical-align:-.18em;flex:0 0 auto}
.btn .icon,.chip .icon{vertical-align:-.2em}
body{background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}
a{text-decoration:none;color:inherit;transition:.2s}
ul{list-style:none}
img{max-width:100%;display:block}
input,select,textarea,button{font-family:inherit}

/* ---------- Navbar ---------- */
header.site{position:sticky;top:0;z-index:50;background:rgba(5,5,7,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-container{max-width:var(--maxw);margin:0 auto;padding:13px 20px;display:flex;align-items:center;gap:14px}
.brand{font-size:22px;font-weight:800;color:var(--accent);letter-spacing:1px;white-space:nowrap;display:flex;align-items:center;gap:10px}
.brand small{color:var(--muted);font-size:11px;font-weight:600;display:block;letter-spacing:0}
.brand-logo{height:38px;width:auto;display:block;border-radius:8px}
.brand-text{line-height:1}
@media (max-width:600px){.brand-text{display:none}}
.search-wrapper{position:relative;flex:1;max-width:420px}
.search-input{width:100%;background:rgba(255,255,255,.08);border:1px solid var(--border);padding:10px 40px 10px 16px;border-radius:50px;color:#fff;font-size:14px;outline:none;transition:.3s}
.search-input:focus{background:rgba(255,255,255,.14);border-color:var(--accent);box-shadow:0 0 10px rgba(255,71,87,.2)}
.search-icon{position:absolute;right:15px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.nav-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.nav-link{color:var(--muted);font-size:14px;font-weight:600;padding:8px 6px}
.nav-link:hover{color:var(--text)}

/* dropdown user */
.user-menu{position:relative}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;cursor:pointer}
.dropdown{position:absolute;right:0;top:48px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;min-width:200px;padding:8px;display:none;box-shadow:0 12px 40px rgba(0,0,0,.5)}
.dropdown.open{display:block}
.dropdown a,.dropdown button{display:flex;width:100%;gap:8px;align-items:center;padding:10px 12px;border-radius:8px;color:var(--text);background:none;border:none;cursor:pointer;font-size:14px;text-align:left}
.dropdown a:hover,.dropdown button:hover{background:var(--panel-hover)}
.dropdown hr{border:none;border-top:1px solid var(--border);margin:6px 0}

/* ---------- Buttons & chips ---------- */
.chip{padding:8px 16px;border-radius:50px;background:var(--panel);border:1px solid var(--border);color:var(--muted);cursor:pointer;font-size:13px;transition:.2s;white-space:nowrap}
.chip:hover,.chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:8px;font-weight:600;border:none;cursor:pointer;font-size:14px;transition:.2s}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-2)}
.btn-ghost{background:var(--panel-2);color:var(--text);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--panel-hover)}
.btn-green{background:var(--green);color:#062b13}
.btn-amber{background:var(--amber);color:#3a2600}
.btn-danger{background:#2a1416;color:#ff6b6b;border:1px solid rgba(255,71,87,.3)}
.btn-danger:hover{background:#3a1a1d}
.btn-block{width:100%;justify-content:center}
.btn-sm{padding:6px 12px;font-size:13px}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:20px}
.section-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:30px 0 18px}
.section-header h2,.section-header h3{font-size:20px;font-weight:700;line-height:1.2;margin:0}
.muted{color:var(--muted)}
.center{text-align:center}

/* ---------- Hero ---------- */
.hero{border-radius:var(--radius);overflow:hidden;position:relative;padding:70px 40px;margin-bottom:10px;background-size:cover;background-position:center;display:flex;align-items:flex-end;min-height:360px}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(0deg,var(--bg) 2%,rgba(5,5,7,.4) 100%)}
.hero-content{position:relative;z-index:2;max-width:620px}
.hero h1{font-size:3rem;margin-bottom:10px;line-height:1.05}
.hero p{color:#d4dcea;margin-bottom:20px;font-size:1.05rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hero .tags{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:50px;font-size:12px;font-weight:600;background:var(--glass);border:1px solid var(--border)}
.badge.red{background:var(--accent);color:#fff;border:none}

/* ---------- Grid + cards ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:20px}
.card{position:relative;transition:transform .2s}
.card:hover{transform:translateY(-5px)}
.thumb{width:100%;aspect-ratio:2/3;background:var(--panel);background-size:cover;background-position:center;border-radius:var(--radius);position:relative;overflow:hidden}
.thumb::after{content:'▶';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:30px;color:#fff;opacity:0;transition:.2s;text-shadow:0 4px 10px rgba(0,0,0,.5)}
.card:hover .thumb::after{opacity:1}
.ep-badge{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.65);padding:4px 8px;font-size:11px;border-radius:6px;backdrop-filter:blur(4px)}
.rate-badge{position:absolute;top:10px;left:10px;background:rgba(0,0,0,.65);padding:4px 8px;font-size:11px;border-radius:6px;color:var(--amber);font-weight:700}
.meta{padding-top:12px}
.meta .title{font-weight:600;font-size:15px;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.meta .genre{color:var(--muted);font-size:12px}
/* ---------- Chips slider (geser/swipe) ---------- */
.chips-slider{position:relative}
.chips-row{display:flex;gap:10px;overflow-x:auto;padding:4px 2px;scroll-behavior:smooth;scroll-snap-type:x proximity;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;-webkit-overflow-scrolling:touch}
.chips-row::-webkit-scrollbar{display:none}
.chips-row.dragging{cursor:grabbing;scroll-behavior:auto;scroll-snap-type:none}
.chips-row .chip{scroll-snap-align:start;flex:0 0 auto}
/* fade tepi (muncul saat masih bisa digeser) */
.chips-slider::before,.chips-slider::after{content:'';position:absolute;top:0;bottom:0;width:54px;pointer-events:none;z-index:2;opacity:0;transition:opacity .25s}
.chips-slider::before{left:0;background:linear-gradient(90deg,var(--bg) 20%,transparent)}
.chips-slider::after{right:0;background:linear-gradient(270deg,var(--bg) 20%,transparent)}
.chips-slider.can-left::before{opacity:1}
.chips-slider.can-right::after{opacity:1}
/* tombol panah (desktop) */
.chips-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:34px;height:34px;border-radius:50%;display:none;align-items:center;justify-content:center;background:var(--panel-2);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:background .2s,border-color .2s,transform .15s;box-shadow:0 6px 16px rgba(0,0,0,.45)}
.chips-nav:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.chips-nav:active{transform:translateY(-50%) scale(.92)}
.chips-prev{left:-8px}.chips-next{right:-8px}
.chips-slider.can-left .chips-prev{display:flex}
.chips-slider.can-right .chips-next{display:flex}
@media (hover:none){.chips-nav{display:none!important}}

/* ---------- Watch ---------- */
.watch-layout{display:grid;grid-template-columns:1fr 350px;gap:30px;align-items:start}
.video-container{background:#000;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden}
.video-container iframe,.video-container video{width:100%;height:100%;border:none;display:block;object-fit:contain;background:#000}
.sidebar{background:var(--panel);padding:20px;border-radius:var(--radius);border:1px solid var(--border)}
.ep-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:15px;max-height:420px;overflow-y:auto;padding-right:5px}
.ep-btn{background:var(--bg);border:1px solid var(--border);color:var(--muted);padding:10px 0;border-radius:6px;cursor:pointer;text-align:center;font-size:13px;transition:.2s}
.ep-btn:hover,.ep-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.watch-title{margin:18px 0 6px;font-size:22px}
.watch-actions{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0}

/* ---------- Detail page ---------- */
.detail-head{display:grid;grid-template-columns:240px 1fr;gap:26px;margin-bottom:20px}
.detail-poster{border-radius:var(--radius);aspect-ratio:2/3;object-fit:cover;width:100%}
.detail-info h1{font-size:2rem;margin-bottom:10px}
.detail-info .sub{color:var(--muted);margin-bottom:14px;display:flex;gap:14px;flex-wrap:wrap}
.detail-info p.syn{color:#cdd5e3;line-height:1.6;margin:14px 0}

/* ---------- Forms / Auth ---------- */
.auth-wrap{max-width:430px;margin:50px auto;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:34px}
.auth-wrap h2{margin-bottom:6px}
.auth-wrap p.sub{color:var(--muted);margin-bottom:22px;font-size:14px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:7px;font-weight:600}
.input,select.input,textarea.input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:12px 14px;color:var(--text);font-size:14px;outline:none;transition:.2s}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,71,87,.12)}
textarea.input{min-height:90px;resize:vertical}
.checkbox-row{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--muted)}
.form-help{font-size:12px;color:var(--muted);margin-top:6px}
.error{color:#ff6b6b;font-size:13px;margin-top:6px}
.auth-foot{margin-top:18px;text-align:center;color:var(--muted);font-size:14px}
.auth-foot a{color:var(--accent);font-weight:600}

/* ---------- Alerts ---------- */
.alert{padding:13px 16px;border-radius:10px;margin-bottom:18px;font-size:14px;border:1px solid}
.alert-success{background:rgba(46,213,115,.1);border-color:rgba(46,213,115,.3);color:#7bed9f}
.alert-error{background:rgba(255,71,87,.1);border-color:rgba(255,71,87,.3);color:#ff8e9e}

/* ---------- Donation ---------- */
.donate-grid{display:grid;grid-template-columns:1fr 360px;gap:30px;align-items:start}
.amount-options{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.amount-opt{flex:1;min-width:90px;text-align:center;padding:14px;border-radius:10px;background:var(--bg);border:1px solid var(--border);cursor:pointer;font-weight:700;transition:.2s}
.amount-opt:hover,.amount-opt.active{border-color:var(--accent);background:rgba(255,71,87,.08);color:#fff}
.qr-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:26px;text-align:center}
.qr-card img{width:280px;height:280px;margin:14px auto;background:#fff;border-radius:12px;padding:10px}
.status-pill{display:inline-block;padding:6px 14px;border-radius:50px;font-size:13px;font-weight:700}
.status-pending{background:rgba(255,165,2,.15);color:var(--amber)}
.status-paid{background:rgba(46,213,115,.15);color:var(--green)}
.status-failed,.status-expired{background:rgba(255,71,87,.15);color:#ff6b6b}

/* ---------- Ads ---------- */
.ad-banner{display:block;margin:18px auto;text-align:center;max-width:100%}
.ad-banner img{margin:0 auto;border-radius:10px}
.ad-slot{margin:18px 0;text-align:center;overflow:hidden}
.ad-label{font-size:10px;color:#555;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}

/* ---------- Footer ---------- */
footer.site{border-top:1px solid var(--border);margin-top:50px;padding:34px 20px;color:var(--muted);text-align:center;font-size:13px}
footer.site a{color:var(--accent)}

/* ---------- Tables / admin ---------- */
.admin-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.admin-side{background:var(--panel);border-right:1px solid var(--border);padding:20px 14px;position:sticky;top:0;height:100vh;overflow-y:auto}
.admin-side .brand{padding:6px 10px 16px}
.admin-nav a{display:flex;gap:10px;align-items:center;padding:11px 14px;border-radius:9px;color:var(--muted);font-size:14px;font-weight:600;margin-bottom:3px}
.admin-nav a:hover{background:var(--panel-hover);color:var(--text)}
.admin-nav a.active{background:var(--accent);color:#fff}
.admin-main{padding:26px 30px;max-width:100%;overflow-x:hidden}
.admin-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.admin-head h1{font-size:24px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:26px}
.stat-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px}
.stat-card .n{font-size:28px;font-weight:800;margin-top:6px}
.stat-card .l{color:var(--muted);font-size:13px}
.panel{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:20px}
.panel h3{margin-bottom:14px;font-size:17px}
table.tbl{width:100%;border-collapse:collapse;font-size:14px}
table.tbl th,table.tbl td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--border)}
table.tbl th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}
table.tbl tr:hover td{background:rgba(255,255,255,.02)}
.tag{display:inline-block;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:700;background:var(--panel-2)}
.tag.admin{background:rgba(83,82,237,.2);color:#a29bfe}
.tag.user{background:var(--panel-2);color:var(--muted)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.inline-form{display:inline}

/* pagination */
.pagination{display:flex;gap:6px;list-style:none;margin-top:24px;flex-wrap:wrap;justify-content:center}
.pagination a,.pagination span{padding:8px 13px;border-radius:8px;background:var(--panel);border:1px solid var(--border);color:var(--muted);font-size:13px}
.pagination .active span{background:var(--accent);color:#fff;border-color:var(--accent)}
.pagination [aria-disabled] span{opacity:.4}

/* ---------- SEO / FAQ block ---------- */
.seo-block{clear:both;margin-top:56px;padding:clamp(22px,4vw,38px);background:linear-gradient(180deg,var(--panel) 0%,rgba(19,20,24,.35) 100%);border:1px solid var(--border);border-radius:18px;color:var(--muted);line-height:1.75}
.seo-block h2{color:var(--text);font-size:20px;font-weight:700;margin:34px 0 14px;display:flex;align-items:center;gap:11px}
.seo-block h2::before{content:'';width:4px;height:21px;background:var(--accent);border-radius:4px;flex:0 0 auto}
.seo-block > h2:first-child{margin-top:0}
.seo-block p{margin:0 0 14px;font-size:14.5px;max-width:80ch}
.seo-block p:last-child{margin-bottom:0}
.seo-block strong{color:#dbe2ee;font-weight:600}

.faq{margin-top:16px;display:flex;flex-direction:column;gap:10px}
.faq-item{background:var(--bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .2s,background .2s}
.faq-item[open]{border-color:rgba(255,71,87,.45)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;font-weight:600;color:var(--text);font-size:15px;padding:15px 18px;list-style:none;user-select:none;transition:background .2s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';color:var(--accent);font-weight:800;font-size:22px;line-height:1;flex:0 0 auto}
.faq-item[open] summary::after{content:'–'}
.faq-item summary:hover{background:var(--panel-hover)}
.faq-item > p{margin:0;padding:2px 18px 16px;font-size:14px;color:var(--muted);line-height:1.7;max-width:none}

.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty .ico{font-size:48px;margin-bottom:10px}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .watch-layout,.donate-grid{grid-template-columns:1fr}
  .detail-head{grid-template-columns:160px 1fr}
  .admin-shell{grid-template-columns:1fr}
  .admin-side{position:static;height:auto;display:flex;flex-wrap:wrap;gap:6px}
  .admin-nav{display:flex;flex-wrap:wrap;gap:6px}
}
@media (max-width:600px){
  .hero h1{font-size:2rem}.hero{padding:40px 20px;min-height:280px}
  .grid-2{grid-template-columns:1fr}
  .nav-link.hide-sm{display:none}
}
