@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --bg:        #080608;
  --bg2:       #100d10;
  --bg3:       #18121a;
  --card:      #130f14;
  --pink:      #ff2d78;
  --pink2:     #ff6faa;
  --pink-dim:  rgba(255,45,120,0.12);
  --pink-glow: rgba(255,45,120,0.35);
  --white:     #f5eef5;
  --gray:      #9888a0;
  --muted:     #3d2f42;
  --border:    rgba(255,255,255,0.06);
  --border-p:  rgba(255,45,120,0.3);
  --radius:    12px;
  --radius-sm: 8px;
  --shadow:    0 8px 40px rgba(0,0,0,0.7);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--bg);
  color: var(--white);
  min-height: 100vh;
  overflow-x: hidden;
}

/* Noise grain */
body::after {
  content:'';
  position:fixed; inset:0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events:none; z-index:999; opacity:0.5;
}

/* Pink mesh bg glow */
body::before {
  content:'';
  position:fixed;
  top:-30vh; right:-20vw;
  width:70vw; height:70vw;
  border-radius:50%;
  background: radial-gradient(circle, rgba(255,45,120,0.07) 0%, transparent 70%);
  pointer-events:none; z-index:0;
}

a { text-decoration:none; color:inherit; }
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--muted); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--pink); }

/* ── NAVBAR ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:62px;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 clamp(14px,4vw,52px);
  background:rgba(8,6,8,0.88);
  backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
}

.nav-logo {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.7rem;
  letter-spacing:2px;
  color:var(--white);
  display:flex; align-items:center; gap:3px;
}

.nav-logo .ni { color:var(--pink); }

.nav-logo .dot {
  width:7px; height:7px;
  background:var(--pink);
  border-radius:50%;
  box-shadow:0 0 10px var(--pink);
  margin:0 2px;
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0%,100% { box-shadow:0 0 6px var(--pink); }
  50% { box-shadow:0 0 16px var(--pink), 0 0 30px var(--pink-glow); }
}

.nav-links { display:flex; gap:2px; list-style:none; }
.nav-links a {
  padding:6px 14px; border-radius:6px;
  font-size:0.88rem; font-weight:500;
  color:var(--gray); transition:all .2s;
}
.nav-links a:hover, .nav-links a.active {
  color:var(--pink); background:var(--pink-dim);
}

.nav-right { display:flex; align-items:center; gap:8px; }
.nav-search-btn {
  width:38px; height:38px;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg3); border:1px solid var(--border);
  border-radius:8px; cursor:pointer; color:var(--gray);
  font-size:1rem; transition:all .2s;
}
.nav-search-btn:hover { border-color:var(--pink); color:var(--pink); }

/* ── LOADING ── */
.loading-screen {
  position:fixed; inset:0;
  background:var(--bg);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:20px; z-index:9999;
  transition:opacity .5s;
}
.loading-screen.hide { opacity:0; pointer-events:none; }

.loading-logo {
  font-family:'Bebas Neue',sans-serif;
  font-size:3rem; letter-spacing:4px;
  background:linear-gradient(90deg,var(--pink),var(--pink2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}

.loading-bar {
  width:180px; height:2px;
  background:var(--muted); border-radius:2px; overflow:hidden;
}
.loading-fill {
  height:100%; background:linear-gradient(90deg,var(--pink),var(--pink2));
  animation:fill 1.6s ease forwards;
}
@keyframes fill { from{width:0} to{width:100%} }

/* ── HERO ── */
.hero {
  padding-top:62px; min-height:88vh;
  display:flex; align-items:flex-end;
  position:relative; overflow:hidden;
}

.hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  filter:blur(3px) brightness(0.28) saturate(1.2);
  transform:scale(1.06); transition:all .9s ease;
}

.hero-grad {
  position:absolute; inset:0;
  background:
    linear-gradient(to right, rgba(8,6,8,.97) 0%, rgba(8,6,8,.65) 55%, transparent 100%),
    linear-gradient(to top, rgba(8,6,8,1) 0%, transparent 45%);
}

.hero-pink-line {
  position:absolute; bottom:0; left:0; right:0;
  height:1px;
  background:linear-gradient(to right, var(--pink), transparent 60%);
}

.hero-content {
  position:relative; z-index:2;
  padding:clamp(20px,5vw,80px);
  padding-bottom:clamp(48px,7vw,90px);
  max-width:580px;
  animation:fadeUp .6s ease forwards;
}

.hero-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--pink-dim);
  border:1px solid var(--border-p);
  color:var(--pink); font-size:.72rem;
  font-weight:700; letter-spacing:2px;
  text-transform:uppercase; padding:5px 12px;
  border-radius:20px; margin-bottom:14px;
}

.hero-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2rem,5vw,3.6rem);
  letter-spacing:1px; line-height:1.1;
  margin-bottom:14px;
}

.hero-desc {
  font-size:.92rem; color:var(--gray);
  line-height:1.75; margin-bottom:20px;
  display:-webkit-box; -webkit-line-clamp:3;
  -webkit-box-orient:vertical; overflow:hidden;
}

.hero-meta {
  display:flex; gap:18px; flex-wrap:wrap;
  margin-bottom:24px;
}
.hero-meta span {
  font-size:.82rem; color:var(--gray);
  display:flex; align-items:center; gap:5px;
}
.hero-meta .hl { color:var(--pink); }

.hero-tags {
  display:flex; gap:7px; flex-wrap:wrap; margin-bottom:24px;
}
.tag {
  padding:4px 10px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:4px; font-size:.73rem;
  color:var(--gray); cursor:pointer;
  transition:all .2s;
}
.tag:hover { border-color:var(--pink); color:var(--pink); }

.hero-btns { display:flex; gap:10px; flex-wrap:wrap; }

.btn-pink {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 28px;
  background:linear-gradient(135deg,var(--pink),#c0235a);
  color:#fff; border:none; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif;
  font-size:.9rem; font-weight:700;
  cursor:pointer; transition:all .2s;
  box-shadow:0 4px 20px var(--pink-glow);
}
.btn-pink:hover { transform:translateY(-2px); box-shadow:0 8px 30px var(--pink-glow); }

.btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 22px;
  background:rgba(255,255,255,.05);
  border:1px solid var(--border);
  color:var(--white);
  border-radius:var(--radius-sm);
  font-size:.9rem; font-weight:500;
  cursor:pointer; transition:all .2s;
}
.btn-ghost:hover { border-color:var(--pink); color:var(--pink); }

/* Hero thumbs */
.hero-thumbs {
  position:absolute; right:clamp(14px,4vw,52px); bottom:48px;
  display:flex; gap:10px; z-index:3;
}
.hero-thumb {
  width:58px; height:82px; border-radius:7px;
  overflow:hidden; cursor:pointer; opacity:.45;
  border:2px solid transparent; transition:all .2s;
}
.hero-thumb.active, .hero-thumb:hover { opacity:1; border-color:var(--pink); }
.hero-thumb img { width:100%; height:100%; object-fit:cover; }

/* ── SECTION ── */
.section { padding:44px clamp(14px,4vw,52px); position:relative; z-index:1; }

.sec-head {
  display:flex; align-items:center;
  justify-content:space-between; margin-bottom:22px;
}
.sec-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.35rem; letter-spacing:1.5px;
  display:flex; align-items:center; gap:10px;
}
.sec-title::before {
  content:'';
  width:3px; height:22px;
  background:linear-gradient(180deg,var(--pink),var(--pink2));
  border-radius:2px;
  box-shadow:0 0 10px var(--pink-glow);
}
.see-all {
  font-size:.82rem; color:var(--pink);
  display:flex; align-items:center; gap:4px;
  transition:gap .2s;
}
.see-all:hover { gap:8px; }

/* ── CARDS ── */
.grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(155px,1fr));
  gap:14px;
}

.card {
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--card);
  cursor:pointer;
  position:relative;
  transition:transform .22s, box-shadow .22s;
}
.card:hover { transform:translateY(-5px); box-shadow:0 14px 40px rgba(0,0,0,.7); }

.card-img {
  width:100%; aspect-ratio:2/3;
  object-fit:cover; display:block;
  transition:filter .3s;
}
.card:hover .card-img { filter:brightness(.65) saturate(1.1); }

.card-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.92) 0%, transparent 55%);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:10px;
}

.card-play {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%) scale(.7);
  width:46px; height:46px;
  background:linear-gradient(135deg,var(--pink),#c0235a);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:all .2s;
  font-size:1.1rem; color:#fff;
  box-shadow:0 4px 16px var(--pink-glow);
}
.card:hover .card-play { opacity:1; transform:translate(-50%,-50%) scale(1); }

.card-title {
  font-size:.8rem; font-weight:600; color:#fff;
  line-height:1.3;
  display:-webkit-box; -webkit-line-clamp:2;
  -webkit-box-orient:vertical; overflow:hidden;
}
.card-sub {
  font-size:.68rem; color:var(--pink);
  margin-top:3px;
}

.card-badge {
  position:absolute; top:7px; left:7px;
  background:linear-gradient(135deg,var(--pink),#c0235a);
  color:#fff; font-size:.62rem; font-weight:700;
  padding:2px 7px; border-radius:4px;
  text-transform:uppercase; letter-spacing:.5px;
}

.card-score {
  position:absolute; top:7px; right:7px;
  background:rgba(0,0,0,.75);
  border:1px solid rgba(255,255,255,.1);
  color:var(--pink2); font-size:.68rem; font-weight:700;
  padding:2px 7px; border-radius:4px;
  display:flex; align-items:center; gap:3px;
}

/* ── SCROLL ROW ── */
.scroll-wrap { position:relative; }
.scroll-row {
  display:flex; gap:12px; overflow-x:auto;
  padding-bottom:6px; scrollbar-width:none;
  scroll-snap-type:x mandatory;
}
.scroll-row::-webkit-scrollbar { display:none; }
.scroll-row .card { min-width:148px; flex-shrink:0; scroll-snap-align:start; }

.scr-btn {
  position:absolute; top:50%; transform:translateY(-50%);
  width:36px; height:36px;
  background:rgba(19,15,20,.92);
  border:1px solid var(--border);
  color:var(--white); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; z-index:5; font-size:.9rem;
  transition:all .2s;
}
.scr-btn:hover { background:var(--pink); border-color:var(--pink); }
.scr-btn.l { left:-16px; }
.scr-btn.r { right:-16px; }

/* ── GENRE CHIPS ── */
.chips { display:flex; flex-wrap:wrap; gap:9px; margin-bottom:28px; }
.chip {
  padding:7px 17px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:20px; font-size:.83rem;
  color:var(--gray); cursor:pointer;
  transition:all .2s;
}
.chip:hover, .chip.active {
  background:var(--pink-dim);
  border-color:var(--pink); color:var(--pink);
}

/* ── SEARCH PAGE ── */
.search-page {
  padding-top:90px; min-height:100vh;
  padding-left:clamp(14px,4vw,52px);
  padding-right:clamp(14px,4vw,52px);
}

.search-bar {
  position:relative; max-width:680px;
  margin:0 auto 36px;
}
.search-bar input {
  width:100%;
  padding:15px 54px 15px 20px;
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--white);
  font-family:'DM Sans',sans-serif;
  font-size:.97rem; outline:none;
  transition:border-color .2s;
}
.search-bar input:focus {
  border-color:var(--pink);
  box-shadow:0 0 0 3px var(--pink-dim);
}
.search-bar input::placeholder { color:var(--muted); }
.search-bar .sbtn {
  position:absolute; right:10px; top:50%;
  transform:translateY(-50%);
  width:36px; height:36px;
  background:linear-gradient(135deg,var(--pink),#c0235a);
  border:none; border-radius:7px;
  color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem;
}

/* ── DETAIL PAGE ── */
.detail-hero {
  padding-top:62px; min-height:520px;
  display:flex; align-items:flex-end;
  position:relative; overflow:hidden;
}
.d-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center top;
  filter:blur(4px) brightness(.25) saturate(1.3);
  transform:scale(1.06);
}
.d-grad {
  position:absolute; inset:0;
  background:linear-gradient(to top, var(--bg) 20%, transparent 70%);
}
.d-content {
  position:relative; z-index:2;
  display:flex; gap:28px; align-items:flex-end;
  padding:clamp(14px,4vw,52px);
  padding-bottom:40px; width:100%;
}
.d-poster {
  width:175px; min-width:175px;
  aspect-ratio:2/3; border-radius:var(--radius);
  object-fit:cover;
  box-shadow:0 8px 40px rgba(0,0,0,.8);
  border:1px solid var(--border-p);
}
.d-info { flex:1; }
.d-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(1.8rem,4vw,3rem);
  letter-spacing:1px; line-height:1.1;
  margin-bottom:12px;
}
.d-meta {
  display:flex; gap:18px; flex-wrap:wrap;
  margin-bottom:14px;
}
.d-meta span {
  font-size:.83rem; color:var(--gray);
  display:flex; align-items:center; gap:5px;
}
.d-desc {
  font-size:.9rem; color:var(--gray);
  line-height:1.7; margin-bottom:18px;
  max-width:600px;
}

/* ── EPISODES ── */
.eps-section { padding:28px clamp(14px,4vw,52px); }
.eps-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(76px,1fr));
  gap:9px; max-width:820px;
}
.ep-btn {
  padding:10px 0; text-align:center;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  font-size:.82rem; font-weight:600;
  color:var(--gray); cursor:pointer;
  transition:all .2s;
}
.ep-btn:hover, .ep-btn.active {
  background:var(--pink-dim);
  border-color:var(--pink); color:var(--pink);
}

/* ── WATCH PAGE ── */
.watch-page { padding-top:62px; min-height:100vh; }

.player-wrap {
  width:100%; max-width:1100px;
  margin:0 auto;
  background:#000;
  border-bottom:2px solid var(--pink);
  position:relative;
}
.player-wrap iframe {
  width:100%; aspect-ratio:16/9;
  border:none; display:block;
}
.player-wrap .no-src {
  aspect-ratio:16/9;
  display:flex; align-items:center; justify-content:center;
  color:var(--muted); font-size:.9rem; flex-direction:column; gap:10px;
}

.watch-info {
  max-width:1100px; margin:0 auto;
  padding:20px clamp(14px,3vw,32px);
}
.watch-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.5rem; letter-spacing:1px; margin-bottom:10px;
}

.servers {
  display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px;
}
.server-btn {
  padding:8px 18px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  font-size:.82rem; color:var(--gray);
  cursor:pointer; transition:all .2s;
}
.server-btn:hover, .server-btn.active {
  background:var(--pink-dim);
  border-color:var(--pink); color:var(--pink);
}

.watch-eps-row {
  display:flex; gap:8px; flex-wrap:wrap;
  max-height:200px; overflow-y:auto;
  padding:4px; margin-bottom:16px;
}

/* ── PAGINATION ── */
.pagination {
  display:flex; gap:7px; justify-content:center;
  margin-top:36px; flex-wrap:wrap;
}
.pg-btn {
  width:36px; height:36px;
  display:flex; align-items:center; justify-content:center;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--gray); font-size:.83rem;
  cursor:pointer; transition:all .2s;
}
.pg-btn:hover, .pg-btn.active {
  background:var(--pink-dim);
  border-color:var(--pink); color:var(--pink);
}

/* ── EMPTY ── */
.empty {
  text-align:center; padding:80px 20px;
  color:var(--muted); grid-column:1/-1;
}
.empty .ico { font-size:3rem; margin-bottom:14px; }
.empty h3 { color:var(--gray); margin-bottom:6px; }

/* ── FOOTER ── */
footer {
  text-align:center; padding:30px;
  border-top:1px solid var(--border);
  font-size:.82rem; color:var(--muted);
  position:relative; z-index:1;
}
footer .fl {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.3rem; letter-spacing:2px;
  background:linear-gradient(90deg,var(--pink),var(--pink2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}

/* ── ANIMATIONS ── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}
.fade-up { animation:fadeUp .45s ease forwards; opacity:0; }

/* ── SKELETON ── */
.skeleton {
  background:linear-gradient(90deg,var(--card) 25%,rgba(255,255,255,.04) 50%,var(--card) 75%);
  background-size:200% 100%;
  animation:shimmer 1.6s infinite;
  border-radius:var(--radius);
}
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ── RESPONSIVE ── */
@media (max-width:768px) {
  .hero-thumbs { display:none; }
  .d-content { flex-direction:column; align-items:flex-start; }
  .d-poster { width:120px; min-width:120px; }
  .nav-links { display:none; }
  .grid { grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); }
}

/* ── SPINNER ── */
.spinner {
  width:36px; height:36px;
  border:3px solid var(--muted);
  border-top-color:var(--pink);
  border-radius:50%;
  animation:spin .8s linear infinite;
  margin:60px auto;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* Info table */
.info-table { display:flex; flex-direction:column; gap:6px; margin-bottom:18px; }
.info-row { display:flex; gap:10px; font-size:.83rem; }
.info-key { color:var(--gray); min-width:120px; }
.info-val { color:var(--white); }
