/* ═══════════════════════════════════════════════════════════════════
   CINEFLIXX — Design System v3
   All bugs fixed · Mobile aligned · Dense layout · Cinematic
   ════════════════════════════════════════════════════════════════════ */

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

/* ── Variables ─────────────────────────────────────────────────── */
:root {
  --bg:       #0a0a0a;
  --bg-card:  #111;
  --bg-el:    #181818;
  --bg-modal: #141414;
  --text:     #fff;
  --muted:    #aaa;
  --dim:      #555;
  --accent:   #e50914;
  --accent-h: #ff1a26;
  --glow:     rgba(229,9,20,.4);
  --gold:     #f5c518;
  --green:    #46d369;
  --blue:     #0f76bf;
  --nav-h:    60px;
  --r:        6px;
  --rlg:      14px;
  --shadow:   0 4px 20px rgba(0,0,0,.7);
  --shadowH:  0 16px 50px rgba(0,0,0,.95);
  --t:        .22s ease;
  --fd:       'Bebas Neue', Impact, sans-serif;
  --fb:       'Outfit', 'Helvetica Neue', sans-serif;
  --gap:      7px;
  --cw:       clamp(115px, 12vw, 172px);
  --px:       clamp(12px, 3vw, 44px);
}

/* ── Reset ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background:var(--bg); color:var(--text);
  font-family:var(--fb); font-size:14px; line-height:1.5;
  overflow-x:hidden; -webkit-font-smoothing:antialiased;
}
a { color:inherit; text-decoration:none; }
button { cursor:pointer; border:none; background:none; font:inherit; color:inherit; }
img { display:block; max-width:100%; }
ul  { list-style:none; }
select { appearance:none; -webkit-appearance:none; }

/* ════════════════════════════════════════════════════════════════════
   NAV
   ════════════════════════════════════════════════════════════════════ */
#main-nav {
  position:fixed; inset:0 0 auto; z-index:1000;
  height:var(--nav-h);
  display:flex; align-items:center; gap:0;
  padding:0 var(--px);
  background:linear-gradient(to bottom, rgba(0,0,0,.95) 0%, transparent 100%);
  transition:background var(--t), box-shadow var(--t);
}
#main-nav.opaque {
  background:rgba(10,10,10,.97);
  box-shadow:0 1px 0 rgba(255,255,255,.06), 0 2px 20px rgba(0,0,0,.8);
  backdrop-filter:blur(12px);
}

.nav-logo {
  font-family:var(--fd); font-size:28px; letter-spacing:1px;
  flex-shrink:0; margin-right:20px;
}
.nav-logo a { color:var(--text); }
.logo-accent { color:var(--accent); }

/* Nav links */
#nav-links {
  display:flex; align-items:center; gap:2px; flex:1;
}
.nav-link {
  padding:7px 12px; border-radius:var(--r);
  color:var(--muted); font-size:13px; font-weight:500;
  transition:color var(--t), background var(--t); white-space:nowrap;
}
.nav-link:hover { color:var(--text); background:rgba(255,255,255,.07); }
.nav-link.active { color:var(--accent); }

/* Nav right */
.nav-right {
  display:flex; align-items:center; gap:10px; margin-left:auto;
}

/* Search */
.nav-search {
  display:flex; align-items:center; gap:7px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px; padding:6px 14px;
  transition:all var(--t);
}
.nav-search:focus-within {
  background:rgba(255,255,255,.11);
  border-color:rgba(255,255,255,.22);
  box-shadow:0 0 0 2px var(--glow);
}
.nav-search-icon { color:var(--muted); font-size:14px; flex-shrink:0; }
.nav-search-input {
  background:none; border:none; color:var(--text);
  font:inherit; font-size:13px; width:165px; outline:none;
}
.nav-search-input::placeholder { color:var(--dim); }

/* Watchlist btn */
.nav-wl-btn {
  padding:6px 14px; border-radius:20px;
  border:1px solid rgba(255,255,255,.13);
  color:var(--muted); font-size:13px; font-weight:500;
  transition:all var(--t); white-space:nowrap;
}
.nav-wl-btn:hover { color:var(--text); border-color:rgba(255,255,255,.28); }

/* Ko-fi btn */
.nav-kofi {
  display:flex; align-items:center; gap:5px;
  padding:6px 12px; border-radius:20px;
  background:#ff5e5b; color:#fff;
  font-size:12px; font-weight:700;
  transition:filter var(--t);
}
.nav-kofi:hover { filter:brightness(1.12); }

/* Burger (mobile) */
#nav-burger {
  display:none; flex-direction:column; gap:5px;
  padding:5px; margin-left:auto; z-index:1001;
}
#nav-burger span {
  display:block; width:22px; height:2px;
  background:var(--text); border-radius:2px;
  transition:var(--t);
}
#nav-burger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
#nav-burger.open span:nth-child(2) { opacity:0; }
#nav-burger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ════════════════════════════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════════════════════════════ */
.hero {
  position:relative;
  height:clamp(400px, 54vw, 700px);
  overflow:hidden;
  transition:opacity .4s ease;
}
.hero-bg { position:absolute; inset:0; }
.hero-img {
  width:100%; height:100%; object-fit:cover; object-position:center 20%;
  transition:transform 10s ease;
}
.hero:hover .hero-img { transform:scale(1.03); }
.hero-vignette {
  position:absolute; inset:0;
  background:radial-gradient(ellipse at 70% 50%, transparent 40%, rgba(10,10,10,.55) 100%);
}
.hero-grad {
  position:absolute; inset:0;
  background:
    linear-gradient(to right, rgba(10,10,10,.97) 0%, rgba(10,10,10,.5) 45%, transparent 70%),
    linear-gradient(to top, var(--bg) 0%, transparent 28%);
}
.hero-content {
  position:absolute;
  bottom:clamp(60px,8vw,100px);
  left:var(--px); right:42%;
  z-index:2; animation:fadeUp .7s ease both;
}
@keyframes fadeUp { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:none} }

.hero-eyebrow { display:flex; align-items:center; gap:10px; margin-bottom:12px; flex-wrap:wrap; }
.hero-rating  { color:var(--gold); font-weight:700; font-size:14px; }
.hero-year    { color:var(--muted); font-size:13px; }
.hero-title {
  font-family:var(--fd); font-size:clamp(32px,5.5vw,76px);
  line-height:1; letter-spacing:1px; margin-bottom:12px;
  text-shadow:0 2px 28px rgba(0,0,0,.9);
}
.hero-genres  { display:flex; gap:7px; flex-wrap:wrap; margin-bottom:14px; }
.hero-genre {
  font-size:11px; color:var(--muted);
  border:1px solid rgba(255,255,255,.18); padding:2px 9px; border-radius:3px;
}
.hero-overview {
  font-size:14px; color:rgba(255,255,255,.75); line-height:1.65;
  max-width:500px; margin-bottom:22px;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}
.hero-actions { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.hero-dots {
  position:absolute; bottom:26px; right:var(--px);
  display:flex; gap:7px; z-index:5;
}
.hero-dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,.35); transition:all var(--t);
}
.hero-dot.on   { width:22px; border-radius:4px; background:#fff; }
.hero-scroll-cue {
  position:absolute; bottom:24px; left:50%; transform:translateX(-50%);
  color:rgba(255,255,255,.35); font-size:20px; z-index:4;
  animation:bounce 2s ease infinite;
}
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(6px)} }

/* ════════════════════════════════════════════════════════════════════
   BUTTONS
   ════════════════════════════════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 22px; border-radius:var(--r);
  font-size:13px; font-weight:600; white-space:nowrap;
  transition:all var(--t); position:relative; overflow:hidden;
}
.btn-play {
  background:var(--accent); color:#fff;
}
.btn-play:hover { background:var(--accent-h); transform:translateY(-2px); box-shadow:0 8px 28px var(--glow); }
.btn-trailer {
  background:rgba(255,255,255,.13); color:#fff;
  border:1px solid rgba(255,255,255,.2); backdrop-filter:blur(4px);
}
.btn-trailer:hover { background:rgba(255,255,255,.22); transform:translateY(-1px); }
.btn-wl {
  background:rgba(255,255,255,.07); color:var(--muted);
  border:1px solid rgba(255,255,255,.12);
}
.btn-wl:hover  { color:#fff; background:rgba(255,255,255,.14); }
.btn-wl.wl-on  { color:var(--accent); border-color:var(--glow); }

/* ════════════════════════════════════════════════════════════════════
   SECTIONS
   ════════════════════════════════════════════════════════════════════ */
.section { padding:14px 0 4px; }
.reveal-me { opacity:0; transform:translateY(20px); transition:opacity .5s ease, transform .5s ease; }
.reveal-me.revealed { opacity:1; transform:none; }

.section-hdr {
  display:flex; align-items:center; justify-content:space-between;
  padding:0 var(--px); margin-bottom:10px;
}
.section-title {
  font-size:15px; font-weight:700; letter-spacing:.2px;
  display:flex; align-items:center; gap:8px;
}
.cw-dot {
  width:20px; height:20px; border-radius:50%;
  background:var(--green); color:#000;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:9px;
}
.see-all-btn {
  font-size:12px; color:var(--muted); padding:4px 10px;
  border-radius:12px; border:1px solid rgba(255,255,255,.1);
  transition:all var(--t);
}
.see-all-btn:hover { color:var(--text); border-color:rgba(255,255,255,.25); background:rgba(255,255,255,.06); }

/* Row (horizontal scroll) */
.row {
  display:flex; gap:var(--gap);
  overflow-x:auto; padding:6px var(--px) 18px;
  scrollbar-width:none; scroll-snap-type:x proximity;
}
.row::-webkit-scrollbar { display:none; }

/* Grid */
.grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(var(--cw), 1fr));
  gap:var(--gap); padding:4px var(--px) 24px;
}

/* ════════════════════════════════════════════════════════════════════
   CARDS
   ════════════════════════════════════════════════════════════════════ */
.card {
  flex-shrink:0; width:var(--cw);
  border-radius:var(--r); background:var(--bg-card);
  position:relative; cursor:pointer;
  transition:transform var(--t), box-shadow var(--t), z-index 0s;
  will-change:transform; outline:none; scroll-snap-align:start;
}
.card:hover    { transform:scale(1.12); box-shadow:var(--shadowH); z-index:20; }
.card:focus-visible { outline:2px solid var(--accent); outline-offset:2px; }
.grid .card    { width:100%; }

/* Poster */
.card-poster-wrap {
  position:relative; aspect-ratio:2/3; overflow:hidden;
  background:#0d0d0d; border-radius:var(--r) var(--r) 0 0;
}
.card-poster {
  width:100%; height:100%; object-fit:cover;
  transition:transform .4s ease;
}
.card:hover .card-poster { transform:scale(1.06); }

/* Hover trailer */
.card-trailer-container {
  position:absolute; inset:0; z-index:2;
  opacity:0; transition:opacity .3s ease;
  pointer-events:none;
}
.card.trailer-playing .card-trailer-container { opacity:1; pointer-events:auto; }
.card-trailer-frame {
  position:absolute; inset:0;
}
.card-trailer-frame iframe { width:100%; height:100%; border:none; }
.card-trailer-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.7) 0%, transparent 40%);
}

/* Overlay */
.card-overlay {
  position:absolute; inset:0; z-index:3;
  background:linear-gradient(to bottom, rgba(0,0,0,.05) 0%, rgba(0,0,0,.75) 100%);
  display:flex; flex-direction:column; justify-content:space-between; padding:8px;
  opacity:0; transition:opacity var(--t);
}
.card:hover .card-overlay { opacity:1; }
.card-ov-top { display:flex; justify-content:flex-end; }
.card-ov-mid { display:flex; align-items:center; justify-content:center; flex:1; }

/* WL button */
.wl-btn {
  width:30px; height:30px; border-radius:50%;
  background:rgba(0,0,0,.65); backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,.12);
  color:var(--muted); font-size:16px;
  display:flex; align-items:center; justify-content:center;
  transition:all var(--t);
}
.wl-btn:hover { background:rgba(229,9,20,.8); color:#fff; border-color:transparent; }
.wl-btn.wl-on { color:var(--accent); }

/* Play button */
.card-play {
  width:46px; height:46px; border-radius:50%;
  background:var(--accent); color:#fff;
  display:flex; align-items:center; justify-content:center;
  transition:all var(--t); box-shadow:0 4px 18px rgba(0,0,0,.6);
}
.card-play:hover { background:var(--accent-h); transform:scale(1.1); box-shadow:0 6px 24px var(--glow); }

/* Badges */
.badge {
  font-size:9px; font-weight:700; text-transform:uppercase;
  letter-spacing:.6px; padding:2px 6px; border-radius:3px;
}
.badge-m  { background:var(--accent); color:#fff; }
.badge-tv { background:var(--blue); color:#fff; }

/* Static badge position on card */
.card .badge {
  position:absolute; top:6px; left:6px; z-index:4; pointer-events:none;
}

/* Rating pill */
.rating-pill {
  position:absolute; top:6px; right:6px; z-index:4;
  font-size:10px; font-weight:700; padding:2px 6px;
  border-radius:3px; backdrop-filter:blur(8px); pointer-events:none;
}
.rating-pill.small { position:static; font-size:10px; }
.rg { background:rgba(70,211,105,.88); color:#000; }
.ro { background:rgba(245,197,24,.88); color:#000; }
.rb { background:rgba(229,9,20,.88);   color:#fff; }

/* Progress bar */
.progress-bar { position:absolute; bottom:0; left:0; right:0; height:3px; background:rgba(255,255,255,.15); z-index:4; }
.progress-fill { height:100%; background:var(--accent); border-radius:0 2px 2px 0; }

/* Card body */
.card-body { padding:7px 8px 9px; }
.card-title {
  font-size:12px; font-weight:600;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  color:var(--text); margin-bottom:3px;
}
.card-sub {
  display:flex; gap:6px; flex-wrap:wrap; align-items:center;
  font-size:10px; color:var(--dim);
}
.card-genres { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:110px; }

/* ── Hover Preview Panel ─────────────────────────────────────────── */
.card-preview {
  position:absolute; bottom:calc(100% + 7px); left:50%;
  transform:translateX(-50%) scale(.9) translateY(10px);
  width:220px; background:var(--bg-el);
  border-radius:var(--r); overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.95), 0 0 0 1px rgba(255,255,255,.07);
  opacity:0; pointer-events:none;
  transition:opacity .25s ease, transform .25s ease; z-index:30;
}
.card:hover .card-preview { opacity:1; pointer-events:auto; transform:translateX(-50%) scale(1) translateY(0); }

/* Edge fixes */
.row .card:first-child .card-preview  { left:0; transform:scale(.9) translateY(10px); }
.row .card:first-child:hover .card-preview  { transform:scale(1) translateY(0); }
.row .card:last-child .card-preview   { left:auto; right:0; transform:scale(.9) translateY(10px); }
.row .card:last-child:hover .card-preview   { left:auto; right:0; transform:scale(1) translateY(0); }

.cp-img {
  height:110px; background-size:cover; background-position:center; position:relative;
}
.cp-gradient { position:absolute; inset:0; background:linear-gradient(to top,var(--bg-el) 0%,transparent 60%); }
.cp-body { padding:10px 12px 12px; }
.cp-title { font-size:13px; font-weight:700; line-height:1.3; margin-bottom:5px; }
.cp-meta  { display:flex; gap:7px; align-items:center; margin-bottom:7px; flex-wrap:wrap; font-size:11px; color:var(--muted); }
.cp-tv    { font-size:9px; font-weight:700; text-transform:uppercase; color:var(--blue); background:rgba(15,118,191,.15); padding:2px 5px; border-radius:3px; }
.cp-overview { font-size:11px; color:var(--muted); line-height:1.5; margin-bottom:10px; }
.cp-actions  { display:flex; gap:6px; }
.cp-play {
  flex:1; display:inline-flex; align-items:center; justify-content:center; gap:5px;
  padding:7px 10px; background:var(--accent); color:#fff;
  border-radius:var(--r); font-size:12px; font-weight:600; transition:background var(--t);
}
.cp-play:hover { background:var(--accent-h); }
.cp-info {
  width:32px; height:32px; border-radius:var(--r);
  background:rgba(255,255,255,.1); color:var(--muted);
  display:flex; align-items:center; justify-content:center; font-size:14px;
  transition:all var(--t);
}
.cp-info:hover { background:rgba(255,255,255,.2); color:#fff; }

/* Skeleton cards */
.skeleton-card .card-poster-wrap { aspect-ratio:2/3; }
.skel-poster { width:100%; height:100%; }
.skel-title  { height:12px; width:80%; border-radius:3px; margin-bottom:6px; }
.skel-sub    { height:10px; width:50%; border-radius:3px; }
.skel {
  background:linear-gradient(90deg,#191919 25%,#222 50%,#191919 75%);
  background-size:400% 100%; animation:shimmer 1.6s ease infinite;
}
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ════════════════════════════════════════════════════════════════════
   MODALS
   ════════════════════════════════════════════════════════════════════ */
.modal-overlay {
  position:fixed; inset:0; z-index:2000;
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .3s ease;
}
.modal-overlay.open { opacity:1; }
.modal-bg { position:absolute; inset:0; background:rgba(0,0,0,.88); backdrop-filter:blur(10px); }
.modal-close {
  position:absolute; top:13px; right:13px; z-index:10;
  width:34px; height:34px; border-radius:50%;
  background:rgba(0,0,0,.7); color:#fff; font-size:15px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(255,255,255,.12); transition:background var(--t);
}
.modal-close:hover { background:var(--accent); border-color:var(--accent); }
.modal-box {
  position:relative; z-index:1;
  animation:modalUp .35s ease both;
}
@keyframes modalUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:none} }

/* Trailer modal */
.trailer-box { width:min(920px,95vw); }
.trailer-wrap { aspect-ratio:16/9; border-radius:var(--rlg); overflow:hidden; box-shadow:0 40px 90px rgba(0,0,0,.9); }
.trailer-wrap iframe { width:100%; height:100%; border:none; }

/* Info modal */
#info-modal { align-items:flex-start; overflow-y:auto; padding:50px 16px 50px; }
.info-box {
  width:min(880px,100%); background:var(--bg-modal);
  border-radius:var(--rlg); overflow:hidden;
  box-shadow:0 50px 120px rgba(0,0,0,.9), 0 0 0 1px rgba(255,255,255,.06);
}
.info-hero { position:relative; height:clamp(220px,32vw,340px); overflow:hidden; }
.info-hero-img { width:100%; height:100%; object-fit:cover; object-position:center 20%; filter:brightness(.5); }
.info-hero-grad { position:absolute; inset:0; background:linear-gradient(to top, var(--bg-modal) 0%, transparent 55%); }
.info-hero-content { position:absolute; bottom:22px; left:26px; right:26px; z-index:2; }
.info-eyebrow { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.info-title {
  font-family:var(--fd); font-size:clamp(20px,4vw,42px);
  margin-bottom:8px; text-shadow:0 2px 10px rgba(0,0,0,.8);
}
.info-meta { display:flex; gap:14px; align-items:center; flex-wrap:wrap; font-size:13px; color:var(--muted); margin-bottom:14px; }
.info-actions { display:flex; gap:9px; flex-wrap:wrap; }
.info-body { padding:18px 26px 28px; }
.info-genres { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:14px; }
.info-overview { font-size:14px; color:var(--muted); line-height:1.75; margin-bottom:20px; }
.info-sec-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--dim); margin-bottom:10px; }
.cast-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(74px,1fr)); gap:10px; }
.cast-item { text-align:center; }
.cast-img { width:100%; aspect-ratio:2/3; object-fit:cover; border-radius:var(--r); margin-bottom:4px; background:#1a1a1a; }
.cast-name { font-size:11px; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cast-char { font-size:10px; color:var(--dim); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* ════════════════════════════════════════════════════════════════════
   PLAYER PAGE
   ════════════════════════════════════════════════════════════════════ */
.watch-page { padding-top:var(--nav-h); min-height:100vh; }
.player-section { background:#000; }

.pw {
  position:relative; width:100%;
  aspect-ratio:16/9; max-height:82vh; background:#000;
}
.pl-iframe { width:100%; height:100%; border:none; display:block; background:#000; }

.pl-loading {
  position:absolute; inset:0; background:#000;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px;
  z-index:10; transition:opacity .3s;
}
.pl-loading.hidden { opacity:0; pointer-events:none; }
.pl-spinner {
  width:48px; height:48px; border:3px solid rgba(255,255,255,.08);
  border-top-color:var(--accent); border-radius:50%;
  animation:spin .75s linear infinite;
}
@keyframes spin { to{transform:rotate(360deg)} }
.pl-loading-txt { color:var(--muted); font-size:13px; }

.pl-error {
  position:absolute; inset:0; background:rgba(0,0,0,.93);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px;
  z-index:10; padding:20px; text-align:center;
}
.pl-error.hidden { display:none; }
.pl-err-icon  { font-size:48px; }
.pl-err-title { font-size:19px; font-weight:700; }
.pl-err-msg   { color:var(--muted); font-size:13px; max-width:380px; }
.pl-err-btns  { display:flex; gap:10px; margin-top:6px; }
.pl-btn {
  padding:8px 18px; border-radius:var(--r);
  background:rgba(255,255,255,.1); color:#fff;
  font-size:13px; font-weight:600; border:1px solid rgba(255,255,255,.14);
  transition:background var(--t);
}
.pl-btn:hover { background:rgba(255,255,255,.18); }
.pl-btn.red   { background:var(--accent); border-color:var(--accent); }
.pl-btn.red:hover { background:var(--accent-h); }

.pl-bar {
  display:flex; align-items:center; justify-content:space-between;
  padding:7px 13px; background:rgba(0,0,0,.75); backdrop-filter:blur(8px);
  position:absolute; top:0; left:0; right:0; z-index:5;
  opacity:0; transition:opacity var(--t);
}
.pw:hover .pl-bar { opacity:1; }
.pl-bar-srv  { font-size:13px; color:var(--accent); font-weight:600; }
.pl-bar-nav  { display:flex; gap:4px; }
.pl-bar-btn  {
  width:29px; height:29px; border-radius:50%;
  background:rgba(255,255,255,.1); color:#fff; font-size:15px;
  display:flex; align-items:center; justify-content:center; transition:background var(--t);
}
.pl-bar-btn:hover { background:var(--accent); }

/* Server selector */
.srv-wrap { padding:13px var(--px); }
#server-selector { background:var(--bg-el); border-radius:var(--r); padding:13px; }
.srv-label {
  font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:1px; color:var(--muted); margin-bottom:9px;
}
.srv-list { display:flex; flex-wrap:wrap; gap:6px; }
.srv-btn {
  display:flex; align-items:center; gap:5px;
  padding:5px 12px; border-radius:18px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);
  color:var(--muted); font-size:12px; transition:all var(--t);
}
.srv-btn:hover { border-color:rgba(255,255,255,.25); color:#fff; }
.srv-btn.active { background:var(--accent); border-color:var(--accent); color:#fff; }
.srv-num {
  font-size:9px; background:rgba(255,255,255,.12);
  width:15px; height:15px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.srv-btn.active .srv-num { background:rgba(255,255,255,.22); }

/* Watch info */
.watch-info { padding:16px var(--px) 10px; }
.watch-header { display:flex; gap:18px; align-items:flex-start; margin-bottom:18px; }
.watch-poster { width:88px; flex-shrink:0; border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow); }
.watch-poster img { width:100%; aspect-ratio:2/3; object-fit:cover; }
.watch-detail { flex:1; }
.watch-title { font-family:var(--fd); font-size:clamp(20px,3.5vw,42px); margin-bottom:8px; }
.watch-meta {
  display:flex; gap:12px; align-items:center; flex-wrap:wrap;
  font-size:13px; color:var(--muted); margin-bottom:10px;
}
.watch-overview { font-size:13px; color:var(--muted); line-height:1.7; max-width:720px; }

/* Episodes */
.ep-section { padding:0 var(--px) 20px; }
.season-tabs { display:flex; gap:6px; overflow-x:auto; padding-bottom:11px; scrollbar-width:none; margin-bottom:12px; }
.season-tabs::-webkit-scrollbar { display:none; }
.s-tab {
  flex-shrink:0; padding:6px 15px; border-radius:18px;
  border:1px solid rgba(255,255,255,.13); color:var(--muted);
  font-size:12px; font-weight:500; transition:all var(--t);
}
.s-tab:hover  { color:#fff; border-color:rgba(255,255,255,.28); }
.s-tab.active { background:var(--accent); border-color:var(--accent); color:#fff; }
.ep-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); gap:7px; }
.ep-card {
  display:flex; align-items:center; gap:11px;
  background:var(--bg-el); border-radius:var(--r); padding:9px;
  cursor:pointer; border:1px solid transparent; transition:all var(--t);
}
.ep-card:hover  { border-color:rgba(255,255,255,.13); background:#1f1f1f; }
.ep-card.active { border-color:var(--accent); background:rgba(229,9,20,.07); }
.ep-thumb { width:96px; flex-shrink:0; border-radius:4px; overflow:hidden; background:#0d0d0d; }
.ep-thumb img { width:100%; aspect-ratio:16/9; object-fit:cover; }
.ep-info  { flex:1; min-width:0; }
.ep-num   { font-size:10px; color:var(--dim); margin-bottom:2px; }
.ep-name  { font-size:12px; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ep-air   { font-size:10px; color:var(--dim); margin-top:2px; }

/* ════════════════════════════════════════════════════════════════════
   SEARCH PAGE
   ════════════════════════════════════════════════════════════════════ */
.search-page { padding-top:calc(var(--nav-h) + 20px); min-height:100vh; padding-inline:var(--px); }
.search-hero { text-align:center; padding:36px 0 26px; }
.search-hero h1 { font-family:var(--fd); font-size:clamp(30px,5vw,62px); margin-bottom:20px; }
.search-wrap { max-width:600px; margin:0 auto; position:relative; }
.search-input {
  width:100%; background:var(--bg-el);
  border:1px solid rgba(255,255,255,.12); border-radius:var(--r);
  padding:13px 50px 13px 18px; color:var(--text);
  font:inherit; font-size:15px; outline:none; transition:border-color var(--t);
}
.search-input:focus { border-color:var(--accent); }
.search-input::placeholder { color:var(--dim); }
.search-icon-btn {
  position:absolute; right:12px; top:50%; transform:translateY(-50%);
  color:var(--muted); font-size:18px; display:flex; align-items:center;
  transition:color var(--t);
}
.search-icon-btn:hover { color:var(--accent); }
.filter-pills { display:flex; gap:7px; justify-content:center; margin-top:14px; flex-wrap:wrap; }

/* ════════════════════════════════════════════════════════════════════
   BROWSE PAGE (Movies / TV)
   ════════════════════════════════════════════════════════════════════ */
.page-header { padding:calc(var(--nav-h) + 26px) var(--px) 14px; }
.page-title   { font-family:var(--fd); font-size:clamp(26px,4.5vw,54px); margin-bottom:6px; }
.page-sub     { color:var(--muted); font-size:13px; }

/* Filter bar */
.filter-bar {
  display:flex; gap:8px; align-items:center; flex-wrap:wrap;
  padding:8px var(--px) 14px;
}
.filter-select {
  background:var(--bg-el); color:var(--text);
  border:1px solid rgba(255,255,255,.12); border-radius:var(--r);
  padding:7px 32px 7px 12px; font:inherit; font-size:13px; outline:none;
  cursor:pointer; transition:border-color var(--t);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='%23aaa'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 10px center;
}
.filter-select:focus { border-color:var(--accent); }

.genre-pill {
  flex-shrink:0; padding:6px 14px; border-radius:18px;
  border:1px solid rgba(255,255,255,.13); color:var(--muted);
  font-size:12px; font-weight:500; transition:all var(--t); white-space:nowrap;
}
.genre-pill:hover  { color:#fff; border-color:rgba(255,255,255,.28); }
.genre-pill.active { background:var(--accent); border-color:var(--accent); color:#fff; }

.genre-scroll {
  display:flex; gap:6px; overflow-x:auto; padding:8px var(--px);
  scrollbar-width:none;
}
.genre-scroll::-webkit-scrollbar { display:none; }

/* ════════════════════════════════════════════════════════════════════
   AD GATE
   ════════════════════════════════════════════════════════════════════ */
#ad-gate-overlay {
  position:fixed; inset:0; z-index:3000;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.94); backdrop-filter:blur(16px);
  padding:20px; opacity:0; transition:opacity .35s ease;
}
#ad-gate-overlay.visible { opacity:1; }
.ad-gate-modal {
  background:#141414; border:1px solid rgba(255,255,255,.08);
  border-radius:20px; padding:34px 30px; max-width:480px; width:100%;
  text-align:center; box-shadow:0 50px 120px rgba(0,0,0,.9);
  animation:modalUp .4s ease;
}
.ad-gate-logo { display:flex; align-items:center; justify-content:center; gap:10px; margin-bottom:4px; }
.ad-gate-favicon { width:32px; height:32px; border-radius:6px; }
.ad-logo-text { font-family:var(--fd); font-size:30px; letter-spacing:1px; }
.ad-gate-icon   { font-size:48px; margin:8px 0; }
.ad-gate-title  { font-size:19px; font-weight:700; margin-bottom:10px; }
.ad-gate-sub    { font-size:13px; color:var(--muted); line-height:1.65; margin-bottom:20px; }
.ad-gate-share  {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r); padding:14px; margin-bottom:18px;
}
.share-label   { font-size:12px; font-weight:600; color:var(--gold); margin-bottom:10px; }
.share-buttons { display:flex; gap:6px; flex-wrap:wrap; justify-content:center; }
.share-btn {
  display:inline-flex; align-items:center; gap:5px;
  padding:6px 12px; border-radius:16px;
  font-size:11px; font-weight:600; border:1px solid transparent; transition:all var(--t);
}
.share-wa { background:#25D366; color:#000; }
.share-wa:hover  { filter:brightness(1.1); transform:translateY(-1px); }
.share-tw { background:#000; color:#fff; border-color:rgba(255,255,255,.18); }
.share-tw:hover  { background:#111; transform:translateY(-1px); }
.share-fb { background:#1877F2; color:#fff; }
.share-fb:hover  { filter:brightness(1.1); transform:translateY(-1px); }
.share-cp { background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.13); }
.share-cp:hover  { background:rgba(255,255,255,.15); transform:translateY(-1px); }
.ad-gate-continue {
  width:100%; padding:12px 22px; border-radius:var(--r);
  background:#2a2a2a; color:var(--muted);
  font-size:14px; font-weight:700; transition:all var(--t); margin-bottom:9px;
}
.ad-gate-continue:disabled { cursor:not-allowed; opacity:.55; }
.ad-gate-continue.ready { background:var(--accent); color:#fff; cursor:pointer; }
.ad-gate-continue.ready:hover { background:var(--accent-h); transform:translateY(-1px); box-shadow:0 8px 28px var(--glow); }
.ag-count { color:var(--dim); font-size:12px; margin-left:4px; }
.ad-gate-note { font-size:11px; color:var(--dim); margin-bottom:12px; }
.kofi-link {
  display:inline-block; font-size:12px; color:var(--muted);
  border-bottom:1px solid rgba(255,255,255,.1); padding-bottom:1px;
  transition:color var(--t);
}
.kofi-link:hover { color:#ff5e5b; }

/* ════════════════════════════════════════════════════════════════════
   ADBLOCK WARNING
   ════════════════════════════════════════════════════════════════════ */
#adblock-warning {
  position:fixed; bottom:20px; left:50%; transform:translateX(-50%) translateY(30px);
  z-index:2500; background:#1a1a1a; border:1px solid rgba(229,9,20,.35);
  border-radius:var(--rlg); padding:16px 20px;
  max-width:500px; width:calc(100% - 32px);
  box-shadow:0 20px 60px rgba(0,0,0,.8);
  opacity:0; transition:all .4s ease;
}
#adblock-warning.visible { opacity:1; transform:translateX(-50%) translateY(0); }
.adblock-inner { display:flex; align-items:center; gap:14px; }
.adblock-icon  { font-size:28px; flex-shrink:0; }
.adblock-text  { flex:1; }
.adblock-text strong { display:block; margin-bottom:3px; }
.adblock-text p      { font-size:12px; color:var(--muted); }
.adblock-dismiss {
  padding:7px 14px; background:var(--accent); color:#fff;
  border-radius:var(--r); font-size:12px; font-weight:700;
  flex-shrink:0; transition:background var(--t);
}
.adblock-dismiss:hover { background:var(--accent-h); }

/* ════════════════════════════════════════════════════════════════════
   AUTH MODAL
   ════════════════════════════════════════════════════════════════════ */
#auth-modal .modal-box {
  width:min(420px,95vw); background:var(--bg-modal);
  border-radius:var(--rlg); padding:36px 32px; text-align:center;
}
.auth-logo { font-family:var(--fd); font-size:28px; margin-bottom:4px; }
.auth-tagline { font-size:12px; color:var(--muted); margin-bottom:24px; }
.auth-tabs { display:flex; gap:4px; background:var(--bg-el); border-radius:var(--r); padding:4px; margin-bottom:22px; }
.auth-tab {
  flex:1; padding:8px; border-radius:4px; font-size:13px; font-weight:600;
  color:var(--muted); transition:all var(--t);
}
.auth-tab.active { background:var(--accent); color:#fff; }
.auth-field {
  width:100%; background:var(--bg-el); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r); padding:11px 14px; color:var(--text);
  font:inherit; font-size:14px; outline:none; margin-bottom:10px;
  transition:border-color var(--t);
}
.auth-field:focus { border-color:var(--accent); }
.auth-submit {
  width:100%; padding:12px; background:var(--accent); color:#fff;
  border-radius:var(--r); font-size:14px; font-weight:700;
  transition:background var(--t); margin-top:4px;
}
.auth-submit:hover { background:var(--accent-h); }
.auth-err { font-size:12px; color:var(--accent); margin-top:8px; min-height:18px; }
.auth-optional { font-size:11px; color:var(--dim); margin-top:12px; }

/* ════════════════════════════════════════════════════════════════════
   TOAST
   ════════════════════════════════════════════════════════════════════ */
#toast-box {
  position:fixed; bottom:22px; right:22px; z-index:4000;
  display:flex; flex-direction:column; gap:7px; pointer-events:none;
}
.toast {
  background:#222; color:var(--text); padding:10px 16px;
  border-radius:var(--r); font-size:13px; font-weight:500;
  box-shadow:0 6px 22px rgba(0,0,0,.7); border-left:3px solid var(--accent);
  opacity:0; transform:translateX(22px); transition:all .3s ease; max-width:300px;
}
.toast.show { opacity:1; transform:translateX(0); }

/* ════════════════════════════════════════════════════════════════════
   RIPPLE
   ════════════════════════════════════════════════════════════════════ */
.ripple {
  position:absolute; border-radius:50%;
  background:rgba(255,255,255,.25); pointer-events:none;
  animation:rip .65s ease-out forwards; z-index:0;
}
@keyframes rip { from{opacity:.5;transform:scale(0)} to{opacity:0;transform:scale(1)} }

/* ════════════════════════════════════════════════════════════════════
   BACK TO TOP
   ════════════════════════════════════════════════════════════════════ */
#btt {
  position:fixed; bottom:22px; left:22px; z-index:900;
  width:40px; height:40px; border-radius:50%;
  background:var(--bg-el); border:1px solid rgba(255,255,255,.12);
  color:var(--muted); font-size:17px;
  display:flex; align-items:center; justify-content:center;
  opacity:0; transform:translateY(10px);
  transition:all var(--t); pointer-events:none; box-shadow:var(--shadow);
}
#btt.show { opacity:1; transform:translateY(0); pointer-events:auto; }
#btt:hover { background:var(--accent); color:#fff; border-color:var(--accent); }

/* ════════════════════════════════════════════════════════════════════
   PAGE HEADERS (Browse)
   ════════════════════════════════════════════════════════════════════ */
.section-hdr-gen {
  display:flex; align-items:center; justify-content:space-between;
  padding:0 var(--px); margin-bottom:10px;
}

/* ════════════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════════════ */
.site-footer {
  background:#070707; border-top:1px solid rgba(255,255,255,.05);
  padding:28px var(--px) 24px; margin-top:40px; text-align:center;
}
.footer-inner { max-width:1100px; margin:0 auto; }
.footer-logo  { font-family:var(--fd); font-size:26px; margin-bottom:6px; }
.footer-tag   { font-size:12px; color:var(--muted); margin-bottom:18px; }
.footer-links {
  display:flex; gap:16px; flex-wrap:wrap;
  justify-content:center; margin-bottom:16px;
}
.footer-links a { font-size:12px; color:var(--dim); transition:color var(--t); }
.footer-links a:hover { color:var(--text); }
.footer-kofi {
  display:inline-flex; align-items:center; gap:6px; margin-bottom:16px;
  padding:8px 18px; background:#ff5e5b; color:#fff;
  border-radius:20px; font-size:13px; font-weight:700;
  transition:filter var(--t);
}
.footer-kofi:hover { filter:brightness(1.1); }
.footer-copy { font-size:11px; color:var(--dim); }

/* ════════════════════════════════════════════════════════════════════
   404
   ════════════════════════════════════════════════════════════════════ */
.error-page {
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; padding:40px;
}
.e-code {
  font-family:var(--fd); font-size:clamp(90px,14vw,180px);
  color:var(--accent); line-height:1;
  animation:gPulse 3s ease infinite;
}
@keyframes gPulse { 0%,100%{text-shadow:0 0 60px var(--glow)} 50%{text-shadow:0 0 120px rgba(229,9,20,.6)} }
.e-title { font-size:clamp(20px,3vw,32px); font-weight:700; margin:10px 0 12px; }
.e-msg   { color:var(--muted); max-width:420px; margin-bottom:26px; line-height:1.65; }
.e-btn {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--accent); color:#fff;
  padding:12px 28px; border-radius:var(--r);
  font-size:14px; font-weight:700; transition:all var(--t);
}
.e-btn:hover { background:var(--accent-h); transform:translateY(-2px); box-shadow:0 10px 28px var(--glow); }

/* ════════════════════════════════════════════════════════════════════
   UTILITIES
   ════════════════════════════════════════════════════════════════════ */
.hidden  { display:none !important; }
.no-res  { text-align:center; padding:60px 20px; color:var(--muted); }
.no-res-icon  { font-size:50px; margin-bottom:12px; }
.no-res-title { font-size:19px; font-weight:700; margin-bottom:8px; color:var(--text); }

::-webkit-scrollbar       { width:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:#2a2a2a; border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:#444; }
::selection { background:var(--accent); color:#fff; }

/* ════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════════ */
@media (max-width:1024px) {
  :root { --cw:clamp(105px,15vw,152px); }
  .hero-content { right:26%; }
}

@media (max-width:768px) {
  :root { --cw:clamp(98px,26vw,136px); --gap:5px; }

  /* Nav mobile */
  #nav-links {
    display:none; flex-direction:column;
    position:absolute; top:var(--nav-h); left:0; right:0;
    background:rgba(10,10,10,.99); padding:12px var(--px);
    border-bottom:1px solid rgba(255,255,255,.07); gap:2px; z-index:999;
  }
  #nav-links.open { display:flex; }
  #nav-burger    { display:flex; }
  .nav-search    { display:none; }
  .nav-wl-btn    { display:none; }
  .nav-kofi      { display:none; }

  /* Hero mobile */
  .hero-content { right:10px; }
  .hero-overview { display:none; }
  .hero-title { font-size:clamp(24px,7vw,44px); }
  .hero-btn-info, .btn:nth-child(3) { display:none; }

  /* Player */
  .watch-header { flex-direction:column; }
  .watch-poster { width:76px; }
  .ep-grid { grid-template-columns:1fr; }

  /* Info modal */
  #info-modal { padding:6px; }
  .info-body  { padding:14px 16px 22px; }
  .cast-grid  { grid-template-columns:repeat(auto-fill,minmax(60px,1fr)); }

  /* No hover previews on touch */
  .card-preview { display:none; }
  .card-trailer-container { display:none; }
}

@media (max-width:480px) {
  :root { --cw:clamp(88px,29vw,118px); --gap:5px; }
  .hero { height:58vw; min-height:290px; }
  .hero-actions { gap:6px; }
  .btn { padding:9px 14px; font-size:12px; }
  .ad-gate-modal { padding:22px 16px; }
  .pw { max-height:55vw; min-height:190px; }
  #info-modal { padding:4px; }
}

@media (min-width:1440px) {
  :root { --cw:clamp(145px,10vw,192px); }
}
@media (min-width:1800px) {
  :root { --cw:clamp(158px,9.5vw,210px); }
}
