/*
Theme Name: AflamPro
Theme URI: https://aflampro.com
Author: AflamPro
Author URI: https://aflampro.com
Description: Professional Netflix-style WordPress theme — Movies, TV Shows, TMDB API, Streaming, Membership, PWA
Version: 6.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cinemapress
Tags: rtl-language-support, translation-ready, custom-menu, featured-images, threaded-comments
*/

/* ======================================================
   VARIABLES
====================================================== */
:root {
  --cp-bg:       #0a0a0f;
  --cp-bg2:      #111118;
  --cp-card:     #16161f;
  --cp-elevated: #1e1e2a;
  --cp-accent:   #e50914;
  --cp-accent2:  #f40612;
  --cp-glow:     rgba(229,9,20,0.25);
  --cp-gold:     #f5c518;
  --cp-gold-bg:  rgba(245,197,24,0.12);
  --cp-green:    #00c853;
  --cp-text:     #ffffff;
  --cp-text2:    #b3b3c6;
  --cp-muted:    #6b6b85;
  --cp-border:   rgba(255,255,255,0.06);
  --cp-border2:  rgba(255,255,255,0.12);
  --cp-r:        8px;
  --cp-rl:       16px;
  --cp-xl:       24px;
  --cp-shadow:   0 8px 40px rgba(0,0,0,0.6);
  --cp-trans:    all 0.28s cubic-bezier(0.4,0,0.2,1);
  --cp-font:     'Cairo','Outfit',sans-serif;
  --cp-display:  'Bebas Neue','Cairo',sans-serif;
  --cp-hh:       64px; /* synced with header.php --hdr-h */
}

/* ======================================================
   RESET & BASE
====================================================== */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  padding-top: 64px; /* header height — synced with --hdr-h */ background:var(--cp-bg); color:var(--cp-text); font-family:var(--cp-font);
  line-height:1.65; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; transition:var(--cp-trans); }
img { max-width:100%; display:block; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
input, select, textarea { font-family:inherit; }
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--cp-bg2); }
::-webkit-scrollbar-thumb { background:var(--cp-accent); border-radius:3px; }
.cp-no-scroll { overflow:hidden; }

/* ======================================================
   LAYOUT
====================================================== */
.cp-container { max-width:1440px; margin:0 auto; padding:0 40px; }

/* ======================================================
   HEADER
====================================================== */
#cp-header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:var(--cp-hh); display:flex; align-items:center;
  padding:0 40px; transition:var(--cp-trans);
  background:linear-gradient(to bottom,rgba(0,0,0,0.9) 0%,transparent 100%);
}
#cp-header.scrolled {
  background:rgba(10,10,15,0.97); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--cp-border); box-shadow:0 4px 30px rgba(0,0,0,0.5);
}
.cp-logo { font-family:var(--cp-display); font-size:26px; letter-spacing:2px; color:var(--cp-accent);
  text-shadow:0 0 20px var(--cp-glow); margin-inline-end:48px; flex-shrink:0; }
.cp-logo span { color:var(--cp-text); }
.cp-nav { display:flex; align-items:center; gap:4px; flex:1; }
.cp-nav a { color:var(--cp-text2); font-size:14px; font-weight:600; padding:7px 14px;
  border-radius:var(--cp-r); position:relative; }
.cp-nav a:hover, .cp-nav a.active { color:var(--cp-text); background:rgba(255,255,255,0.06); }
.cp-nav a.active::after { content:''; position:absolute; bottom:-2px; left:50%;
  transform:translateX(-50%); width:20px; height:2px; background:var(--cp-accent); border-radius:2px; }
.cp-header-right { display:flex; align-items:center; gap:10px; margin-inline-start:auto; }
.cp-icon-btn { width:40px; height:40px; border-radius:var(--cp-r); display:flex;
  align-items:center; justify-content:center; color:var(--cp-text2);
  background:rgba(255,255,255,0.05); transition:var(--cp-trans); font-size:18px; }
.cp-icon-btn:hover { background:rgba(255,255,255,0.1); color:var(--cp-text); }

/* ======================================================
   SEARCH BAR
====================================================== */
.cp-search-bar { position:fixed; top:var(--cp-hh); left:0; right:0; z-index:999;
  background:rgba(10,10,15,0.98); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--cp-border); padding:20px 40px;
  transform:translateY(-8px); opacity:0; pointer-events:none; transition:var(--cp-trans); }
.cp-search-bar.open { transform:translateY(0); opacity:1; pointer-events:all; }
.cp-search-input-wrap { position:relative; max-width:700px; margin:0 auto; }
.cp-search-input-wrap input { width:100%; padding:14px 52px 14px 20px;
  background:var(--cp-card); border:1px solid var(--cp-border2); border-radius:var(--cp-rl);
  color:var(--cp-text); font-size:16px; outline:none; transition:var(--cp-trans); }
.cp-search-input-wrap input:focus { border-color:var(--cp-accent); box-shadow:0 0 0 3px var(--cp-glow); }
#cpSearchResults { position:absolute; top:calc(100% + 8px); left:0; right:0;
  background:var(--cp-card); border:1px solid var(--cp-border2); border-radius:var(--cp-rl);
  overflow:hidden; z-index:10; box-shadow:var(--cp-shadow); display:none; }
.cp-search-item { display:flex; align-items:center; gap:12px; padding:12px 16px;
  transition:var(--cp-trans); border-bottom:1px solid var(--cp-border); }
.cp-search-item:last-child { border-bottom:none; }
.cp-search-item:hover { background:rgba(255,255,255,0.05); }
.cp-search-item img { width:44px; height:64px; object-fit:cover; border-radius:6px; flex-shrink:0; }
.cp-si-title { font-size:14px; font-weight:700; margin-bottom:2px; }
.cp-si-meta { font-size:12px; color:var(--cp-muted); }
.cp-search-all { display:block; text-align:center; padding:12px; font-size:13px; font-weight:700;
  color:var(--cp-accent); border-top:1px solid var(--cp-border); }
.cp-search-empty { text-align:center; padding:32px; color:var(--cp-muted); }
.cp-search-loading { text-align:center; padding:20px; color:var(--cp-muted); font-size:13px; }

/* ======================================================
   HERO SLIDER
====================================================== */
.cp-hero { position:relative; height:88vh; min-height:550px; overflow:hidden; }
.cp-hero-slide { position:absolute; inset:0; opacity:0; transition:opacity 1.2s ease; }
.cp-hero-slide.active { opacity:1; }
.cp-hero-bg { width:100%; height:100%; object-fit:cover; object-position:center center; display:block; }
.cp-hero-overlay { position:absolute; inset:0;
  background:
    linear-gradient(to right,rgba(5,5,8,.96) 0%,rgba(5,5,8,.65) 45%,rgba(5,5,8,.12) 75%,transparent 100%),
    linear-gradient(to top,rgba(5,5,8,1) 0%,rgba(5,5,8,.55) 28%,transparent 55%); }
.cp-hero-content { position:absolute; bottom:14%; inset-inline-start:60px; max-width:580px; z-index:2; }
.cp-hero-badges { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.cp-badge { display:inline-flex; align-items:center; gap:5px; padding:4px 12px;
  border-radius:4px; font-size:11px; font-weight:800; letter-spacing:0.5px; text-transform:uppercase; }
.cp-badge-type { background:var(--cp-accent); color:#fff; }
.cp-badge-rating { background:var(--cp-gold-bg); color:var(--cp-gold); border:1px solid rgba(245,197,24,0.3); }
.cp-badge-year { background:rgba(255,255,255,0.1); color:var(--cp-text2); }
.cp-badge-quality { background:rgba(0,200,83,0.15); color:var(--cp-green); border:1px solid rgba(0,200,83,0.3); }
.cp-hero-title { font-size:clamp(34px,5vw,62px); font-weight:900; line-height:1.05; margin-bottom:14px;
  text-shadow:0 2px 20px rgba(0,0,0,0.5); }
.cp-hero-desc { font-size:15px; color:var(--cp-text2); line-height:1.75; margin-bottom:28px;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.cp-hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.cp-hero-nav { position:absolute; bottom:36px; inset-inline-end:60px; display:flex; gap:8px; z-index:3; }
.cp-hero-dot { width:8px; height:8px; border-radius:4px; background:rgba(255,255,255,0.3); transition:var(--cp-trans); cursor:pointer; }
.cp-hero-dot.active { width:28px; background:var(--cp-accent); }
.cp-hero-arrows { position:absolute; top:50%; transform:translateY(-50%); width:100%;
  display:flex; justify-content:space-between; padding:0 20px; z-index:3; pointer-events:none; }
.cp-hero-arrow { width:48px; height:48px; border-radius:50%; background:rgba(255,255,255,0.08);
  backdrop-filter:blur(10px); border:1px solid var(--cp-border2); display:flex; align-items:center;
  justify-content:center; font-size:22px; pointer-events:all; transition:var(--cp-trans); }
.cp-hero-arrow:hover { background:var(--cp-accent); border-color:var(--cp-accent); }

/* ======================================================
   BUTTONS
====================================================== */
.cp-btn { display:inline-flex; align-items:center; gap:8px; padding:12px 24px;
  border-radius:var(--cp-r); font-size:14px; font-weight:700; transition:var(--cp-trans); white-space:nowrap; }
.cp-btn-lg { padding:15px 32px; font-size:16px; }
.cp-btn-primary { background:var(--cp-accent); color:#fff; box-shadow:0 4px 20px var(--cp-glow); }
.cp-btn-primary:hover { background:var(--cp-accent2); transform:translateY(-2px); box-shadow:0 8px 30px var(--cp-glow); }
.cp-btn-secondary { background:rgba(255,255,255,0.1); color:var(--cp-text); border:1px solid var(--cp-border2); backdrop-filter:blur(10px); }
.cp-btn-secondary:hover { background:rgba(255,255,255,0.18); transform:translateY(-1px); }
.cp-btn-gold { background:var(--cp-gold-bg); color:var(--cp-gold); border:1px solid rgba(245,197,24,0.3); }
.cp-btn-gold:hover { background:rgba(245,197,24,0.2); }

/* ======================================================
   SECTIONS
====================================================== */
.cp-section { padding:44px 0; }
.cp-section-header { display:flex; align-items:center; justify-content:space-between;
  margin-bottom:20px; padding:0 40px; }
.cp-section-title { font-size:20px; font-weight:800; display:flex; align-items:center; gap:10px; }
.cp-section-title::before { content:''; width:4px; height:20px; background:var(--cp-accent); border-radius:2px; }
.cp-section-heading { font-size:18px; font-weight:800; margin-bottom:16px; display:flex; align-items:center; gap:8px; }
.cp-section-heading::before { content:''; width:3px; height:18px; background:var(--cp-accent); border-radius:2px; }
.cp-section-more { font-size:12px; font-weight:700; color:var(--cp-accent); display:flex; align-items:center; gap:4px;
  padding:6px 14px; border-radius:var(--cp-r); border:1px solid rgba(229,9,20,0.25); transition:var(--cp-trans); }
.cp-section-more:hover { background:rgba(229,9,20,0.1); }

/* ======================================================
   HORIZONTAL ROW
====================================================== */
.cp-row { padding:0 40px 8px; overflow-x:auto; scrollbar-width:none; display:flex; gap:16px; scroll-snap-type:x mandatory; }
.cp-row::-webkit-scrollbar { display:none; }

/* ======================================================
   MOVIE CARDS
====================================================== */
.cp-card { flex:0 0 175px; width:175px; scroll-snap-align:start; position:relative;
  border-radius:var(--cp-rl); overflow:hidden; background:var(--cp-card); transition:var(--cp-trans); cursor:pointer; }
.cp-card:hover { transform:translateY(-6px) scale(1.03); box-shadow:0 20px 50px rgba(0,0,0,0.7),0 0 0 1px rgba(229,9,20,0.4); z-index:10; }
/* Single full-card link */
.cp-card-link { display:block; text-decoration:none; position:relative; }
.cp-card-poster { width:100%; aspect-ratio:2/3; object-fit:cover; transition:transform 0.4s ease; display:block; }
.cp-card-no-img { width:100%; aspect-ratio:2/3; background:var(--cp-card); display:flex; align-items:center; justify-content:center; font-size:40px; }
.cp-card:hover .cp-card-poster { transform:scale(1.07); }
/* Badges */
.cp-card-quality { position:absolute; top:8px; inset-inline-start:8px; padding:2px 7px;
  border-radius:4px; font-size:10px; font-weight:800; letter-spacing:.5px; background:rgba(0,180,70,0.92); color:#fff; z-index:3; pointer-events:none; }
.cp-card-locked { position:absolute; top:8px; inset-inline-end:8px; padding:2px 7px;
  border-radius:4px; font-size:10px; font-weight:800; background:rgba(229,9,20,0.9); color:#fff; z-index:3; pointer-events:none; }
.cp-card-checked { position:absolute; top:8px; inset-inline-end:8px; width:22px; height:22px; border-radius:50%;
  background:var(--cp-accent); color:#fff; font-size:12px; display:flex; align-items:center; justify-content:center; z-index:3; pointer-events:none; }
/* Wishlist btn */
.cp-card-wishlist { position:absolute; bottom:50px; inset-inline-end:8px; z-index:4;
  width:28px; height:28px; border-radius:50%; background:rgba(0,0,0,0.75); border:none;
  display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:700;
  color:#fff; cursor:pointer; transition:var(--cp-trans); opacity:0; }
.cp-card:hover .cp-card-wishlist { opacity:1; }
.cp-card-wishlist:hover, .cp-card-wishlist.in-list { background:var(--cp-accent); }
/* Hover overlay */
.cp-card-overlay { position:absolute; inset:0;
  background:linear-gradient(to top,rgba(0,0,0,1) 0%,rgba(0,0,0,.5) 40%,transparent 70%);
  opacity:0; transition:opacity 0.3s ease; display:flex; flex-direction:column;
  justify-content:flex-end; padding:10px; pointer-events:none; }
.cp-card-link:hover .cp-card-overlay { opacity:1; }
.cp-card-play-icon { width:40px; height:40px; border-radius:50%; background:var(--cp-accent);
  display:flex; align-items:center; justify-content:center; font-size:16px;
  margin:0 auto 12px; box-shadow:0 4px 20px rgba(229,9,20,.5); transition:transform .2s; flex-shrink:0; }
.cp-card-link:hover .cp-card-play-icon { transform:scale(1.15); }
.cp-card-info { }
.cp-card-title { font-size:12px; font-weight:700; margin-bottom:4px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; color:#fff; }
.cp-card-meta { display:flex; align-items:center; gap:6px; font-size:10px; color:rgba(255,255,255,.7); flex-wrap:wrap; }
.cp-card-genre { color:rgba(255,255,255,.6); text-decoration:none; }
.cp-card-genre:hover { color:var(--cp-accent); }
.cp-card-year  { color:rgba(255,255,255,.5); text-decoration:none; }
.cp-card-year:hover  { color:var(--cp-accent); }
.cp-card-star { color:var(--cp-gold); font-weight:700; }

/* Grid layout for browse pages */
.cp-movies-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:16px; padding:0 24px; }
.cp-movies-grid .cp-card { flex:none; width:100%; }

/* ======================================================
   TOP 10 CARDS
====================================================== */
.cp-top10-card { flex:0 0 190px; position:relative; display:flex; align-items:flex-end; }
.cp-top10-number { position:absolute; bottom:-12px; inset-inline-start:-12px; font-size:90px;
  font-family:var(--cp-display); font-weight:900; line-height:1; color:transparent;
  -webkit-text-stroke:3px var(--cp-muted); z-index:0; user-select:none; }
.cp-top10-card .cp-card { z-index:1; }

/* ======================================================
   FILTER PILLS
====================================================== */
.cp-filter-wrap { display:flex; gap:8px; padding:0 40px; margin-bottom:28px;
  overflow-x:auto; scrollbar-width:none; }
.cp-filter-wrap::-webkit-scrollbar { display:none; }
.cp-filter-btn { flex-shrink:0; padding:8px 18px; border-radius:100px; font-size:13px; font-weight:600;
  color:var(--cp-text2); background:var(--cp-card); border:1px solid var(--cp-border); transition:var(--cp-trans); }
.cp-filter-btn:hover, .cp-filter-btn.active { background:var(--cp-accent); border-color:var(--cp-accent);
  color:#fff; box-shadow:0 4px 15px var(--cp-glow); }
.cp-filter-select { padding:9px 16px; background:var(--cp-card); border:1px solid var(--cp-border);
  border-radius:var(--cp-r); color:var(--cp-text); font-size:13px; cursor:pointer; }

/* ======================================================
   MOVIE/SHOW DETAIL PAGE
====================================================== */
.cp-movie-hero { position:relative; min-height:75vh; display:flex; align-items:flex-end; padding-bottom:56px; }
.cp-movie-backdrop { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:top; }
.cp-movie-backdrop-overlay { position:absolute; inset:0;
  background:linear-gradient(to right,rgba(10,10,15,0.98) 0%,rgba(10,10,15,0.8) 48%,rgba(10,10,15,0.3) 100%),
  linear-gradient(to top,rgba(10,10,15,1) 0%,rgba(10,10,15,0.6) 28%,transparent 55%); }
.cp-movie-detail { position:relative; z-index:2; display:grid;
  grid-template-columns:260px 1fr; gap:48px; padding:0 60px; width:100%; }
.cp-movie-poster-wrap img { width:100%; border-radius:var(--cp-rl); box-shadow:0 20px 60px rgba(0,0,0,0.7); }
.cp-tagline { font-size:14px; color:var(--cp-accent); font-style:italic; margin-bottom:8px; }
.cp-movie-info-title { font-size:clamp(28px,4vw,52px); font-weight:900; margin-bottom:14px; line-height:1.05; }
.cp-movie-meta-row { display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:18px; font-size:14px; }
.cp-imdb-rating { display:flex; align-items:center; gap:6px; background:var(--cp-gold-bg);
  border:1px solid rgba(245,197,24,0.3); padding:6px 14px; border-radius:var(--cp-r); font-weight:700; color:var(--cp-gold); }
.cp-imdb-rating small { opacity:0.6; font-size:11px; }
.cp-mpaa { padding:3px 10px; border-radius:4px; font-size:11px; font-weight:800;
  background:rgba(255,255,255,0.1); border:1px solid var(--cp-border2); }
.cp-genres { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:18px; }
.cp-genre-tag { padding:5px 14px; border-radius:100px; font-size:12px; font-weight:600;
  background:rgba(255,255,255,0.07); border:1px solid var(--cp-border2); color:var(--cp-text2); transition:var(--cp-trans); }
.cp-genre-tag:hover { background:rgba(229,9,20,0.12); border-color:rgba(229,9,20,0.3); color:var(--cp-text); }
.cp-movie-overview { font-size:15px; color:var(--cp-text2); line-height:1.8; margin-bottom:22px; }
.cp-detail-row { display:flex; align-items:center; gap:10px; margin-bottom:8px; font-size:14px; }
.cp-detail-label { font-size:11px; text-transform:uppercase; letter-spacing:0.5px; color:var(--cp-muted); font-weight:700; min-width:80px; }
.cp-status-badge { padding:4px 12px; border-radius:4px; font-size:12px; font-weight:700; }
.cp-status-badge.ongoing { background:rgba(0,200,83,0.1); color:var(--cp-green); border:1px solid rgba(0,200,83,0.3); }
.cp-status-badge.ended { background:rgba(255,82,82,0.1); color:#ff5252; border:1px solid rgba(255,82,82,0.3); }
.cp-ongoing-badge { position:absolute; top:12px; left:12px; background:rgba(0,200,83,0.9);
  color:#fff; padding:4px 10px; border-radius:4px; font-size:11px; font-weight:800; }
.cp-network-badge { text-align:center; margin-top:10px; font-size:12px; color:var(--cp-text2);
  background:var(--cp-elevated); padding:6px 12px; border-radius:var(--cp-r); }
.cp-action-btns { display:flex; gap:10px; flex-wrap:wrap; margin-top:16px; }

/* ======================================================
   USER RATING WIDGET
====================================================== */
.cp-user-rating-widget { margin:16px 0; }
.cp-url-label { font-size:12px; text-transform:uppercase; letter-spacing:0.5px; color:var(--cp-muted); font-weight:700; margin-bottom:8px; }
.cp-stars { display:flex; gap:4px; margin-bottom:8px; }
.cp-star { font-size:22px; color:var(--cp-muted); transition:var(--cp-trans); cursor:pointer; background:none; border:none; }
.cp-star.active, .cp-star.hover { color:var(--cp-gold); transform:scale(1.15); }
.cp-url-stats { font-size:12px; color:var(--cp-text2); }

/* ======================================================
   SEASONS PREVIEW (On Detail Page)
====================================================== */
.cp-seasons-preview { display:flex; gap:8px; flex-wrap:wrap; margin:16px 0; }
.cp-sp-item { text-align:center; padding:6px 12px; background:var(--cp-elevated);
  border-radius:var(--cp-r); border:1px solid var(--cp-border); }
.cp-sp-num { font-size:13px; font-weight:800; color:var(--cp-text); }
.cp-sp-eps { font-size:10px; color:var(--cp-muted); }
.cp-sp-more { color:var(--cp-accent); }

/* ======================================================
   CAST
====================================================== */
.cp-cast-item { flex-shrink:0; text-align:center; width:80px; }
.cp-cast-photo { width:64px; height:64px; border-radius:50%; object-fit:cover;
  border:2px solid var(--cp-border2); margin:0 auto 6px; transition:var(--cp-trans); }
.cp-cast-item:hover .cp-cast-photo { border-color:var(--cp-accent); transform:scale(1.05); }
.cp-cast-name { font-size:11px; font-weight:700; text-align:center; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis; }
.cp-cast-char { font-size:10px; color:var(--cp-muted); text-align:center;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* ======================================================
   WATCH / PLAYER PAGE
====================================================== */
.cp-watch-page { padding-top:calc(var(--cp-hh) + 20px); min-height:100vh; }
.cp-breadcrumb { font-size:12px; color:var(--cp-muted); margin-bottom:16px; }
.cp-breadcrumb a { color:var(--cp-muted); }
.cp-breadcrumb a:hover { color:var(--cp-accent); }
.cp-player-wrap { position:relative; background:#000; border-radius:var(--cp-rl);
  overflow:hidden; box-shadow:0 16px 50px rgba(0,0,0,0.7); }
.cp-player-wrap iframe, .cp-player-wrap video { width:100%; aspect-ratio:16/9; display:block; border:none; }
.cp-player-placeholder { aspect-ratio:16/9; display:flex; align-items:center; justify-content:center;
  background:#050508; color:var(--cp-muted); text-align:center; }
.cp-current-ep-bar { display:flex; align-items:center; gap:14px; padding:16px 0;
  border-bottom:1px solid var(--cp-border); margin-bottom:20px; flex-wrap:wrap; }
.cp-episode-server-panel { background:var(--cp-card); border:1px solid var(--cp-border);
  border-radius:var(--cp-rl); padding:20px; margin-bottom:16px; }
.cp-resume-banner { background:var(--cp-elevated); border:1px solid var(--cp-border2);
  border-radius:var(--cp-r); padding:12px 18px; display:flex; align-items:center; gap:12px;
  margin:10px 0; font-size:13px; }
.cp-resume-banner button { padding:6px 14px; border-radius:6px; font-size:12px; font-weight:700; cursor:pointer; }
#cpResumeBtn { background:var(--cp-accent); color:#fff; border:none; }
.cp-dismiss { background:none; border:none; color:var(--cp-muted); font-size:16px; cursor:pointer; margin-inline-start:auto; }

/* ======================================================
   SERVERS
====================================================== */
.cp-servers-grid { display:flex; gap:8px; flex-wrap:wrap; }
.cp-server-btn { display:flex; align-items:center; gap:8px; padding:10px 18px;
  border-radius:var(--cp-r); background:var(--cp-card); border:1px solid var(--cp-border);
  color:var(--cp-text2); font-size:13px; font-weight:600; transition:var(--cp-trans); }
.cp-server-btn:hover { border-color:var(--cp-accent); color:var(--cp-text); background:rgba(229,9,20,0.06); }
.cp-server-btn.active { border-color:var(--cp-accent); background:rgba(229,9,20,0.1); color:var(--cp-text); box-shadow:0 0 0 1px var(--cp-accent); }
.server-quality { padding:2px 6px; border-radius:3px; font-size:10px; font-weight:800;
  background:rgba(0,200,83,0.15); color:var(--cp-green); }

/* ======================================================
   EPISODES
====================================================== */
.cp-episodes-section { padding:28px 0; }
.cp-seasons-tabs { display:flex; gap:6px; overflow-x:auto; scrollbar-width:none; margin-bottom:20px; padding-bottom:4px; }
.cp-seasons-tabs::-webkit-scrollbar { display:none; }
.cp-season-tab { flex-shrink:0; display:flex; align-items:center; gap:6px; padding:9px 18px;
  border-radius:100px; font-size:13px; font-weight:700; color:var(--cp-text2);
  background:var(--cp-card); border:1px solid var(--cp-border); transition:var(--cp-trans); cursor:pointer; }
.cp-season-tab:hover { border-color:var(--cp-accent); color:var(--cp-text); }
.cp-season-tab.active { background:var(--cp-accent); border-color:var(--cp-accent); color:#fff; }
.cp-st-count { font-size:10px; opacity:0.7; }
.cp-specials-tab { border-style:dashed; }

.cp-episodes-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:14px; }
.cp-episode-card { display:flex; gap:12px; padding:12px; background:var(--cp-card);
  border-radius:var(--cp-r); border:1px solid var(--cp-border); transition:var(--cp-trans); cursor:pointer; }
.cp-episode-card:hover { border-color:rgba(229,9,20,0.4); background:var(--cp-elevated); }
.cp-episode-card.playing { border-color:var(--cp-accent); background:rgba(229,9,20,0.06); box-shadow:0 0 0 1px var(--cp-accent); }
.cp-episode-card.watched { opacity:0.7; }
.cp-ep-thumb { width:110px; flex-shrink:0; border-radius:6px; overflow:hidden;
  position:relative; aspect-ratio:16/9; background:var(--cp-elevated); }
.cp-ep-thumb img { width:100%; height:100%; object-fit:cover; }
.cp-ep-play-icon { position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,0.4); color:#fff; font-size:20px; opacity:0; transition:var(--cp-trans); }
.cp-episode-card:hover .cp-ep-play-icon { opacity:1; }
.cp-ep-no-thumb { width:100%; height:100%; background:var(--cp-elevated); }
.cp-ep-watched-badge { position:absolute; bottom:4px; right:4px; background:rgba(0,200,83,0.9);
  color:#fff; font-size:9px; font-weight:800; padding:2px 6px; border-radius:3px; }
.cp-ep-info { flex:1; min-width:0; }
.cp-ep-number { font-size:11px; color:var(--cp-muted); margin-bottom:3px; }
.cp-ep-title { font-size:13px; font-weight:700; margin-bottom:4px; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis; }
.cp-ep-overview { font-size:12px; color:var(--cp-muted); line-height:1.5;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.cp-ep-meta { display:flex; align-items:center; gap:8px; margin-top:6px; font-size:11px; color:var(--cp-muted); flex-wrap:wrap; }
.cp-ep-servers-count { color:var(--cp-green); }
.cp-ep-loading { text-align:center; padding:40px; color:var(--cp-muted); font-size:14px; }

/* Seasons Overview Cards */
.cp-seasons-overview { padding:0 40px; }
.cp-season-overview-card { flex-shrink:0; width:140px; cursor:pointer; transition:var(--cp-trans); }
.cp-season-overview-card:hover { transform:translateY(-4px); }

/* ======================================================
   DOWNLOADS
====================================================== */
.cp-downloads-section { padding:28px 0; }
.cp-download-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:10px; }
.cp-download-btn { display:flex; align-items:center; gap:10px; padding:14px 16px;
  background:var(--cp-card); border-radius:var(--cp-r); border:1px solid var(--cp-border);
  color:var(--cp-text2); transition:var(--cp-trans); }
.cp-download-btn:hover { border-color:rgba(0,200,83,0.4); color:var(--cp-green); background:rgba(0,200,83,0.04); }
.cp-dl-icon { width:36px; height:36px; border-radius:var(--cp-r); background:rgba(0,200,83,0.1);
  display:flex; align-items:center; justify-content:center; font-size:18px; color:var(--cp-green); flex-shrink:0; }

/* ======================================================
   PAYWALL / MEMBERSHIP
====================================================== */
.cp-paywall { text-align:center; padding:60px 40px; }
.cp-paywall-icon { font-size:56px; margin-bottom:16px; }
.cp-paywall h2 { font-size:28px; font-weight:900; margin-bottom:12px; }
.cp-paywall p { color:var(--cp-text2); font-size:15px; margin-bottom:40px; }
.cp-plans-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; max-width:900px; margin:0 auto; text-align:left; }
.cp-plan-card { background:var(--cp-card); border:2px solid var(--cp-border); border-radius:var(--cp-rl);
  padding:24px; transition:var(--cp-trans); }
.cp-plan-card:hover { transform:translateY(-4px); box-shadow:var(--cp-shadow); }
.cp-plan-name { font-size:14px; font-weight:800; text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }
.cp-plan-price { font-size:36px; font-weight:900; font-family:var(--cp-display); }
.cp-plan-price span { font-size:14px; color:var(--cp-muted); }
.cp-plan-features { list-style:none; margin:16px 0 20px; }
.cp-plan-features li { font-size:13px; color:var(--cp-text2); padding:4px 0; }

/* ======================================================
   MODAL
====================================================== */
.cp-modal-overlay { display:flex; align-items:center; justify-content:center; }
.cp-modal { background:var(--cp-card); border:1px solid var(--cp-border2); border-radius:var(--cp-xl);
  padding:28px; width:90%; max-width:440px; box-shadow:var(--cp-shadow); }
.cp-modal h3 { font-size:18px; font-weight:800; margin-bottom:16px; }

/* ======================================================
   LOADING
====================================================== */
.cp-shimmer { background:linear-gradient(90deg,var(--cp-card) 25%,var(--cp-elevated) 50%,var(--cp-card) 75%);
  background-size:200% 100%; animation:shimmer 1.5s infinite; border-radius:var(--cp-r); }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.cp-loading-dots span { display:inline-block; width:8px; height:8px; border-radius:50%;
  background:var(--cp-accent); margin:0 3px; animation:bounce 1.2s infinite; }
.cp-loading-dots span:nth-child(2){animation-delay:.2s} .cp-loading-dots span:nth-child(3){animation-delay:.4s}
@keyframes bounce { 0%,80%,100%{transform:scale(0)} 40%{transform:scale(1)} }

/* ======================================================
   TOAST
====================================================== */
.cp-toast-wrap { position:fixed; bottom:24px; inset-inline-end:24px; z-index:9999;
  display:flex; flex-direction:column; gap:8px; }
.cp-toast { display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:12px 18px; background:var(--cp-elevated); border-radius:var(--cp-r);
  border-inline-start:3px solid var(--cp-accent); font-size:14px; box-shadow:var(--cp-shadow);
  animation:toastIn 0.3s ease; min-width:240px; }
.cp-toast-success { border-color:var(--cp-green); }
.cp-toast-warning { border-color:var(--cp-gold); }
.cp-toast-error { border-color:#ff5252; }
.cp-toast button { color:var(--cp-muted); font-size:16px; padding:0 4px; }
.cp-toast.fade-out { opacity:0; transform:translateX(8px); transition:all 0.3s ease; }
@keyframes toastIn { from{transform:translateX(100%);opacity:0} to{transform:translateX(0);opacity:1} }

/* ======================================================
   MOBILE DRAWER
====================================================== */
.cp-mobile-drawer { position:fixed; top:0; inset-inline-end:-280px; width:280px; height:100%;
  background:var(--cp-bg2); z-index:1001; transition:var(--cp-trans); border-inline-start:1px solid var(--cp-border); }
.cp-mobile-drawer.open { inset-inline-end:0; }
.cp-mobile-drawer-inner { padding:24px; }
.cp-mobile-logo { font-family:var(--cp-display); font-size:24px; color:var(--cp-accent);
  letter-spacing:2px; margin-bottom:24px; }
.cp-mobile-nav { display:flex; flex-direction:column; gap:4px; }
.cp-mobile-nav a { padding:12px 16px; border-radius:var(--cp-r); color:var(--cp-text2); font-weight:600; }
.cp-mobile-nav a:hover { background:rgba(255,255,255,0.06); color:var(--cp-text); }
.cp-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.7); z-index:1000;
  opacity:0; pointer-events:none; transition:opacity 0.3s; }
.cp-overlay.active { opacity:1; pointer-events:all; }
.cp-mobile-menu-btn { display:none; flex-direction:column; gap:5px; width:36px; height:36px;
  align-items:center; justify-content:center; }
.cp-mobile-menu-btn span { display:block; width:22px; height:2px; background:var(--cp-text2);
  border-radius:2px; transition:var(--cp-trans); }
.cp-mobile-menu-btn.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.cp-mobile-menu-btn.open span:nth-child(2){opacity:0}
.cp-mobile-menu-btn.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ======================================================
   FOOTER
====================================================== */
#cp-footer { background:var(--cp-bg2); border-top:1px solid var(--cp-border);
  padding:60px 40px 32px; margin-top:80px; }
.cp-footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.cp-footer-logo { font-family:var(--cp-display); font-size:30px; color:var(--cp-accent); margin-bottom:14px; letter-spacing:2px; }
.cp-footer-desc { font-size:14px; color:var(--cp-muted); line-height:1.8; max-width:300px; }
.cp-footer-title { font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:1.5px;
  color:var(--cp-text2); margin-bottom:18px; }
.cp-footer-links { list-style:none; }
.cp-footer-links li { margin-bottom:10px; }
.cp-footer-links a { color:var(--cp-muted); font-size:14px; transition:var(--cp-trans); }
.cp-footer-links a:hover { color:var(--cp-accent); padding-inline-start:4px; }
.cp-social-link { width:38px; height:38px; border-radius:var(--cp-r); background:rgba(255,255,255,0.06);
  display:inline-flex; align-items:center; justify-content:center; color:var(--cp-text2); transition:var(--cp-trans); }
.cp-social-link:hover { background:var(--cp-accent); color:#fff; }
.cp-footer-bottom { border-top:1px solid var(--cp-border); padding-top:24px; display:flex;
  align-items:center; justify-content:space-between; font-size:13px; color:var(--cp-muted); flex-wrap:wrap; gap:12px; }

/* ======================================================
   ANIMATIONS
====================================================== */
@keyframes fadeInUp { from{opacity:0;transform:translateY(32px)} to{opacity:1;transform:translateY(0)} }
.cp-animate-up { animation:fadeInUp 0.7s ease forwards; }

/* ======================================================
   RESPONSIVE — FULL MOBILE-FIRST FIX
====================================================== */

/* ── 1100px: Large tablet / small desktop ── */
@media (max-width:1100px) {
  .cp-movie-detail  { grid-template-columns:200px 1fr; gap:32px; }
  .cp-footer-grid   { grid-template-columns:1fr 1fr; gap:32px; }
  .cp-container     { padding:0 28px; }
  .cp-section-header,.cp-row,.cp-filter-wrap,.cp-movies-grid,
  .cp-seasons-overview,.cp-paywall { padding-inline:28px; }
}

/* ── 900px: Tablet ── */
@media (max-width:900px) {
  :root { --cp-hh: 60px; }

  /* Header */
  #cp-header            { padding:0 16px; gap:10px; }
  .cp-nav               { display:none; }
  .cp-mobile-menu-btn   { display:flex; }
  .cp-header-actions    { gap:8px; }
  .cp-points-badge      { display:none; } /* hide on tablet, show in drawer */

  /* Hero */
  .cp-hero              { height:72vw; min-height:300px; max-height:520px; }
  .cp-hero-content      { inset-inline-start:16px; inset-inline-end:16px;
                          max-width:none; bottom:12%; }
  .cp-hero-title        { font-size:clamp(32px,9vw,60px); }
  .cp-hero-desc         { -webkit-line-clamp:2; font-size:13px; }
  .cp-hero-meta         { font-size:12px; gap:8px; }
  .cp-hero-actions      { gap:8px; flex-wrap:wrap; }
  .cp-hero-dots         { bottom:10px; inset-inline-start:16px; }

  /* Layout containers */
  .cp-container,
  .cp-section-header,
  .cp-filter-wrap,
  .cp-movies-grid,
  .cp-seasons-overview,
  .cp-paywall               { padding-inline:16px; }
  .cp-row                   { padding:0 16px 8px; gap:10px; }

  /* Cards */
  .cp-card                  { flex:0 0 140px; width:140px; }
  .cp-card-poster           { height:210px; }

  /* Movie / TV detail */
  .cp-movie-detail          { grid-template-columns:1fr; gap:0; padding:0 16px; }
  .cp-movie-poster-wrap     { display:flex; justify-content:center; margin-bottom:20px; }
  .cp-movie-poster-wrap img { width:160px; border-radius:12px; }
  .cp-movie-info            { padding-top:0; }
  .cp-movie-title           { font-size:clamp(28px,7vw,48px); }
  .cp-movie-actions         { gap:8px; flex-wrap:wrap; }

  /* Footer */
  .cp-footer-grid           { grid-template-columns:1fr 1fr; gap:24px; }
  #cp-footer                { padding:40px 16px 24px; margin-top:48px; }
}

/* ── 600px: Mobile ── */
@media (max-width:600px) {
  :root { --cp-hh: 54px; }

  /* Hero */
  .cp-hero                { height:78vw; min-height:260px; max-height:420px; }
  .cp-hero-title          { font-size:clamp(28px,10vw,48px); line-height:.95; }
  .cp-hero-content        { bottom:10%; }
  .cp-hero-desc           { display:none; } /* hide description on small phones */

  /* Cards */
  .cp-card                { flex:0 0 120px; width:120px; }
  .cp-card-poster         { height:180px; }
  .cp-card-title          { font-size:11px; }

  /* Grids */
  .cp-movies-grid         { grid-template-columns:repeat(2,1fr); gap:10px; }
  .cp-episodes-grid       { grid-template-columns:1fr; }
  .cp-plans-grid          { grid-template-columns:1fr; }
  .cp-download-grid       { grid-template-columns:1fr; }
  .cp-footer-grid         { grid-template-columns:1fr; }
  .cp-section-header      { flex-wrap:wrap; gap:8px; }

  /* Movie detail poster */
  .cp-movie-poster-wrap img { width:130px; }
  .cp-movie-title         { font-size:clamp(24px,8vw,40px); }

  /* Tabs */
  .cp-tabs-nav            { padding:0 4px; gap:2px; }
  .cp-tab-btn             { padding:10px 12px; font-size:12px; }

  /* Season cards */
  .cp-season-overview-card { width:110px; }

  /* Paywall */
  .cp-paywall             { padding:32px 16px; }
  .cp-plan-card           { padding:20px 16px; }

  /* Person page */
  .cp-person-header       { flex-direction:column; align-items:center; text-align:center; }
  .cp-person-photo        { margin-bottom:16px; }

  /* Footer */
  #cp-footer              { padding:28px 16px 20px; }
  .cp-footer-grid         { gap:20px; }
  .cp-footer-title        { margin-bottom:10px; }

  /* Modal */
  .cp-modal-inner         { width:96%; padding:20px 14px; }
  .cp-rating-modal        { width:96%; }

  /* Toast */
  .cp-toast               { min-width:unset; width:calc(100vw - 32px); left:16px; right:16px; bottom:16px; }

  /* Watch party chat */
  .cp-party-chat          { height:140px; }

  /* Resume banner */
  .cp-resume-banner       { flex-direction:column; align-items:flex-start; gap:8px; padding:10px 14px; }

  /* Breadcrumb — hide on mobile */
  .cp-breadcrumb          { display:none; }
}

/* ── 400px: Very small phones ── */
@media (max-width:400px) {
  .cp-hero-actions .cp-btn + .cp-btn { display:none; } /* show only play button */
  .cp-movies-grid { grid-template-columns:repeat(2,1fr); gap:8px; }
  .cp-card        { flex:0 0 110px; width:110px; }
  .cp-card-poster { height:165px; }
}

/* ======================================================
   RESPONSIVE HELPER CLASSES (used in PHP templates)
====================================================== */
:root { --cp-px: 16px; }
@media (min-width:600px)  { :root { --cp-px: 24px; } }
@media (min-width:900px)  { :root { --cp-px: 40px; } }
@media (min-width:1100px) { :root { --cp-px: 60px; } }

.cp-stats-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.cp-two-col    { display:grid; grid-template-columns:1fr; gap:16px; }
.cp-person-header { display:grid; grid-template-columns:1fr; gap:24px; text-align:center; }
.cp-person-photo  { width:160px; height:160px; margin:0 auto; border-radius:50%; object-fit:cover; }

@media (min-width:600px) {
  .cp-stats-grid   { grid-template-columns:repeat(4,1fr); gap:16px; }
  .cp-two-col      { grid-template-columns:1fr 1fr; gap:20px; }
}
@media (min-width:900px) {
  .cp-two-col        { gap:24px; }
  .cp-person-header  { grid-template-columns:240px 1fr; text-align:start; }
  .cp-person-photo   { width:240px; height:360px; border-radius:12px; }
}


====================================================== */
[dir="rtl"] .cp-hero-overlay {
  background:linear-gradient(to left,rgba(10,10,15,0.97) 0%,rgba(10,10,15,0.65) 45%,rgba(10,10,15,0.1) 75%,transparent 100%),
  linear-gradient(to top,rgba(10,10,15,1) 0%,rgba(10,10,15,0.6) 25%,transparent 55%);
}
[dir="rtl"] .cp-toast { border-inline-start:none; border-inline-end:3px solid var(--cp-accent); }

/* ======================================================
   v4 DESIGN OVERRIDES — topcinema.fan style
====================================================== */

/* Body background */
body {
  background: #050508; } /* padding-top managed globally above */

/* Header: v4 overrides now minimal — layout handled by .hdr-inner */
#cp-header {
    background: rgba(5,5,8,.97);
}
#cp-header.scrolled {
    background: rgba(5,5,8,.99);
    box-shadow: 0 1px 0 rgba(255,255,255,.05), 0 8px 32px rgba(0,0,0,.5);
}
.cp-logo { margin-inline-end: 36px; }
.cp-nav { gap: 2px; }
.cp-nav a {
    font-size: 13.5px; font-weight: 700;
    padding: 6px 13px; border-radius: 7px;
    color: rgba(255,255,255,.6);
}
.cp-nav a:hover, .cp-nav a.active { color: #fff; background: rgba(255,255,255,.07); }
.cp-nav a.active::after { display: none; }

/* Cards: more refined */
.cp-card {
    flex: 0 0 160px; width: 160px;
    background: #13131a;
    border-radius: 10px;
    box-shadow: 0 4px 16px rgba(0,0,0,.4);
}
.cp-card:hover {
    transform: translateY(-6px) scale(1.02);
    box-shadow: 0 16px 40px rgba(0,0,0,.6), 0 0 0 1px rgba(229,9,20,.35);
}
.cp-card-poster { border-radius: 10px 10px 0 0; }
.cp-card-quality {
    border-radius: 5px;
    font-size: 9px; font-weight: 900;
    letter-spacing: .6px;
}
.cp-card-overlay {
    border-radius: 0 0 10px 10px;
    background: linear-gradient(to top, rgba(0,0,0,1) 0%, rgba(0,0,0,.6) 40%, transparent 75%);
}
.cp-card-play-icon {
    width: 36px; height: 36px; font-size: 14px;
    box-shadow: 0 4px 16px rgba(229,9,20,.5);
}
.cp-card-title { font-size: 11.5px; }

/* Sections: tighter */
.cp-section { padding: 36px 0 8px; }
.cp-section-header { padding: 0 40px; margin-bottom: 16px; }
.cp-section-title {
    font-size: 17px; font-weight: 900; gap: 10px;
}
.cp-section-title::before {
    width: 4px; height: 18px;
    border-radius: 3px;
    box-shadow: 0 0 8px rgba(229,9,20,.5);
}
.cp-row { padding: 0 40px 10px; gap: 12px; }
.cp-section-more {
    font-size: 11px; padding: 5px 12px;
    border-radius: 6px;
}

/* Search items */
.cp-search-item img { border-radius: 6px; }
.cp-si-title { font-weight: 800; }

/* Footer fix */
#cp-footer { margin-top: 64px; }

/* Scrollbar */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-thumb { background: #e50914; border-radius: 2px; }

/* Mobile fix */
@media (max-width: 900px) {
    .cp-section-header, .cp-row { padding-inline: 14px; }
    .cp-card { flex: 0 0 130px; width: 130px; }
}
@media (max-width: 600px) {
    .cp-card { flex: 0 0 116px; width: 116px; }
    .cp-section { padding: 24px 0 4px; }
}

/* ══════════════════════════════════════════════
   AflamPro — Detail Pages (arabseed style)
══════════════════════════════════════════════ */

/* ── Hero backdrop ── */
/* ════════════════════════════════════════════════════════════
   CINEMATIC MOVIE / TV SHOW PAGE — AflamPro
   Full-bleed backdrop · glassmorphism panels · rich typography
   ════════════════════════════════════════════════════════════ */

/* ── Cinematic Hero ── */
.v5-hero {
  position: fixed;
  inset: 0;
  z-index: 0;
  height: 100vh;
  pointer-events: none;
}
.v5-hero-bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 25%;
  filter: brightness(.28) saturate(1.15);
  transform: scale(1.03);
}
.v5-hero-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(to top,  #080a14 0%, #080a14e0 30%, #080a1490 60%, transparent 100%),
    linear-gradient(to right, #080a14 0%, #080a14cc 25%, transparent 60%),
    linear-gradient(to bottom, #080a14cc 0%, transparent 20%);
}

/* ── صفحات الأفلام/مسلسلات: الجسم بدون padding ── */
body.single-cp_movie,
body.single-cp_tvshow,
body.single.postid-cp_movie,
body.posttype-cp_movie,
body.posttype-cp_tvshow {
  padding-top: 0 !important;
  background: #080a14 !important;
}

/* ── Page root: يبدأ من أعلى الشاشة ── */
.v5-page-root {
  position: relative;
  z-index: 2;
  min-height: 100vh;
  /* لا padding — المحتوى يعلو من خلف الهيدر */
}

/* ── Wrap / container ── */
.v5-wrap {
  max-width: 1260px;
  margin: 0 auto;
  padding: 0 32px 80px;
  position: relative;
  z-index: 2;
}

/* ── Breadcrumb ── */
.v5-breadcrumb {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; color: rgba(255,255,255,.35);
  margin-bottom: 36px; flex-wrap: wrap;
}
.v5-breadcrumb a { color: rgba(255,255,255,.4); transition: .2s; }
.v5-breadcrumb a:hover { color: var(--cp-accent); }
.v5-breadcrumb span { color: rgba(255,255,255,.2); }

/* ══════════════════════════════════════
   TOP SECTION: poster + info
   ══════════════════════════════════════ */
.v5-top {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 44px;
  align-items: start;
  margin-bottom: 40px;
}

/* ── Poster column ── */
.v5-poster-col { display: flex; flex-direction: column; gap: 14px; }
.v5-poster-wrap {
  position: relative; border-radius: 14px; overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,.85), 0 0 0 1px rgba(255,255,255,.07);
}
.v5-poster-img { width: 100%; aspect-ratio: 2/3; object-fit: cover; display: block; }
.v5-poster-placeholder {
  width: 100%; aspect-ratio: 2/3;
  background: rgba(255,255,255,.04);
  display: flex; align-items: center; justify-content: center;
  font-size: 60px;
}
.v5-poster-quality {
  position: absolute; top: 10px; right: 10px;
  padding: 4px 11px; border-radius: 5px;
  font-size: 10px; font-weight: 900; letter-spacing: 1px;
  background: rgba(0,180,70,.88); color: #fff;
  backdrop-filter: blur(6px);
  box-shadow: 0 2px 8px rgba(0,0,0,.4);
}
.v5-poster-ongoing {
  position: absolute; top: 10px; left: 10px;
  padding: 4px 11px; border-radius: 5px;
  font-size: 10px; font-weight: 800;
  background: rgba(229,9,20,.9); color: #fff;
}

/* ── Sidebar buttons ── */
.v5-sidebar-btns { display: flex; flex-direction: column; gap: 9px; }
.v5-btn {
  display: flex; align-items: center; justify-content: center;
  gap: 9px; padding: 12px 18px; border-radius: 10px;
  font-size: 14px; font-weight: 800; font-family: var(--cp-font);
  cursor: pointer; transition: all .22s; border: none; text-align: center;
  white-space: nowrap; letter-spacing: .3px;
}
.v5-btn-play {
  background: linear-gradient(135deg, #e50914, #c8070f);
  color: #fff;
  box-shadow: 0 6px 24px rgba(229,9,20,.45), 0 2px 8px rgba(0,0,0,.3);
}
.v5-btn-play:hover { transform: translateY(-2px); box-shadow: 0 10px 32px rgba(229,9,20,.55); }
.v5-btn-dl {
  background: rgba(0,200,83,.1); color: #00c853;
  border: 1px solid rgba(0,200,83,.22);
}
.v5-btn-dl:hover { background: rgba(0,200,83,.18); transform: translateY(-1px); }
.v5-btn-trailer {
  background: rgba(245,197,24,.08); color: #f5c518;
  border: 1px solid rgba(245,197,24,.18);
}
.v5-btn-trailer:hover { background: rgba(245,197,24,.14); }
.v5-btn-list {
  background: rgba(255,255,255,.05); color: rgba(255,255,255,.6);
  border: 1px solid rgba(255,255,255,.1);
}
.v5-btn-list:hover, .v5-btn-list.active {
  background: rgba(229,9,20,.1); color: #e50914;
  border-color: rgba(229,9,20,.3);
}

/* ── Info column ── */
.v5-info-col {
  display: flex; flex-direction: column; gap: 22px;
  padding-top: 6px;
}

/* Type badge + title */
.v5-title-block {}
.v5-type-badge {
  display: inline-block; padding: 4px 14px; border-radius: 5px;
  font-size: 11px; font-weight: 900; letter-spacing: 1px;
  background: var(--cp-accent); color: #fff; margin-bottom: 12px;
  text-transform: uppercase;
}
.v5-type-series { background: #0a6eb5; }
.v5-title {
  font-size: clamp(26px, 3.2vw, 48px); font-weight: 900;
  line-height: 1.08; margin-bottom: 8px;
  color: #fff;
  text-shadow: 0 2px 30px rgba(0,0,0,.5);
  letter-spacing: -.5px;
}
.v5-tagline {
  font-size: 14px; color: rgba(255,255,255,.45);
  font-style: italic; letter-spacing: .2px;
}

/* Rating block */
.v5-rating-block {}
.v5-imdb-score { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.v5-score-num { font-size: 30px; font-weight: 900; color: #f5c518; line-height: 1; }
.v5-score-max { font-size: 14px; color: rgba(255,255,255,.3); }
.v5-vote-count { font-size: 11px; color: rgba(255,255,255,.35); }
.v5-score-bar {
  height: 3px; background: rgba(255,255,255,.08);
  border-radius: 2px; overflow: hidden; max-width: 200px;
}
.v5-score-fill {
  height: 100%;
  background: linear-gradient(to right, #f5c518, #e5940a);
  border-radius: 2px; transition: width 1.2s cubic-bezier(.4,0,.2,1);
}

/* ── Info table — glassmorphism ── */
.v5-info-table {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px; overflow: hidden;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}
.v5-info-row {
  display: grid; grid-template-columns: 110px 1fr;
  padding: 11px 18px; gap: 14px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  align-items: center; transition: background .15s;
}
.v5-info-row:last-child { border-bottom: none; }
.v5-info-row:hover { background: rgba(255,255,255,.03); }
.v5-info-label {
  font-size: 10px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 1px; color: rgba(255,255,255,.3);
}
.v5-info-val {
  font-size: 13px; color: rgba(255,255,255,.75);
  display: flex; flex-wrap: wrap; gap: 5px; align-items: center;
}
.v5-tag {
  display: inline-block; padding: 3px 11px; border-radius: 100px;
  font-size: 11px; font-weight: 700;
  background: rgba(229,9,20,.12); color: #e50914;
  border: 1px solid rgba(229,9,20,.22); transition: .2s;
}
.v5-tag:hover { background: rgba(229,9,20,.22); color: #ff3040; }
.v5-quality-badge {
  padding: 3px 10px; border-radius: 5px;
  font-size: 11px; font-weight: 900; letter-spacing: .5px;
  background: rgba(0,200,83,.12); color: #00c853;
  border: 1px solid rgba(0,200,83,.2);
}
.v5-views { color: rgba(255,255,255,.5); }
.v5-imdb-link {
  color: #f5c518; font-size: 12px;
  display: inline-flex; align-items: center; gap: 4px;
  font-weight: 700;
}
.v5-imdb-link:hover { text-decoration: underline; }
.v5-status-on  { color: #e50914; font-weight: 800; }
.v5-status-off { color: #00c853; font-weight: 800; }

/* ── Overview ── */
.v5-overview-block {}
.v5-overview {
  font-size: 14.5px; line-height: 1.85; color: rgba(255,255,255,.65);
  max-height: 88px; overflow: hidden; transition: max-height .45s ease;
  position: relative;
}
.v5-overview::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 40px;
  background: linear-gradient(to top, #080a14, transparent);
  transition: opacity .3s;
}
.v5-overview.v5-expanded { max-height: 1000px; }
.v5-overview.v5-expanded::after { opacity: 0; }
.v5-read-more {
  background: none; border: none; color: #e50914;
  font-size: 12px; font-weight: 800; cursor: pointer;
  margin-top: 8px; display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--cp-font); letter-spacing: .3px;
  transition: color .15s;
}
.v5-read-more:hover { color: #ff3040; }

/* Mobile buttons (hidden on desktop) */
.v5-mobile-btns { display: none; gap: 8px; flex-wrap: wrap; }

/* ══════════════════════════════════════
   CONTENT BLOCKS (cast, similar, etc.)
   ══════════════════════════════════════ */
.v5-block {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px; padding: 26px;
  margin-bottom: 22px;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  transition: border-color .2s;
}
.v5-block:hover { border-color: rgba(255,255,255,.11); }
.v5-block-title {
  display: flex; align-items: center; gap: 10px;
  font-size: 16px; font-weight: 900; margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  color: #fff;
}
.v5-block-title::before {
  content: '';
  display: block; width: 3px; height: 18px;
  background: var(--cp-accent); border-radius: 2px;
  flex-shrink: 0;
}

/* ── Cast grid ── */
.v5-cast-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(82px, 1fr));
  gap: 14px;
}
.v5-cast-card {
  text-align: center; cursor: pointer;
  transition: transform .22s; text-decoration: none;
}
.v5-cast-card:hover { transform: translateY(-5px); }
.v5-cast-photo {
  width: 72px; height: 72px; border-radius: 50%;
  overflow: hidden; margin: 0 auto 8px;
  background: rgba(255,255,255,.06);
  border: 2px solid rgba(255,255,255,.08);
  transition: border-color .2s;
  display: flex; align-items: center; justify-content: center;
}
.v5-cast-card:hover .v5-cast-photo { border-color: var(--cp-accent); }
.v5-cast-photo img { width: 100%; height: 100%; object-fit: cover; }
.v5-cast-no-img { font-size: 28px; color: rgba(255,255,255,.25); }
.v5-cast-name {
  font-size: 11.5px; font-weight: 700; color: rgba(255,255,255,.85);
  margin-bottom: 2px; white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis;
}
.v5-cast-char {
  font-size: 10px; color: rgba(255,255,255,.35);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

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

/* ── Network wrap ── */
.v5-network-wrap {
  text-align: center;
  background: rgba(255,255,255,.04); border-radius: 10px;
  padding: 9px 14px; font-size: 12px; font-weight: 700;
  color: rgba(255,255,255,.5); border: 1px solid rgba(255,255,255,.07);
}

/* ── Live badge ── */
.v5-live-badge {
  position: absolute; top: 20px; right: 20px;
  background: rgba(229,9,20,.9); color: #fff;
  padding: 5px 14px; border-radius: 4px;
  font-size: 12px; font-weight: 800;
  z-index: 2; animation: pulse 2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.6} }

/* ── Season tabs (TV) ── */
.v5-season-tabs {
  display: flex; gap: 6px; flex-wrap: wrap;
  margin-bottom: 16px;
}
.v5-season-tab {
  padding: 7px 18px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px; color: rgba(255,255,255,.6);
  font-size: 13px; font-weight: 700; cursor: pointer; transition: .2s;
}
.v5-season-tab:hover { background: rgba(255,255,255,.1); color: #fff; }
.v5-season-tab.active {
  background: var(--cp-accent); border-color: var(--cp-accent);
  color: #fff; box-shadow: 0 4px 16px rgba(229,9,20,.35);
}

/* ─── RESPONSIVE ─── */
@media (max-width: 900px) {
  .v5-wrap { padding: 0 18px 50px; }
  .v5-top  { grid-template-columns: 180px 1fr; gap: 24px; }
  .v5-title { font-size: clamp(20px, 5vw, 32px); }
  .v5-info-row { grid-template-columns: 90px 1fr; }
  .v5-cast-grid { grid-template-columns: repeat(auto-fill, minmax(70px,1fr)); }
}
@media (max-width: 640px) {
  .v5-wrap { padding: 0 12px 40px; }
  .v5-top  { grid-template-columns: 1fr; gap: 0; }
  .v5-poster-col {
    flex-direction: row; align-items: flex-start;
    gap: 14px; margin-bottom: 20px;
  }
  .v5-poster-wrap { width: 110px; flex-shrink: 0; }
  .v5-sidebar-btns { display: none; }
  .v5-mobile-btns  { display: flex; }
  .v5-info-row  { grid-template-columns: 78px 1fr; padding: 9px 12px; }
  .v5-block     { padding: 16px; }
  .v5-cast-grid { grid-template-columns: repeat(auto-fill, minmax(64px,1fr)); gap: 10px; }
  .v5-cast-photo { width: 58px; height: 58px; }
  .v5-season-tabs { gap: 4px; }
  .v5-season-tab  { padding: 6px 12px; font-size: 12px; }
}
@media (max-width: 400px) {
  .v5-info-row { grid-template-columns: 68px 1fr; }
}

/* ── Utility ── */
.v5-eps-loaded { display: grid; }
.v5-network-name {
  font-size: 12px; font-weight: 700;
  color: rgba(255,255,255,.5);
}

/* ── Watchlist button (used across pages) ── */
.cp-watchlist-btn { cursor: pointer; transition: all .2s; }
.cp-watchlist-btn.active { color: var(--cp-accent) !important; border-color: rgba(229,9,20,.4) !important; }

/* ── Loading dots ── */
.cp-loading-dots {
  display: inline-flex; gap: 6px; align-items: center;
}
.cp-loading-dots span {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--cp-accent); opacity: .4;
  animation: cpDot .9s ease-in-out infinite;
}
.cp-loading-dots span:nth-child(2) { animation-delay: .2s; }
.cp-loading-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes cpDot { 0%,100%{opacity:.2;transform:scale(.8)} 50%{opacity:1;transform:scale(1)} }

/* ── IMDb icon link ── */
.v5-imdb-icon-link {
    display: inline-flex;
    align-items: center;
    opacity: .9;
    transition: opacity .2s, transform .2s;
}
.v5-imdb-icon-link:hover { opacity: 1; transform: scale(1.08); }
.v5-imdb-icon-link svg { display: block; }

/* ── Cinematic pages: body background ── */
body.single-cp_movie,
body.single-cp_tvshow {
  background: #080a14 !important;
}
body.single-cp_movie .cp-body,
body.single-cp_tvshow .cp-body {
  background: transparent;
}
/* Footer على صفحات الأفلام — يجب أن يظهر فوق الـ hero */
body.single-cp_movie footer,
body.single-cp_tvshow footer,
body.single-cp_movie #colophon,
body.single-cp_tvshow #colophon {
  position: relative; z-index: 3;
  background: #080a14;
}
