/*
Theme Name:  NollyPrime
Theme URI:   https://nollyprime.ng
Author:      NollyPrime Media Ltd
Description: The official NollyPrime trade publication WordPress theme. Nollywood's editorial intelligence platform covering film, television, box office, the Commercial Index™, Hall of Fame™, and Rising Watchlist™.
Version:     2.0.0
License:     GNU General Public License v2 or later
Text Domain: nollyprime
Tags:        news, magazine, editorial, custom-logo, featured-images, full-width-template, wide-blocks
*/

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400;1,600&family=Source+Serif+4:ital,opsz,wght@0,8..60,300;0,8..60,400;0,8..60,600;1,8..60,400&family=Barlow:wght@400;500;600;700&family=Barlow+Condensed:wght@400;500;600;700&display=swap');

/* ═══════════════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════════════ */
:root {
  --np-paper:   #FAF8F3;
  --np-paper2:  #F2EEE4;
  --np-paper3:  #E8E3D8;
  --np-paper4:  #DDD7C8;
  --np-ink:     #0D0C0A;
  --np-ink2:    #2A2825;
  --np-ink3:    #6B6660;
  --np-ink4:    #9E9890;
  --np-gold:    #A67C00;
  --np-gold2:   #C9A235;
  --np-gold-bg: rgba(166,124,0,0.07);
  --np-gold-bd: rgba(166,124,0,0.25);
  --np-red:     #B92B27;
  --np-green:   #1A6E3C;
  --np-rule:    rgba(0,0,0,0.08);
  --np-rule2:   rgba(0,0,0,0.14);
  --np-ff-h:    'Playfair Display', Georgia, serif;
  --np-ff-b:    'Source Serif 4', Georgia, serif;
  --np-ff-ui:   'Barlow', sans-serif;
  --np-ff-c:    'Barlow Condensed', sans-serif;
}

/* ── BASE ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body { background:var(--np-paper); color:var(--np-ink); font-family:var(--np-ff-b); line-height:1.65; overflow-x:hidden; font-size:16px; max-width:100vw; }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; height:auto; }
button { cursor:pointer; font-family:inherit; }
input,textarea,select { font-family:inherit; }
ul,ol { list-style:none; }

/* ── TYPE ── */
.np-kicker { font-family:var(--np-ff-c); font-size:11px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--np-gold); margin-bottom:8px; }
.np-kicker.red   { color:var(--np-red); }
.np-kicker.muted { color:var(--np-ink4); }
.np-kicker.white { color:var(--np-paper2); }
.np-kicker.green { color:var(--np-green); }

.np-hed-xl { font-family:var(--np-ff-h); font-size:clamp(34px,5vw,64px);   font-weight:900; line-height:1.05; letter-spacing:-.025em; color:var(--np-ink); }
.np-hed-lg { font-family:var(--np-ff-h); font-size:clamp(24px,3vw,38px);   font-weight:700; line-height:1.12; letter-spacing:-.018em; color:var(--np-ink); }
.np-hed-md { font-family:var(--np-ff-h); font-size:clamp(18px,2vw,26px);   font-weight:700; line-height:1.2;  letter-spacing:-.01em;  color:var(--np-ink); }
.np-hed-sm { font-family:var(--np-ff-h); font-size:17px; font-weight:600; line-height:1.3;  color:var(--np-ink); }
.np-hed-xs { font-family:var(--np-ff-h); font-size:15px; font-weight:600; line-height:1.35; color:var(--np-ink); }

.np-deck    { font-family:var(--np-ff-b); font-size:15px; line-height:1.8;  color:var(--np-ink2); }
.np-deck.sm { font-size:13px; line-height:1.75; color:var(--np-ink3); }
.np-byline  { font-family:var(--np-ff-ui); font-size:11px; font-weight:500; letter-spacing:.04em; color:var(--np-ink4); text-transform:uppercase; }
.np-byline strong { color:var(--np-ink3); font-weight:600; }

.np-flag { font-family:var(--np-ff-c); font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--np-gold); display:flex; align-items:center; gap:12px; margin-bottom:24px; }
.np-flag::after { content:''; flex:1; height:1px; background:linear-gradient(90deg,var(--np-gold-bd),transparent); }
.np-flag.white { color:rgba(255,255,255,.5); }
.np-flag.white::after { background:linear-gradient(90deg,rgba(255,255,255,.15),transparent); }

.np-rm { font-family:var(--np-ff-c); font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--np-gold); display:inline-flex; align-items:center; gap:6px; margin-top:12px; transition:gap .2s; }
.np-rm:hover { gap:10px; }

/* ── LAYOUT ── */
.np-wrap { max-width:1280px; margin:0 auto; padding:0 40px; }
.np-section       { padding:52px 0; }
.np-section.alt   { background:var(--np-paper2); }
.np-section.dark  { background:var(--np-ink); color:var(--np-paper); }
.np-hr      { border:none; border-top:1px solid var(--np-rule); margin:36px 0; }
.np-hr-bold { border:none; border-top:2px solid var(--np-ink); margin:0; }
.np-hr-gold { border:none; border-top:2px solid var(--np-gold); margin:0; }

.np-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:36px; }
.np-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.np-grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.np-grid-5 { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.np-sidebar-layout { display:grid; grid-template-columns:1fr 300px; gap:48px; align-items:start; }

.np-sh { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:28px; gap:16px; flex-wrap:wrap; }
.np-view-all { font-family:var(--np-ff-c); font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--np-gold); border-bottom:1px solid var(--np-gold-bd); padding-bottom:2px; flex-shrink:0; }
.np-view-all:hover { border-color:var(--np-gold); }
.np-view-all.white { color:var(--np-gold2); border-color:rgba(201,162,53,.3); }

/* ── MASTHEAD ── */
.np-header { position:sticky; top:0; z-index:200; background:var(--np-paper); border-bottom:2px solid var(--np-ink); overflow:hidden; max-width:100vw; }
.np-mast-top { display:flex; align-items:center; justify-content:space-between; padding:16px 40px 12px; border-bottom:1px solid var(--np-rule2); }
.np-mast-date { font-family:var(--np-ff-ui); font-size:11px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--np-ink4); }
.np-mast-logo { text-align:center; flex:1; }
.np-logo-name { font-family:var(--np-ff-h); font-size:44px; font-weight:900; letter-spacing:-.02em; line-height:1; color:var(--np-ink); }
.np-logo-name .np-logo-accent { color:var(--np-gold); }
.np-logo-tag { font-family:var(--np-ff-ui); font-size:10px; font-weight:500; letter-spacing:.22em; text-transform:uppercase; color:var(--np-ink4); margin-top:4px; border-top:1px solid var(--np-rule2); padding-top:5px; }
.np-mast-right { display:flex; align-items:center; gap:12px; justify-content:flex-end; }

.np-btn-story { font-family:var(--np-ff-c); font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; background:var(--np-gold); color:var(--np-paper); border:none; padding:9px 20px; transition:background .2s; }
.np-btn-story:hover { background:var(--np-ink); }
.np-btn-sub { font-family:var(--np-ff-c); font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; background:var(--np-ink); color:var(--np-paper); border:none; padding:9px 20px; transition:background .2s; }
.np-btn-sub:hover { background:var(--np-gold); }

.np-sec-nav { display:flex; align-items:center; padding:0 40px; overflow-x:auto; scrollbar-width:none; max-width:100vw; -webkit-overflow-scrolling:touch; }
.np-sec-nav::-webkit-scrollbar { display:none; }
.np-sec-nav a { font-family:var(--np-ff-c); font-size:12px; font-weight:700; letter-spacing:.09em; text-transform:uppercase; color:var(--np-ink3); padding:11px 14px; border-bottom:3px solid transparent; white-space:nowrap; transition:color .2s,border-color .2s; flex-shrink:0; }
.np-sec-nav a:hover,.np-sec-nav a.current-menu-item,.np-sec-nav a.current_page_item { color:var(--np-gold); border-bottom-color:var(--np-gold); }
.np-sec-nav .np-nd { width:1px; height:14px; background:var(--np-rule2); margin:0 3px; flex-shrink:0; }

/* ── COVER SECTION ── */
.np-cover { background:var(--np-ink); min-height:88vh; display:grid; grid-template-columns:1fr 1fr; position:relative; overflow:hidden; }
.np-cover-photo { background:var(--np-ink2); position:relative; min-height:500px; overflow:hidden; }
.np-cover-photo img { width:100%; height:100%; object-fit:cover; opacity:.7; }
.np-cover-photo::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,transparent 40%,var(--np-ink) 100%); }
.np-cover-body { display:flex; flex-direction:column; justify-content:center; padding:80px 60px 100px 48px; position:relative; z-index:1; }
.np-cover-badge { display:inline-flex; align-items:center; gap:10px; margin-bottom:28px; }
.np-badge-tag { font-family:var(--np-ff-c); font-size:10px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; background:var(--np-gold2); color:var(--np-ink); padding:4px 12px; }
.np-badge-issue { font-family:var(--np-ff-ui); font-size:11px; color:rgba(255,255,255,.35); letter-spacing:.06em; }
.np-cover .np-hed-xl { color:var(--np-paper); margin-bottom:18px; }
.np-cover .np-deck { color:rgba(255,255,255,.5); max-width:460px; margin-bottom:28px; }
.np-cover-meta { display:flex; align-items:center; gap:20px; margin-top:10px; padding-top:20px; border-top:1px solid rgba(255,255,255,.08); }
.np-cover-scroll { position:absolute; bottom:0; left:0; right:0; background:rgba(10,10,10,.97); border-top:1px solid rgba(255,255,255,.06); display:flex; overflow-x:auto; scrollbar-width:none; }
.np-cover-scroll::-webkit-scrollbar { display:none; }
.np-cs-item { flex-shrink:0; width:240px; padding:22px 28px; border-right:1px solid rgba(255,255,255,.06); cursor:pointer; transition:background .2s; display:block; }
.np-cs-item:hover { background:rgba(255,255,255,.03); }
.np-cs-num { font-family:var(--np-ff-h); font-size:22px; font-weight:900; color:rgba(255,255,255,.07); line-height:1; margin-bottom:5px; }
.np-cs-kicker { font-family:var(--np-ff-c); font-size:9px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--np-gold2); margin-bottom:4px; }
.np-cs-title { font-family:var(--np-ff-h); font-size:13px; font-weight:600; line-height:1.35; color:rgba(255,255,255,.75); }

/* ── ARTICLE CARD ── */
.np-art-card { cursor:pointer; }
.np-art-card:hover .np-hed-sm,
.np-art-card:hover .np-hed-xs,
.np-art-card:hover .np-hed-md,
.np-art-card:hover .np-hed-lg { color:var(--np-gold); }
.np-art-card .np-thumb { overflow:hidden; margin-bottom:12px; }
.np-art-card .np-thumb img { width:100%; transition:transform .4s; }
.np-art-card:hover .np-thumb img { transform:scale(1.03); }
.np-col-list .np-art-card + .np-art-card { border-top:1px solid var(--np-rule); padding-top:18px; margin-top:18px; }

/* ── PHOTO PLACEHOLDER ── */
.np-photo-ph { background:var(--np-paper3); display:flex; align-items:center; justify-content:center; font-size:32px; opacity:.2; }
.np-photo-ph.wide    { aspect-ratio:16/9; }
.np-photo-ph.cinema  { aspect-ratio:21/9; }
.np-photo-ph.portrait{ aspect-ratio:2/3; }
.np-photo-ph.square  { aspect-ratio:1; }

/* ── BOX OFFICE ── */
.np-bo-table { width:100%; border-collapse:collapse; }
.np-bo-table thead { background:var(--np-ink); color:var(--np-paper); }
.np-bo-table th { font-family:var(--np-ff-c); font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; padding:13px 16px; text-align:left; }
.np-bo-table tbody tr { border-bottom:1px solid var(--np-rule); transition:background .15s; }
.np-bo-table tbody tr:hover { background:var(--np-gold-bg); }
.np-bo-table td { padding:13px 16px; vertical-align:middle; }
.np-bo-rank     { font-family:var(--np-ff-h); font-size:22px; font-weight:900; color:var(--np-gold); line-height:1; }
.np-bo-rank.dim { font-size:16px; color:var(--np-ink4); }
.np-bo-ft { font-family:var(--np-ff-h); font-size:15px; font-weight:600; color:var(--np-ink); line-height:1.2; }
.np-bo-fg { font-family:var(--np-ff-ui); font-size:10px; color:var(--np-ink4); text-transform:uppercase; letter-spacing:.06em; margin-top:2px; }
.np-up { color:var(--np-green); font-family:var(--np-ff-c); font-size:12px; font-weight:700; }
.np-dn { color:var(--np-red);   font-family:var(--np-ff-c); font-size:12px; font-weight:700; }
.np-fl { color:var(--np-ink4);  font-family:var(--np-ff-c); font-size:12px; font-weight:700; }
.np-pill { font-family:var(--np-ff-c); font-size:10px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; padding:3px 9px; border-radius:2px; }
.np-pill.cinema { background:rgba(26,110,60,.1);  color:var(--np-green); }
.np-pill.stream { background:var(--np-gold-bg);   color:var(--np-gold);  }
.np-pill.hybrid  { background:rgba(40,80,200,.08); color:#2855C0; }

/* ── CI CARDS ── */
.np-ci-card { background:var(--np-paper); border:1px solid var(--np-rule); padding:20px; cursor:pointer; transition:border-color .2s,box-shadow .2s; }
.np-ci-card:hover { border-color:var(--np-gold-bd); box-shadow:0 4px 20px rgba(0,0,0,.06); }
.np-ci-av { width:54px; height:54px; border-radius:50%; background:var(--np-paper3); border:1.5px solid var(--np-rule2); display:flex; align-items:center; justify-content:center; font-family:var(--np-ff-h); font-size:17px; font-weight:700; color:var(--np-gold); margin-bottom:12px; overflow:hidden; }
.np-ci-av img { width:100%; height:100%; object-fit:cover; }
.np-ci-score { font-family:var(--np-ff-h); font-size:28px; font-weight:900; color:var(--np-gold); line-height:1; }
.np-ci-score-lbl { font-family:var(--np-ff-ui); font-size:9px; font-weight:600; color:var(--np-ink4); letter-spacing:.1em; text-transform:uppercase; }

/* ── HOF CARDS ── */
.np-hof-card { border:1px solid var(--np-gold-bd); padding:24px; cursor:pointer; transition:background .2s,border-color .2s; position:relative; background:var(--np-paper); }
.np-hof-card:hover { background:var(--np-gold-bg); border-color:var(--np-gold); }
.np-hof-av { width:64px; height:64px; border-radius:50%; background:var(--np-paper2); border:2px solid var(--np-gold-bd); display:flex; align-items:center; justify-content:center; font-family:var(--np-ff-h); font-size:20px; font-weight:700; color:var(--np-gold); margin-bottom:14px; overflow:hidden; }
.np-hof-av img { width:100%; height:100%; object-fit:cover; }
.np-hof-star { position:absolute; top:14px; right:14px; width:28px; height:28px; background:var(--np-gold); display:flex; align-items:center; justify-content:center; font-size:12px; color:var(--np-paper); }

/* ── REVIEW CARDS ── */
.np-rev-card { border:1px solid var(--np-rule); overflow:hidden; cursor:pointer; transition:border-color .2s,transform .15s; background:var(--np-paper); }
.np-rev-card:hover { border-color:var(--np-gold-bd); transform:translateY(-2px); }
.np-rev-photo { position:relative; overflow:hidden; }
.np-rev-photo img,.np-rev-photo .np-photo-ph { width:100%; aspect-ratio:2/3; object-fit:cover; }
.np-rev-overlay { position:absolute; inset:0; background:linear-gradient(0deg,var(--np-paper2) 0%,transparent 55%); }
.np-rev-score-badge { position:absolute; bottom:14px; left:14px; }
.np-rev-score { font-family:var(--np-ff-h); font-size:36px; font-weight:900; color:var(--np-gold); line-height:1; }
.np-rev-score-sub { font-family:var(--np-ff-ui); font-size:9px; color:var(--np-gold); letter-spacing:.08em; text-transform:uppercase; }
.np-rec-tag { display:inline-block; font-family:var(--np-ff-c); font-size:9px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:3px 9px; border-radius:2px; margin-bottom:8px; }
.np-rec-must  { background:rgba(26,110,60,.1);  color:var(--np-green); }
.np-rec-good  { background:var(--np-gold-bg);   color:var(--np-gold);  }
.np-rec-mixed { background:rgba(180,100,0,.08); color:#B46400; }
.np-rec-skip  { background:rgba(185,43,39,.08); color:var(--np-red); }

/* ── RISING WATCHLIST CARDS ── */
.np-rw-card { border:1px solid rgba(26,110,60,.2); border-top:3px solid var(--np-green); background:var(--np-paper); padding:22px; cursor:pointer; transition:background .2s; }
.np-rw-card:hover { background:rgba(26,110,60,.03); }
.np-rw-tag { font-family:var(--np-ff-c); font-size:9px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--np-green); margin-bottom:8px; }

/* ── PROFILE CARDS (Voices/Interviews) ── */
.np-profile-card { border:1px solid var(--np-rule); background:var(--np-paper); overflow:hidden; cursor:pointer; transition:border-color .2s,transform .15s; }
.np-profile-card:hover { border-color:var(--np-gold-bd); transform:translateY(-2px); }
.np-profile-photo { aspect-ratio:16/9; overflow:hidden; }
.np-profile-photo img { width:100%; height:100%; object-fit:cover; }
.np-profile-av { width:60px; height:60px; border-radius:50%; background:var(--np-paper3); border:1.5px solid var(--np-rule2); display:flex; align-items:center; justify-content:center; font-family:var(--np-ff-h); font-size:19px; font-weight:700; color:var(--np-gold); overflow:hidden; margin-bottom:12px; }
.np-profile-av img { width:100%; height:100%; object-fit:cover; }
.np-quote-preview { font-family:var(--np-ff-h); font-size:14px; font-style:italic; line-height:1.5; color:var(--np-ink2); border-left:3px solid var(--np-gold); padding-left:12px; margin:10px 0; }

/* ── ANALYSIS CARDS ── */
.np-analysis-card { border:1px solid var(--np-rule); background:var(--np-paper); overflow:hidden; cursor:pointer; transition:border-color .2s; }
.np-analysis-card:hover { border-color:var(--np-gold-bd); }
.np-analysis-card-header { padding:28px; border-bottom:1px solid var(--np-rule); background:var(--np-paper2); }
.np-analysis-card-body { padding:22px; }
.np-analysis-num { font-family:var(--np-ff-h); font-size:52px; font-weight:900; color:var(--np-paper3); line-height:1; margin-bottom:12px; }
.np-data-callout { background:var(--np-gold-bg); border:1px solid var(--np-gold-bd); padding:16px; margin-bottom:10px; }
.np-data-num { font-family:var(--np-ff-h); font-size:30px; font-weight:900; color:var(--np-gold); letter-spacing:-.02em; line-height:1; }
.np-data-lbl { font-family:var(--np-ff-ui); font-size:10px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--np-ink4); margin-top:3px; }

/* ── SINGLE ARTICLE ── */
.np-article-layout { display:grid; grid-template-columns:1fr 300px; gap:52px; align-items:start; }
.np-article-header { padding-bottom:28px; border-bottom:1px solid var(--np-rule); margin-bottom:28px; }
.np-article-meta { display:flex; align-items:center; gap:20px; flex-wrap:wrap; padding:12px 0; border-top:1px solid var(--np-rule); border-bottom:1px solid var(--np-rule); margin:14px 0; }
.np-article-cover { margin-bottom:32px; overflow:hidden; }
.np-article-cover img { width:100%; max-height:500px; object-fit:cover; }
.np-article-body p { font-family:var(--np-ff-b); font-size:16px; line-height:1.85; color:var(--np-ink2); margin-bottom:22px; }
.np-article-body p.drop-cap::first-letter { font-family:var(--np-ff-h); font-size:64px; font-weight:900; line-height:.8; float:left; margin:8px 12px 0 0; color:var(--np-gold); }
.np-article-body h2,.np-article-body h3 { font-family:var(--np-ff-h); font-size:22px; font-weight:700; color:var(--np-ink); margin:36px 0 14px; padding-top:8px; border-top:2px solid var(--np-ink); }
.np-article-body blockquote { border-left:4px solid var(--np-gold); padding:20px 24px; margin:32px 0; background:var(--np-gold-bg); }
.np-article-body blockquote p { font-family:var(--np-ff-h); font-size:20px; font-weight:700; font-style:italic; line-height:1.4; color:var(--np-ink); margin-bottom:0; }
.np-article-body ul,.np-article-body ol { font-family:var(--np-ff-b); font-size:15px; line-height:1.85; color:var(--np-ink2); padding-left:22px; margin-bottom:22px; list-style:initial; }
.np-article-body ul li,.np-article-body ol li { margin-bottom:8px; }
.np-article-body img { max-width:100%; height:auto; margin:24px 0; }
.np-article-body a { color:var(--np-gold); border-bottom:1px solid var(--np-gold-bd); }
.np-article-body strong { color:var(--np-ink); font-weight:600; }
.np-article-end { border:none; border-top:2px solid var(--np-ink); margin:40px 0 32px; }
.np-author-bio { display:flex; gap:16px; padding:24px; background:var(--np-paper2); border:1px solid var(--np-rule); }
.np-author-av { width:56px; height:56px; border-radius:50%; background:var(--np-paper3); border:1.5px solid var(--np-rule2); display:flex; align-items:center; justify-content:center; font-family:var(--np-ff-h); font-size:18px; font-weight:700; color:var(--np-gold); flex-shrink:0; overflow:hidden; }
.np-author-av img { width:100%; height:100%; object-fit:cover; }

/* ── SIDEBAR ── */
.np-sidebar { display:flex; flex-direction:column; gap:28px; position:sticky; top:80px; }
.np-sw { border-top:2px solid var(--np-ink); padding-top:18px; }
.np-sw-title { font-family:var(--np-ff-c); font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--np-ink); margin-bottom:14px; }
.np-sw-list { display:flex; flex-direction:column; }
.np-sw-item { display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--np-rule); cursor:pointer; }
.np-sw-item:last-child { border-bottom:none; }
.np-sw-num { font-family:var(--np-ff-h); font-size:18px; font-weight:900; color:var(--np-paper4); line-height:1; flex-shrink:0; padding-top:2px; }
.np-sw-item-t { font-family:var(--np-ff-h); font-size:13px; font-weight:600; line-height:1.35; color:var(--np-ink); }
.np-sw-item:hover .np-sw-item-t { color:var(--np-gold); }
.np-sw-meta { font-family:var(--np-ff-ui); font-size:10px; color:var(--np-ink4); letter-spacing:.04em; margin-top:3px; text-transform:uppercase; }

/* ── PAGE HERO ── */
.np-page-hero { background:var(--np-ink); padding:56px 0 44px; border-bottom:3px solid var(--np-gold); }
.np-page-hero.light { background:var(--np-paper2); border-bottom:2px solid var(--np-ink); }
.np-page-hero .np-hed-xl { color:var(--np-paper); }
.np-page-hero.light .np-hed-xl { color:var(--np-ink); }
.np-page-hero .np-deck { color:rgba(255,255,255,.45); max-width:540px; margin-top:12px; }
.np-page-hero.light .np-deck { color:var(--np-ink3); }
.np-ph-kicker { font-family:var(--np-ff-c); font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--np-gold2); margin-bottom:14px; }
.np-page-hero.light .np-ph-kicker { color:var(--np-gold); }

/* ── NEWSLETTER ── */
.np-newsletter { background:var(--np-ink); padding:68px 0; }
.np-nl-inner { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.np-nl-title { font-family:var(--np-ff-h); font-size:clamp(26px,3.5vw,40px); font-weight:900; letter-spacing:-.025em; line-height:1.1; color:var(--np-paper); margin-bottom:14px; }
.np-nl-desc  { font-family:var(--np-ff-b); font-size:14px; color:var(--np-ink4); line-height:1.8; }
.np-nl-perk  { display:flex; align-items:center; gap:10px; font-family:var(--np-ff-b); font-size:13px; color:rgba(255,255,255,.5); margin-top:10px; }
.np-nl-perk::before { content:'✓'; color:var(--np-gold2); font-size:11px; font-weight:700; font-family:var(--np-ff-ui); }
.np-nl-form  { display:flex; border:1.5px solid rgba(255,255,255,.15); margin-top:24px; overflow:hidden; }
.np-nl-input { flex:1; background:rgba(255,255,255,.06); border:none; outline:none; font-family:var(--np-ff-b); font-size:14px; color:var(--np-paper); padding:14px 18px; }
.np-nl-input::placeholder { color:rgba(255,255,255,.3); }
.np-nl-btn   { background:var(--np-gold2); border:none; color:var(--np-ink); font-family:var(--np-ff-c); font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:14px 22px; white-space:nowrap; transition:background .2s; cursor:pointer; }
.np-nl-btn:hover { background:var(--np-gold); }
.np-nl-trust { font-family:var(--np-ff-ui); font-size:10px; color:rgba(255,255,255,.2); letter-spacing:.06em; margin-top:10px; }

/* ── FOOTER ── */
.np-footer { background:var(--np-ink2); border-top:3px solid var(--np-gold); padding:52px 0 26px; }
.np-ft-grid { display:grid; grid-template-columns:260px 1fr; gap:64px; margin-bottom:44px; }
.np-ft-name { font-family:var(--np-ff-h); font-size:26px; font-weight:900; color:var(--np-paper); margin-bottom:12px; }
.np-ft-name span { color:var(--np-gold2); }
.np-ft-desc { font-family:var(--np-ff-b); font-size:12px; color:rgba(255,255,255,.3); line-height:1.8; margin-bottom:18px; }
.np-ft-soc  { display:flex; gap:8px; }
.np-ft-soc-btn { width:32px; height:32px; border:1px solid rgba(255,255,255,.12); background:none; color:rgba(255,255,255,.3); display:flex; align-items:center; justify-content:center; font-size:12px; transition:border-color .2s,color .2s; cursor:pointer; }
.np-ft-soc-btn:hover { border-color:var(--np-gold2); color:var(--np-gold2); }
.np-ft-lnk-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.np-ft-col-h { font-family:var(--np-ff-c); font-size:10px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.25); margin-bottom:14px; padding-bottom:8px; border-bottom:1px solid rgba(255,255,255,.07); }
.np-ft-links { list-style:none; display:flex; flex-direction:column; gap:8px; }
.np-ft-links a { font-family:var(--np-ff-ui); font-size:12px; color:rgba(255,255,255,.35); transition:color .2s; }
.np-ft-links a:hover { color:var(--np-gold2); }
.np-ft-btm { border-top:1px solid rgba(255,255,255,.07); padding-top:22px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.np-ft-copy { font-family:var(--np-ff-ui); font-size:10px; color:rgba(255,255,255,.2); letter-spacing:.06em; }
.np-ft-tm   { font-family:var(--np-ff-ui); font-size:10px; color:rgba(255,255,255,.2); text-align:right; line-height:1.9; }

/* ── PAGINATION ── */
.np-pagination { display:flex; align-items:center; gap:4px; margin-top:48px; padding-top:28px; border-top:1px solid var(--np-rule); flex-wrap:wrap; }
.np-pagination .page-numbers { font-family:var(--np-ff-c); font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:8px 14px; border:1.5px solid var(--np-rule2); color:var(--np-ink3); transition:all .2s; }
.np-pagination .page-numbers:hover { border-color:var(--np-gold); color:var(--np-gold); }
.np-pagination .page-numbers.current { background:var(--np-ink); color:var(--np-paper); border-color:var(--np-ink); }

/* ── SEARCH ── */
.np-search-form { display:flex; border:1.5px solid var(--np-rule2); overflow:hidden; }
.np-search-form input[type="search"] { flex:1; background:var(--np-paper); border:none; outline:none; font-family:var(--np-ff-b); font-size:14px; color:var(--np-ink); padding:12px 16px; }
.np-search-form button { background:var(--np-ink); border:none; color:var(--np-paper); font-family:var(--np-ff-c); font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:12px 20px; transition:background .2s; cursor:pointer; }
.np-search-form button:hover { background:var(--np-gold); }

/* ── DIM BAR (dimension scores) ── */
.np-dim-row { display:flex; align-items:center; gap:8px; margin-bottom:6px; }
.np-dim-lbl { font-family:var(--np-ff-ui); font-size:10px; color:var(--np-ink4); width:150px; flex-shrink:0; }
.np-dim-bg  { flex:1; height:4px; background:var(--np-paper3); border-radius:2px; overflow:hidden; }
.np-dim-fill{ height:100%; background:var(--np-gold); border-radius:2px; }
.np-dim-val { font-family:var(--np-ff-c); font-size:11px; font-weight:700; color:var(--np-ink); width:28px; text-align:right; flex-shrink:0; }

/* ── RESPONSIVE ── */
/* ── TABLET ── */
@media(max-width:1024px){
  .np-wrap { padding:0 24px; }
  .np-mast-top { padding:14px 24px 10px; }
  .np-sec-nav { padding:0 24px; }
  .np-cover { grid-template-columns:1fr; min-height:auto; }
  .np-cover-photo { min-height:300px; }
  .np-cover-body { padding:60px 24px 180px; }
  .np-grid-3 { grid-template-columns:1fr 1fr; }
  .np-grid-4 { grid-template-columns:1fr 1fr; }
  .np-grid-5 { grid-template-columns:repeat(3,1fr); }
  .np-sidebar-layout { grid-template-columns:1fr; }
  .np-article-layout { grid-template-columns:1fr; }
  .np-nl-inner { grid-template-columns:1fr; gap:36px; }
  .np-ft-grid { grid-template-columns:1fr; gap:32px; }
  .np-ft-lnk-grid { grid-template-columns:1fr 1fr; }
  .np-sidebar { position:static; top:auto; }
}

/* ── LARGE PHONE (641px → never hits 640 fix below) ── */
@media(max-width:640px){
  .np-wrap { padding:0 16px; }
  .np-mast-date { display:none; }
  .np-mast-top { padding:12px 16px 10px; }
  .np-sec-nav { padding:0 16px; }
  .np-logo-name { font-size:30px; }
  .np-logo-tag { font-size:9px; letter-spacing:.14em; }
  .np-grid-3 { grid-template-columns:1fr; }
  .np-grid-2 { grid-template-columns:1fr; }
  .np-grid-4 { grid-template-columns:1fr 1fr; gap:14px; }
  .np-grid-5 { grid-template-columns:1fr 1fr; gap:12px; }
  .np-cover-body { padding:40px 16px 200px; }
  .np-cover-scroll { display:none; }
  .np-ft-lnk-grid { grid-template-columns:1fr 1fr; }
  .np-section { padding:36px 0; }
  .np-nl-input { font-size:13px; }
  .np-nl-form { flex-direction:column; }
  .np-nl-btn { width:100%; padding:14px; }
  .np-hed-xl { font-size:clamp(26px,7vw,36px); }
  .np-hed-lg { font-size:clamp(20px,5.5vw,28px); }
  .np-article-body p { font-size:15px; }
  .np-ft-grid { gap:24px; }
  .np-lead-grid,
  .np-int-featured-grid,
  .np-rw-featured-grid { grid-template-columns:1fr !important; }
}

/* ── SMALL PHONE (≤480px — most Android/iPhone SE) ── */
@media(max-width:480px){
  .np-wrap { padding:0 14px; }
  .np-mast-top { padding:10px 14px 8px; flex-wrap:wrap; gap:6px; }
  .np-mast-logo { flex:none; width:100%; text-align:left; }
  .np-mast-right { display:none; }
  .np-logo-name { font-size:26px; }
  .np-logo-tag { display:none; }
  .np-sec-nav { padding:0 14px; }
  .np-sec-nav a { font-size:11px; padding:10px 10px; letter-spacing:.06em; }
  .np-section { padding:28px 0; }
  .np-cover-body { padding:32px 14px 80px; }
  .np-cover-scroll { display:none; }
  .np-hed-xl { font-size:clamp(22px,7.5vw,30px); letter-spacing:-.015em; }
  .np-hed-lg { font-size:clamp(18px,6vw,24px); }
  .np-hed-md { font-size:clamp(16px,5vw,20px); }
  .np-hed-sm { font-size:15px; }
  .np-deck { font-size:14px; }
  .np-grid-4 { grid-template-columns:1fr; }
  .np-grid-5 { grid-template-columns:1fr; }
  .np-flag { font-size:10px; letter-spacing:.12em; }
  .np-newsletter { padding:40px 0; }
  .np-nl-title { font-size:22px; }
  .np-nl-form { flex-direction:column; }
  .np-nl-btn { width:100%; padding:13px; }
  .np-ft-lnk-grid { grid-template-columns:1fr 1fr; gap:16px; }
  .np-footer { padding:36px 0 20px; }
  .np-ft-name { font-size:22px; }
  .np-page-hero { padding:36px 0 28px; }
  .np-article-body p { font-size:15px; line-height:1.75; }
  .np-article-body blockquote p { font-size:17px; }
  .np-bo-table th, .np-bo-table td { padding:10px 10px; font-size:11px; }
  .np-bo-rank { font-size:17px; }
  .np-ci-card { padding:14px; }
  .np-hof-card { padding:18px; }
  .np-lead-grid,
  .np-int-featured-grid,
  .np-rw-featured-grid { grid-template-columns:1fr !important; }
}

/* ── VERY SMALL PHONE (≤380px — Galaxy A series, older iPhones) ── */
@media(max-width:380px){
  .np-wrap { padding:0 12px; }
  .np-logo-name { font-size:22px; }
  .np-sec-nav a { font-size:10px; padding:9px 8px; }
  .np-hed-xl { font-size:22px; }
  .np-hed-lg { font-size:18px; }
  .np-grid-4 { grid-template-columns:1fr; }
  .np-ft-lnk-grid { grid-template-columns:1fr; }
  .np-bo-table th, .np-bo-table td { padding:8px 7px; font-size:10px; }
}

/* ── WP COMPATIBILITY ── */
.wp-block-image { margin:24px 0; }
.wp-block-quote { border-left:4px solid var(--np-gold); padding:20px 24px; margin:32px 0; background:var(--np-gold-bg); }
.wp-block-quote p { font-family:var(--np-ff-h); font-size:20px; font-weight:700; font-style:italic; line-height:1.4; color:var(--np-ink); }
.aligncenter { text-align:center; margin-left:auto; margin-right:auto; display:block; }
.alignleft  { float:left;  margin:0 24px 16px 0; }
.alignright { float:right; margin:0 0 16px 24px; }
.wp-caption-text { font-family:var(--np-ff-ui); font-size:11px; color:var(--np-ink4); font-style:italic; margin-top:8px; }
.screen-reader-text { position:absolute; width:1px; height:1px; clip:rect(0,0,0,0); overflow:hidden; }
