/*
Theme Name: Netstream Download
Theme URI: https://netstream.local
Author: Netstream Team
Author URI: https://netstream.local
Description: Advanced OTT Download Redirect Theme with TMDB Integration. Cinematic dark design with multi-step download flow, countdown redirect, and full WordPress admin controls.
Version: 3.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: netstream-download
Tags: entertainment, dark, ott, streaming, movie, download
*/

/* ── RESET & BASE ──────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:#0d0d0f;
  color:#e8e8ec;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:#6ab3ff;text-decoration:none}
a:hover{text-decoration:underline}

/* ── CSS VARIABLES ─────────────────────────────────────────── */
:root{
  --red:#e50914;
  --red-dk:#b0060f;
  --red-glow:rgba(229,9,20,.3);
  --red-glow-soft:rgba(229,9,20,.12);
  --bg:#0d0d0f;
  --bg2:#111114;
  --card:#141417;
  --card2:#1a1a1f;
  --card3:#202028;
  --border:#2a2a30;
  --border2:#333340;
  --border3:#3d3d4a;
  --text:#e8e8ec;
  --text2:#b0b0bc;
  --muted:#6c6c7a;
  --link:#6ab3ff;
  --gold:#f5c518;
  --green:#22c55e;
  --blue:#3b82f6;
  --purple:#a855f7;
  --orange:#f97316;
  --cyan:#06b6d4;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 8px 40px rgba(0,0,0,.65);
  --shadow-lg:0 16px 60px rgba(0,0,0,.8);
  --transition:0.2s cubic-bezier(0.4,0,0.2,1);
  --transition-slow:0.35s cubic-bezier(0.4,0,0.2,1);
}

/* ── TYPOGRAPHY ────────────────────────────────────────────── */
h1{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;line-height:1.15;letter-spacing:-.02em}
h2{font-size:clamp(1.2rem,3vw,1.8rem);font-weight:800;line-height:1.2;letter-spacing:-.01em}
h3{font-size:1.1rem;font-weight:700}
p{line-height:1.65;color:var(--text2)}

/* ── SITE WRAPPER ──────────────────────────────────────────── */
#ns-wrap{min-height:100vh;display:flex;flex-direction:column}
#ns-main{flex:1;padding:32px 0 80px}
.ns-container{width:100%;max-width:940px;margin:0 auto;padding:0 20px}

/* ── HEADER ────────────────────────────────────────────────── */
#ns-header{
  background:rgba(13,13,15,.97);
  border-bottom:1px solid var(--border);
  padding:0 20px;
  position:sticky;top:0;z-index:100;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  will-change:transform;
}
.ns-header-inner{
  max-width:940px;margin:0 auto;
  height:62px;
  display:flex;align-items:center;justify-content:space-between;
}
.ns-logo{
  font-size:20px;font-weight:900;letter-spacing:-.03em;
  color:var(--text);
  display:flex;align-items:center;gap:9px;
}
.ns-logo span{color:var(--red)}
.ns-logo svg{width:28px;height:28px}
.ns-header-right{font-size:12px;color:var(--muted)}

/* ── FOOTER ────────────────────────────────────────────────── */
#ns-footer{
  background:var(--bg2);
  border-top:1px solid var(--border);
  padding:22px 20px;
  text-align:center;
  font-size:12px;
  color:var(--muted);
}
#ns-footer a{color:var(--muted);transition:color var(--transition)}
#ns-footer a:hover{color:var(--text);text-decoration:none}

/* ── MOVIE HERO CARD ────────────────────────────────────────── */
.ns-movie-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  position:relative;
  box-shadow:var(--shadow-lg);
  animation:ns-fade-up .5s cubic-bezier(0.4,0,0.2,1) both;
}
@keyframes ns-fade-up{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}
.ns-movie-backdrop{
  position:absolute;inset:0;
  background-size:cover;background-position:center 20%;
  opacity:.14;
  pointer-events:none;
  transition:opacity .4s ease;
}
.ns-movie-backdrop::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,var(--card) 28%,rgba(20,20,23,.7) 60%,transparent 100%);
}
.ns-movie-backdrop::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,var(--card) 100%);
}
.ns-movie-inner{
  position:relative;z-index:1;
  display:flex;gap:28px;align-items:flex-start;
  padding:30px;
}
.ns-poster-wrap{flex-shrink:0;position:relative}
.ns-poster{
  width:140px;height:204px;
  border-radius:12px;
  object-fit:cover;
  box-shadow:0 12px 40px rgba(0,0,0,.8);
  transition:transform var(--transition-slow),box-shadow var(--transition-slow);
  will-change:transform;
}
.ns-poster:hover{
  transform:scale(1.03) translateY(-2px);
  box-shadow:0 20px 50px rgba(0,0,0,.9);
}
.ns-quality-badge{
  position:absolute;bottom:10px;right:10px;
  background:rgba(0,0,0,.88);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  font-size:10px;font-weight:800;letter-spacing:.06em;
  padding:3px 8px;border-radius:6px;
  backdrop-filter:blur(8px);
}
.ns-movie-details{flex:1;min-width:0}
.ns-movie-title{
  font-size:clamp(1.3rem,3.5vw,2rem);font-weight:800;
  margin-bottom:12px;line-height:1.1;
  letter-spacing:-.02em;
}
.ns-movie-meta{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px 12px;
  margin-bottom:14px;font-size:13px;color:var(--muted);
}
.ns-meta-sep{opacity:.3}
.ns-movie-tagline{
  font-size:13px;color:var(--muted);
  font-style:italic;margin-bottom:12px;
  opacity:.75;
}
.ns-movie-desc{
  font-size:14px;line-height:1.65;color:var(--text2);
  margin-bottom:20px;
  max-height:84px;overflow:hidden;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;
}
.ns-movie-extra{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;
}
.ns-tag{
  font-size:11px;font-weight:600;
  background:var(--card2);border:1px solid var(--border2);
  color:var(--text2);padding:4px 11px;border-radius:20px;
  transition:border-color var(--transition),color var(--transition);
}
.ns-tag:hover{border-color:var(--border3);color:var(--text)}

/* ── ACTION BUTTONS ────────────────────────────────────────── */
.ns-action-btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:4px}
.ns-btn{
  display:inline-flex;align-items:center;gap:8px;
  border-radius:10px;padding:12px 24px;
  font-size:14px;font-weight:700;font-family:inherit;
  cursor:pointer;border:none;
  transition:background var(--transition),transform 0.1s,box-shadow var(--transition),opacity var(--transition);
  white-space:nowrap;
  will-change:transform;
  position:relative;
  overflow:hidden;
  -webkit-tap-highlight-color:transparent;
}
.ns-btn::after{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(circle at center,rgba(255,255,255,.15) 0%,transparent 70%);
  opacity:0;
  transition:opacity .2s;
  pointer-events:none;
}
.ns-btn:active{transform:scale(.96);transition:transform .08s}
.ns-btn:active::after{opacity:1}
.ns-btn-primary{
  background:var(--red);color:#fff;
  box-shadow:0 4px 16px var(--red-glow-soft);
}
.ns-btn-primary:hover{
  background:var(--red-dk);
  box-shadow:0 6px 28px var(--red-glow);
  transform:translateY(-1px);
}
.ns-btn-secondary{
  background:var(--card2);color:var(--text);
  border:1px solid var(--border2);
}
.ns-btn-secondary:hover{
  background:var(--card3);
  border-color:var(--border3);
  transform:translateY(-1px);
}
.ns-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* ── QUALITY BUTTONS GRID ──────────────────────────────────── */
.ns-quality-grid{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-bottom:4px;
}
.ns-quality-btn{
  display:inline-flex;align-items:center;gap:6px;
  border-radius:10px;padding:9px 16px;
  font-size:13px;font-weight:700;font-family:inherit;
  cursor:pointer;border:none;
  transition:all var(--transition);
  white-space:nowrap;
  position:relative;overflow:hidden;
  -webkit-tap-highlight-color:transparent;
  will-change:transform;
}
.ns-quality-btn:active{transform:scale(.95)}
/* Quality color coding */
.ns-quality-btn[data-tier="4k"]{
  background:linear-gradient(135deg,#7c3aed,#4f46e5);
  color:#fff;
  box-shadow:0 4px 16px rgba(124,58,237,.3);
}
.ns-quality-btn[data-tier="4k"]:hover{
  box-shadow:0 6px 28px rgba(124,58,237,.5);
  transform:translateY(-1px);
}
.ns-quality-btn[data-tier="fhd"]{
  background:linear-gradient(135deg,#0ea5e9,#2563eb);
  color:#fff;
  box-shadow:0 4px 16px rgba(14,165,233,.3);
}
.ns-quality-btn[data-tier="fhd"]:hover{
  box-shadow:0 6px 28px rgba(14,165,233,.5);
  transform:translateY(-1px);
}
.ns-quality-btn[data-tier="hd"]{
  background:linear-gradient(135deg,#22c55e,#16a34a);
  color:#fff;
  box-shadow:0 4px 16px rgba(34,197,94,.3);
}
.ns-quality-btn[data-tier="hd"]:hover{
  box-shadow:0 6px 28px rgba(34,197,94,.5);
  transform:translateY(-1px);
}
.ns-quality-btn[data-tier="sd"]{
  background:var(--card2);color:var(--text);
  border:1px solid var(--border2);
}
.ns-quality-btn[data-tier="sd"]:hover{
  background:var(--card3);border-color:var(--border3);
  transform:translateY(-1px);
}
.ns-quality-btn[data-tier="cam"]{
  background:var(--card2);color:var(--muted);
  border:1px solid var(--border);
}
.ns-quality-meta{
  font-size:10px;font-weight:500;opacity:.8;
  display:flex;flex-direction:column;line-height:1.2;
  text-align:left;
}
.ns-quality-meta .ql-label{font-weight:800;font-size:13px;opacity:1}
.ns-quality-meta .ql-size{font-size:10px;opacity:.7}
.ns-quality-meta .ql-format{font-size:9px;opacity:.55}
.ns-quality-icon{font-size:16px;line-height:1}

/* ── ARROW CONNECTOR ───────────────────────────────────────── */
.ns-arrow-connector{
  display:flex;justify-content:center;align-items:center;
  padding:22px 0;
  opacity:0;
  transform:scaleY(.5);
  transition:opacity .4s,transform .4s cubic-bezier(0.34,1.56,0.64,1);
}
.ns-arrow-connector.ns-visible{
  opacity:1;
  transform:scaleY(1);
}
/* First arrow always visible */
#nsd-arrow-1{opacity:1;transform:scaleY(1)}
.ns-arrow-connector svg{
  animation:ns-bounce .9s ease-in-out infinite alternate;
  filter:drop-shadow(0 0 8px rgba(229,9,20,.5));
}
@keyframes ns-bounce{from{transform:translateY(-2px)}to{transform:translateY(8px)}}

/* ── STEP CARDS ────────────────────────────────────────────── */
.ns-step-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:52px 36px;
  text-align:center;
  box-shadow:var(--shadow-lg);
  transition:opacity .35s,transform .35s cubic-bezier(0.34,1.2,0.64,1);
}
.ns-step-card.ns-entering{
  animation:ns-step-in .4s cubic-bezier(0.34,1.2,0.64,1) both;
}
@keyframes ns-step-in{
  from{opacity:0;transform:translateY(20px) scale(.97)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.ns-step-label{
  font-size:11px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--red);
  margin-bottom:22px;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.ns-step-label::before,.ns-step-label::after{
  content:'';display:inline-block;
  width:32px;height:1px;background:var(--red);opacity:.4;
}
.ns-step-icon{
  width:80px;height:80px;
  background:var(--card2);
  border:1px solid var(--border2);
  border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:22px;
  box-shadow:0 0 0 8px rgba(229,9,20,.05);
  animation:ns-pulse-icon 2.5s ease-in-out infinite;
}
@keyframes ns-pulse-icon{
  0%,100%{box-shadow:0 0 0 8px rgba(229,9,20,.05)}
  50%{box-shadow:0 0 0 14px rgba(229,9,20,.1)}
}
.ns-step-card h2{font-size:1.5rem;margin-bottom:10px;letter-spacing:-.01em}
.ns-step-card p{font-size:14px;color:var(--muted);margin-bottom:26px}

/* ── TIMER ─────────────────────────────────────────────────── */
.ns-timer-wrap{position:relative;width:100px;height:100px;margin:0 auto 24px}
.ns-timer-wrap svg{position:absolute;inset:0;transform:rotate(-90deg)}
.ns-timer-track{fill:none;stroke:var(--border2);stroke-width:5.5}
.ns-timer-arc{
  fill:none;stroke:var(--red);stroke-width:5.5;stroke-linecap:round;
  stroke-dasharray:263.9;stroke-dashoffset:0;
  transition:stroke-dashoffset .95s linear;
  filter:drop-shadow(0 0 6px rgba(229,9,20,.6));
}
.ns-timer-num{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-size:34px;font-weight:900;line-height:1;
}
.ns-manual-link{font-size:13px;color:var(--muted);margin-top:10px}
.ns-manual-link a{color:var(--link);transition:color var(--transition)}
.ns-manual-link a:hover{color:var(--text);text-decoration:none}

/* ── INFO STRIP ────────────────────────────────────────────── */
.ns-info-strip{
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:14px 18px;
  margin-top:22px;
  display:flex;flex-wrap:wrap;gap:14px 20px;
  align-items:center;
  font-size:12px;color:var(--muted);
}
.ns-info-strip span{display:flex;align-items:center;gap:6px}
.ns-info-strip strong{color:var(--text2);font-weight:600}

/* ── CAST ROW ──────────────────────────────────────────────── */
.ns-cast-section{margin-top:28px}
.ns-cast-section h3{
  font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);margin-bottom:12px;
}
.ns-cast-grid{display:flex;flex-wrap:wrap;gap:6px}
.ns-cast-chip{
  font-size:12px;font-weight:500;
  background:var(--card2);border:1px solid var(--border);
  color:var(--text2);padding:5px 12px;border-radius:20px;
  transition:border-color var(--transition),color var(--transition);
}
.ns-cast-chip:hover{border-color:var(--border3);color:var(--text)}

/* ── RATINGS ROW ───────────────────────────────────────────── */
.ns-ratings-row{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px;
}
.ns-rating-box{
  background:var(--card2);border:1px solid var(--border2);
  border-radius:10px;padding:10px 16px;text-align:center;
  transition:border-color var(--transition),transform var(--transition);
}
.ns-rating-box:hover{border-color:var(--border3);transform:translateY(-1px)}
.ns-rating-box .val{font-size:18px;font-weight:800;line-height:1}
.ns-rating-box .lbl{font-size:10px;color:var(--muted);margin-top:3px;text-transform:uppercase;letter-spacing:.07em}
.ns-rating-box.gold{border-color:rgba(245,197,24,.2)}
.ns-rating-box.gold .val{color:var(--gold)}
.ns-rating-box.red{border-color:rgba(229,9,20,.2)}
.ns-rating-box.red .val{color:var(--red)}
.ns-rating-box.green .val{color:var(--green)}

/* ── ALERT BOX ─────────────────────────────────────────────── */
.ns-alert{
  border-radius:10px;padding:14px 18px;
  font-size:13px;font-weight:500;margin-bottom:16px;
  border-left:3px solid;
  animation:ns-fade-up .3s ease both;
}
.ns-alert-error{background:rgba(229,9,20,.08);border-color:var(--red);color:#ff8888}
.ns-alert-info{background:rgba(106,179,255,.08);border-color:var(--link);color:#8ecfff}
.ns-alert-success{background:rgba(34,197,94,.08);border-color:var(--green);color:#6eefaa}

/* ── AD ZONE ───────────────────────────────────────────────── */
.ns-ad-zone{
  background:var(--card2);
  border:1px dashed var(--border2);
  border-radius:10px;
  padding:16px;
  min-height:90px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 28px;
  max-width:728px;
}

/* ── UTILITY ───────────────────────────────────────────────── */
.ns-hidden{display:none!important;visibility:hidden;pointer-events:none}
.ns-center{text-align:center}
.ns-mt16{margin-top:16px}
.ns-mt24{margin-top:24px}
.ns-spinner{
  display:inline-block;
  width:18px;height:18px;border-radius:50%;
  border:2px solid rgba(255,255,255,.25);
  border-top-color:#fff;
  animation:ns-spin .65s linear infinite;
  vertical-align:middle;
}
@keyframes ns-spin{to{transform:rotate(360deg)}}

/* ── PROGRESS INDICATOR ────────────────────────────────────── */
.ns-progress-bar{
  width:100%;height:3px;
  background:var(--border);
  border-radius:99px;
  margin-bottom:32px;
  overflow:hidden;
}
.ns-progress-fill{
  height:100%;background:var(--red);
  border-radius:99px;
  transition:width .4s cubic-bezier(0.4,0,0.2,1);
}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media(max-width:640px){
  .ns-movie-inner{flex-direction:column;align-items:center;text-align:center;padding:22px 18px}
  .ns-poster-wrap{width:100%;display:flex;justify-content:center}
  .ns-poster{width:150px;height:218px}
  .ns-movie-meta,.ns-ratings-row{justify-content:center}
  .ns-action-btns,.ns-quality-grid{justify-content:center}
  .ns-step-card{padding:38px 18px}
  .ns-movie-extra{justify-content:center}
  .ns-cast-grid{justify-content:center}
  .ns-info-strip{justify-content:center;text-align:center}
  .ns-step-label::before,.ns-step-label::after{width:20px}
}
@media(max-width:400px){
  .ns-btn{padding:10px 16px;font-size:13px}
  .ns-quality-btn{padding:8px 12px}
  .ns-step-card{padding:30px 14px}
}

/* ── SCROLL REVEAL ─────────────────────────────────────────── */
.ns-reveal{
  opacity:0;transform:translateY(20px);
  transition:opacity .5s ease,transform .5s ease;
}
.ns-reveal.ns-revealed{opacity:1;transform:translateY(0)}

/* ── AD SLOT WRAPPERS (front-end) ──────────────────────────── */
.ns-ad-slot-wrap{
  text-align:center;
}
.ns-ad-label{
  font-size:10px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);
  margin-bottom:7px;display:block;
}
.ns-footer-ad-wrap .ns-ad-label{margin-bottom:10px}
.ns-ad-zone{
  border-radius:10px;
  padding:14px;
  min-height:60px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
