/* ===================== CINESTREAM CSS ===================== */
/* Dark theme Netflix/Crunchyroll style */

:root {
  --bg: #0a0a0a;
  --card: #141414;
  --accent: #e50914;
  --accent-hover: #f40612;
  --text: #fff;
  --text-muted: #888;
  --text-dim: #555;
  --glass: rgba(255,255,255,.05);
  --glass-border: rgba(255,255,255,.08);
  --glass-hover: rgba(255,255,255,.1);
  --shadow: 0 4px 20px rgba(0,0,0,.5);
  --radius: 10px;
  --radius-sm: 6px;
  --transition: .25s cubic-bezier(.4,0,.2,1);
  --header-h: 56px;
}

/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
img{display:block;max-width:100%}
input{font-family:inherit}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.25)}

/* ===== HEADER ===== */
.header{
  position:sticky;top:0;z-index:100;
  background:rgba(10,10,10,.92);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.04);
  padding:0 20px;height:var(--header-h);
  display:flex;align-items:center;gap:16px;
}
.logo{font-size:22px;font-weight:900;color:var(--accent);letter-spacing:-.5px;flex-shrink:0}
.logo span{color:var(--text)}
.nav-links{display:flex;gap:4px;margin-left:12px}
.nav-link{
  padding:6px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;
  color:var(--text-muted);transition:var(--transition);white-space:nowrap;
}
.nav-link:hover,.nav-link.active{color:var(--text);background:var(--glass)}
.search-wrap{margin-left:auto;position:relative}
.search-input{
  background:var(--glass);border:1px solid var(--glass-border);
  border-radius:20px;padding:7px 14px 7px 34px;color:var(--text);
  width:180px;font-size:13px;outline:none;transition:var(--transition);
}
.search-input:focus{border-color:var(--accent);width:240px}
.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--text-muted)}
.menu-btn{display:none;background:none;border:none;color:var(--text);font-size:22px;padding:4px}

/* ===== HERO ===== */
.hero{
  position:relative;height:420px;overflow:hidden;
  margin:12px 20px 0;border-radius:var(--radius);
}
.hero-bg{width:100%;height:100%;object-fit:cover;filter:brightness(.3)}
.hero-gradient{
  position:absolute;inset:0;
  background:linear-gradient(to top,var(--bg) 0%,transparent 50%),
             linear-gradient(to right,rgba(10,10,10,.8) 0%,transparent 60%);
}
.hero-content{position:absolute;bottom:35px;left:35px;right:35px;max-width:550px}
.hero-badge{display:inline-flex;gap:6px;align-items:center;margin-bottom:10px}
.badge{
  background:var(--accent);color:#fff;padding:2px 8px;border-radius:4px;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
}
.badge-rating{background:#f5c518;color:#000}
.hero-title{font-size:32px;font-weight:900;line-height:1.15;margin-bottom:8px;text-shadow:0 2px 8px rgba(0,0,0,.6)}
.hero-meta{font-size:13px;color:var(--text-muted);margin-bottom:6px}
.hero-genres{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.hero-genre{
  background:var(--glass);border:1px solid var(--glass-border);
  padding:3px 10px;border-radius:12px;font-size:11px;color:var(--text-muted);
}
.hero-synopsis{font-size:13px;color:var(--text-muted);line-height:1.6;margin-bottom:18px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hero-btns{display:flex;gap:10px}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:700;
  border:none;transition:var(--transition);
}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover);transform:scale(1.03)}
.btn-ghost{background:var(--glass);color:var(--text);border:1px solid var(--glass-border)}
.btn-ghost:hover{background:var(--glass-hover)}
.btn-icon{background:rgba(255,255,255,.08);color:var(--text);border:1px solid var(--glass-border);padding:10px 14px}
.btn-icon:hover{background:rgba(255,255,255,.15)}

/* ===== SECTIONS ===== */
.section{padding:25px 20px 0}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.section-title{font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px}
.section-title::before{content:'';width:3px;height:18px;background:var(--accent);border-radius:2px}
.section-link{font-size:12px;color:var(--text-muted);transition:var(--transition)}
.section-link:hover{color:var(--accent)}

/* ===== GENRE BAR ===== */
.genre-bar{
  display:flex;gap:8px;padding:15px 20px 0;
  overflow-x:auto;-webkit-overflow-scrolling:touch;
}
.genre-bar::-webkit-scrollbar{display:none}
.genre-pill{
  background:var(--glass);border:1px solid var(--glass-border);
  padding:6px 14px;border-radius:20px;font-size:12px;
  white-space:nowrap;cursor:pointer;transition:var(--transition);
  color:var(--text-muted);
}
.genre-pill:hover,.genre-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* ===== CAROUSEL ===== */
.carousel{
  display:flex;gap:10px;overflow-x:auto;
  padding-bottom:10px;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.carousel::-webkit-scrollbar{height:3px}
.carousel::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}

/* ===== CARDS ===== */
.card{
  min-width:150px;max-width:150px;scroll-snap-align:start;
  cursor:pointer;transition:transform var(--transition);
  flex-shrink:0;
}
.card:hover{transform:scale(1.05)}
.card-poster{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--card)}
.card-img{width:100%;height:210px;object-fit:cover}
.card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(transparent 50%,rgba(0,0,0,.8));
  opacity:0;transition:var(--transition);
  display:flex;align-items:flex-end;padding:10px;
}
.card:hover .card-overlay{opacity:1}
.card-play{
  width:36px;height:36px;border-radius:50%;
  background:var(--accent);display:flex;align-items:center;justify-content:center;
  font-size:14px;
}
.card-badge{
  position:absolute;top:6px;left:6px;
  background:var(--accent);color:#fff;
  padding:2px 7px;border-radius:4px;font-size:9px;font-weight:700;
}
.card-badge-rating{background:#f5c518;color:#000;left:auto;right:6px}
.card-info{padding:8px 2px 0}
.card-title{
  font-size:12px;font-weight:600;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;margin-bottom:3px;
}
.card-meta{font-size:10px;color:var(--text-muted)}

/* ===== GRID ===== */
.content-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:12px;
}

/* ===== DETAIL PAGE ===== */
.detail-page{
  display:none;position:fixed;inset:0;z-index:200;
  background:var(--bg);overflow-y:auto;
}
.detail-page.active{display:block}
.detail-backdrop{position:relative;height:350px;overflow:hidden}
.detail-backdrop img{width:100%;height:100%;object-fit:cover;filter:brightness(.25)}
.detail-backdrop-gradient{
  position:absolute;inset:0;
  background:linear-gradient(to top,var(--bg),transparent 60%);
}
.detail-close{
  position:absolute;top:12px;left:12px;z-index:10;
  background:rgba(0,0,0,.6);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.1);color:var(--text);
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;transition:var(--transition);
}
.detail-close:hover{background:var(--accent)}
.detail-body{max-width:1000px;margin:-80px auto 0;padding:0 20px 40px;position:relative}
.detail-header{display:flex;gap:20px;margin-bottom:20px}
.detail-poster{width:160px;border-radius:var(--radius);overflow:hidden;flex-shrink:0;box-shadow:var(--shadow)}
.detail-poster img{width:100%;height:240px;object-fit:cover}
.detail-info{flex:1;min-width:0}
.detail-title{font-size:24px;font-weight:900;margin-bottom:4px}
.detail-subtitle{font-size:13px;color:var(--text-dim);margin-bottom:10px}
.detail-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.detail-tag{
  background:var(--glass);border:1px solid var(--glass-border);
  padding:3px 10px;border-radius:var(--radius-sm);
  font-size:11px;color:var(--text-muted);
}
.detail-tag-accent{background:var(--accent);border-color:var(--accent);color:#fff}
.detail-synopsis{font-size:13px;color:var(--text-muted);line-height:1.7;margin-bottom:20px}
.detail-btns{display:flex;gap:10px;flex-wrap:wrap}

/* Episode List */
.ep-section{margin-top:25px}
.ep-section h3{font-size:16px;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.ep-section h3::before{content:'';width:3px;height:14px;background:var(--accent);border-radius:2px}
.ep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(55px,1fr));gap:6px}
.ep-btn{
  background:var(--glass);border:1px solid var(--glass-border);
  color:var(--text);padding:8px 4px;border-radius:var(--radius-sm);
  font-size:12px;text-align:center;transition:var(--transition);
}
.ep-btn:hover,.ep-btn.active{background:var(--accent);border-color:var(--accent)}
.ep-btn.watched{border-color:rgba(0,200,80,.3);color:#00c850}

/* ===== PLAYER PAGE ===== */
.player-page{
  display:none;position:fixed;inset:0;z-index:300;
  background:#000;flex-direction:column;
}
.player-page.active{display:flex}
.player-header{
  padding:8px 12px;display:flex;align-items:center;gap:10px;
  background:#0a0a0a;flex-shrink:0;
}
.player-close{
  background:none;border:none;color:var(--text);
  font-size:20px;padding:4px 8px;border-radius:var(--radius-sm);
  transition:var(--transition);
}
.player-close:hover{background:rgba(255,255,255,.1)}
.player-title{flex:1;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-ep-info{font-size:12px;color:var(--text-muted);flex-shrink:0}
/* Iframe takes most of screen — crop EVERYTHING except video player */
.player-video{flex:1;position:relative;overflow:hidden;background:#000;max-width:900px;margin:0 auto;width:100%}
.player-video iframe{
  width:100%;height:calc(100% + 600px);border:none;
  margin-top:-150px;  /* crop header + nav */
  margin-bottom:-400px; /* crop info box + download + sidebar */
}
.player-controls{
  background:#0a0a0a;border-top:1px solid rgba(255,255,255,.04);
  flex-shrink:0;max-height:40vh;overflow-y:auto;
}
.server-tabs{display:flex;gap:6px;padding:10px 12px;flex-wrap:wrap}
.server-tab{
  background:var(--glass);border:1px solid var(--glass-border);
  color:var(--text-muted);padding:5px 12px;border-radius:var(--radius-sm);
  font-size:11px;cursor:pointer;transition:var(--transition);
}
.server-tab:hover,.server-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}
.ep-nav{display:flex;gap:6px;padding:0 12px 8px;align-items:center}
.ep-nav-btn{
  background:var(--glass);border:1px solid var(--glass-border);
  color:var(--text);padding:6px 14px;border-radius:var(--radius-sm);
  font-size:12px;transition:var(--transition);
}
.ep-nav-btn:hover:not(:disabled){background:var(--accent);border-color:var(--accent)}
.ep-nav-btn:disabled{opacity:.3;cursor:not-allowed}
.ep-nav-info{flex:1;text-align:center;font-size:12px;color:var(--text-muted)}
.player-ep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:5px;padding:8px 12px 12px}

/* ===== FOOTER ===== */
.footer{
  text-align:center;padding:30px 20px;margin-top:30px;
  border-top:1px solid rgba(255,255,255,.04);
  color:var(--text-dim);font-size:11px;
}
.footer a{color:var(--text-muted);transition:var(--transition)}
.footer a:hover{color:var(--accent)}

/* ===== EMPTY STATE ===== */
.empty{text-align:center;padding:60px 20px;color:var(--text-muted)}
.empty-icon{font-size:48px;margin-bottom:12px}
.empty-text{font-size:14px}

/* ===== TOAST ===== */
.toast{
  position:fixed;bottom:80px;left:50%;transform:translateX(-50%);
  background:rgba(20,20,20,.95);backdrop-filter:blur(10px);
  border:1px solid var(--glass-border);border-radius:var(--radius);
  padding:10px 20px;font-size:13px;color:var(--text);
  z-index:500;opacity:0;transition:opacity .3s;pointer-events:none;
}
.toast.show{opacity:1}

/* ===== BOTTOM NAV (mobile) ===== */
.bottom-nav{
  display:none;position:fixed;bottom:0;left:0;right:0;
  background:rgba(10,10,10,.95);backdrop-filter:blur(12px);
  border-top:1px solid rgba(255,255,255,.06);
  padding:6px 0;z-index:50;
}
.nav-items{display:flex;justify-content:space-around}
.bnav{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-muted);font-size:9px;padding:4px 0}
.bnav.active{color:var(--accent)}
.bnav-icon{font-size:18px}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  .header{padding:0 12px}
  .nav-links{display:none}
  .menu-btn{display:block}
  .search-input{width:140px}
  .search-input:focus{width:180px}
  .hero{height:280px;margin:8px 12px 0;border-radius:8px}
  .hero-content{bottom:20px;left:18px;right:18px}
  .hero-title{font-size:22px}
  .hero-synopsis{-webkit-line-clamp:2}
  .section{padding:20px 12px 0}
  .genre-bar{padding:12px 12px 0}
  .card{min-width:130px;max-width:130px}
  .card-img{height:185px}
  .content-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
  .detail-header{flex-direction:column;align-items:center;text-align:center}
  .detail-poster{width:140px}
  .detail-btns{justify-content:center}
  .bottom-nav{display:block}
  body{padding-bottom:55px}
}
@media(min-width:1024px){
  .hero{height:480px}
  .hero-content{max-width:600px}
  .hero-title{font-size:38px}
  .card{min-width:170px;max-width:170px}
  .card-img{height:240px}
  .content-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}
  .detail-body{max-width:1100px}
}

/* ===== ANIMATIONS ===== */
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .3s ease}
